| | |
| | | package com.zy.asrs.controller; |
| | | |
| | | import com.alibaba.fastjson.JSON; |
| | | import com.core.annotations.AppAuth; |
| | | import com.core.common.*; |
| | | 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.entity.ErpOrder; |
| | | import com.zy.asrs.entity.ErpOrderDetl; |
| | | import com.zy.asrs.entity.param.*; |
| | | import com.zy.asrs.entity.ErpMat; |
| | | import com.zy.asrs.service.ErpOrderDetlService; |
| | | import com.zy.asrs.service.ErpOrderService; |
| | | import com.zy.asrs.service.OpenService; |
| | | import com.zy.asrs.service.ErpMatService; |
| | | import com.zy.common.model.DetlDto; |
| | | import com.zy.common.web.BaseController; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.beans.factory.annotation.Value; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.springframework.web.bind.annotation.*; |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | import javax.servlet.http.HttpServletRequest; |
| | | import java.io.IOException; |
| | | import java.util.*; |
| | | import java.util.concurrent.ConcurrentHashMap; |
| | | |
| | | /** |
| | | * 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>() {{ |
| | |
| | | |
| | | @Autowired |
| | | private OpenService openService; |
| | | @Autowired |
| | | private ErpMatService erpMatService; |
| | | @Autowired |
| | | private ErpOrderService erpOrderService; |
| | | @Autowired |
| | | private ErpOrderDetlService erpOrderDetlService; |
| | | @Value("${open-asrs.auth.app-id:wms_8f7c3d126a944e3ab5c89d21f4a7c6b2}") |
| | | private String openAppId; |
| | | |
| | | @Value("${open-asrs.auth.app-secret:D9f3A7xP1kLm8Q2tW5zH0sY6vR4bNcE7FjK3uM9pT2aL8qX6}") |
| | | private String openAppSecret; |
| | | |
| | | @Value("${open-asrs.auth.token-valid-minutes:30}") |
| | | private Integer tokenValidMinutes; |
| | | |
| | | /****************************************************************************/ |
| | | /********************************* 打包上线 **********************************/ |
| | | /****************************************************************************/ |
| | | private static final Map<String, TokenInfoParam> TOKEN_CACHE = new ConcurrentHashMap<>(); |
| | | |
| | | |
| | | @PostMapping("/order/pakin/new/package/v1") |
| | | public synchronized R pakinOrderPackage(@RequestHeader(required = false) String appkey, |
| | | @RequestParam(required = false) String barcode) { |
| | | auth(appkey, barcode); |
| | | if (Cools.isEmpty(barcode)) { |
| | | @PostMapping("/getToken") |
| | | public synchronized R getToken(@RequestBody(required = false) Map<String, String> param) { |
| | | log.info("{}接口被访问;请求数据:{}", "/getToken", JSON.toJSONString(param)); |
| | | if (Cools.isEmpty(param)) { |
| | | return R.parse(BaseRes.PARAM); |
| | | } |
| | | openService.packageUp(barcode); |
| | | |
| | | String appId = param.get("appId"); |
| | | String appSecret = param.get("appSecret"); |
| | | if (Cools.isEmpty(appId)) { |
| | | return R.error("参数[appId]不能为空"); |
| | | } |
| | | if (Cools.isEmpty(appSecret)) { |
| | | return R.error("参数[appSecret]不能为空"); |
| | | } |
| | | if (Cools.isEmpty(openAppId) || Cools.isEmpty(openAppSecret)) { |
| | | throw new CoolException("系统未配置open-asrs.auth.app-id或open-asrs.auth.app-secret"); |
| | | } |
| | | if (!openAppId.equals(appId) || !openAppSecret.equals(appSecret)) { |
| | | throw new CoolException("认证失败,请确认appId或appSecret无误!"); |
| | | } |
| | | |
| | | String token = UUID.randomUUID().toString().replace("-", ""); |
| | | long expireAt = System.currentTimeMillis() + tokenValidMinutes * 60L * 1000L; |
| | | TOKEN_CACHE.put(token, new TokenInfoParam(appId, expireAt)); |
| | | |
| | | Map<String, Object> result = new HashMap<>(); |
| | | result.put("token", token); |
| | | result.put("validTime", tokenValidMinutes); |
| | | return R.ok().add(result); |
| | | } |
| | | |
| | | public static boolean validToken(String authorization) { |
| | | if (Cools.isEmpty(authorization)) { |
| | | return false; |
| | | } |
| | | TokenInfoParam tokenInfo = TOKEN_CACHE.get(authorization); |
| | | if (tokenInfo == null) { |
| | | return false; |
| | | } |
| | | if (System.currentTimeMillis() > tokenInfo.getExpireAt()) { |
| | | TOKEN_CACHE.remove(authorization); |
| | | return false; |
| | | } |
| | | return true; |
| | | } |
| | | @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("/erp/mat/sync") |
| | | public synchronized R erpMatSync(@RequestBody(required = false) List<Map<String, Object>> body, |
| | | HttpServletRequest request) { |
| | | auth(null, body, request); |
| | | if (Cools.isEmpty(body)) { |
| | | return R.parse(BaseRes.PARAM); |
| | | } |
| | | openService.syncErpMat(body); |
| | | Map<String, Object> res = new HashMap<>(); |
| | | res.put("result", "SUCCESS"); |
| | | return R.ok().add(res); |
| | | } |
| | | |
| | | @PostMapping("/erp/order/addPrd") |
| | | public synchronized R erpOrderAddPrd(@RequestBody Object body, |
| | | HttpServletRequest request) { |
| | | List<OrderDto> orders; |
| | | if (body instanceof List) { |
| | | orders = JSON.parseArray(JSON.toJSONString(body), OrderDto.class); |
| | | } else { |
| | | OrderDto dto = JSON.parseObject(JSON.toJSONString(body), OrderDto.class); |
| | | orders = new ArrayList<>(); |
| | | orders.add(dto); |
| | | } |
| | | auth(null, orders, request); |
| | | if (Cools.isEmpty(orders)) { |
| | | return R.parse(BaseRes.PARAM); |
| | | } |
| | | return R.ok().add(openService.addErpOrder(orders)); |
| | | } |
| | | |
| | | @PostMapping("/erp/order/addQc") |
| | | public synchronized R erpOrderAddQc(@RequestBody Object body, |
| | | HttpServletRequest request) { |
| | | List<OrderDto> orders; |
| | | if (body instanceof List) { |
| | | orders = JSON.parseArray(JSON.toJSONString(body), OrderDto.class); |
| | | } else { |
| | | OrderDto dto = JSON.parseObject(JSON.toJSONString(body), OrderDto.class); |
| | | orders = new ArrayList<>(); |
| | | orders.add(dto); |
| | | } |
| | | auth(null, orders, request); |
| | | if (Cools.isEmpty(orders)) { |
| | | return R.parse(BaseRes.PARAM); |
| | | } |
| | | return R.ok().add(openService.addErpOrder(orders)); |
| | | } |
| | | |
| | | @PostMapping("/erp/order/addSrm") |
| | | public synchronized R erpOrderAddSrm(@RequestBody Object body, |
| | | HttpServletRequest request) { |
| | | List<OrderDto> orders; |
| | | if (body instanceof List) { |
| | | orders = JSON.parseArray(JSON.toJSONString(body), OrderDto.class); |
| | | } else { |
| | | OrderDto dto = JSON.parseObject(JSON.toJSONString(body), OrderDto.class); |
| | | orders = new ArrayList<>(); |
| | | orders.add(dto); |
| | | } |
| | | auth(null, orders, request); |
| | | if (Cools.isEmpty(orders)) { |
| | | return R.parse(BaseRes.PARAM); |
| | | } |
| | | return R.ok().add(openService.addErpOrder(orders)); |
| | | } |
| | | |
| | | @PostMapping("/MES/inventory/details") |
| | | public synchronized R mesInventoryDetails(@RequestBody(required = false) Map<String, Object> param, |
| | | HttpServletRequest request) throws IOException { |
| | | auth(null, param, request); |
| | | if (param == null) { |
| | | param = new HashMap<>(); |
| | | } |
| | | return R.ok().add(openService.mesInventoryDetails(param)); |
| | | } |
| | | |
| | | @PostMapping("/MES/inventory/summary") |
| | | public synchronized R mesInventorySummary(@RequestBody(required = false) Map<String, Object> param, |
| | | HttpServletRequest request) throws IOException { |
| | | auth(null, param, request); |
| | | if (param == null) { |
| | | param = new HashMap<>(); |
| | | } |
| | | return R.ok().add(openService.mesInventorySummary(param)); |
| | | } |
| | | |
| | | |
| | | /** |
| | | * 添加入库单 |
| | | */ |
| | | @PostMapping("/order/pakin/new/default/v1") |
| | | @PostMapping("/order/pakin/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") |
| | | @PostMapping("/order/pakout/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()); |
| | | } |
| | | |
| | | |
| | | private void auth(String appkey, Object obj) { |
| | | log.info("{}接口被访问!appkey:{},请求数据:{}", "open/sensorType/list/auth/v1", appkey, JSON.toJSONString(obj)); |
| | | private void auth(String appkey, Object obj, HttpServletRequest request) { |
| | | log.info("{}接口被访问;token:{};请求数据:{}", "open/sensorType/list/auth/v1", request.getHeader("Authorization"), JSON.toJSONString(obj)); |
| | | request.setAttribute("cache", obj); |
| | | if (!auth) { |
| | | return; |
| | | } |
| | | if (Cools.isEmpty(appkey)) { |
| | | throw new CoolException("认证失败,请确认appkey无误!"); |
| | | String authorization = request.getHeader("Authorization"); |
| | | if (Cools.isEmpty(authorization)) { |
| | | authorization = request.getHeader("authorization"); |
| | | } |
| | | if (!APP_KEY_LIST.contains(appkey)) { |
| | | throw new CoolException("认证失败,请确认appkey无误!"); |
| | | if (!Cools.isEmpty(authorization)) { |
| | | String val = authorization.trim(); |
| | | if (val.toLowerCase().startsWith("bearer")) { |
| | | int idx = val.indexOf(' '); |
| | | authorization = idx > -1 ? val.substring(idx + 1).trim() : ""; |
| | | } else { |
| | | authorization = val; |
| | | } |
| | | } |
| | | if (!Cools.isEmpty(authorization)) { |
| | | if (validToken(authorization)) { |
| | | return; |
| | | } |
| | | throw new CoolException("认证失败,请确认Authorization无误!"); |
| | | } |
| | | throw new CoolException("认证失败,请确认Authorization无误!"); |
| | | } |
| | | |
| | | public static void main(String[] args) { |