From bab6283f5c0b5da44b7a342f9daef35473a13ab7 Mon Sep 17 00:00:00 2001
From: dubin <bindu_bean@163.com>
Date: 星期四, 16 四月 2026 14:54:57 +0800
Subject: [PATCH] 初始化
---
src/main/java/com/zy/asrs/controller/OpenController.java | 219 +++++++++++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 214 insertions(+), 5 deletions(-)
diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java
index 94e16c3..908b7a6 100644
--- a/src/main/java/com/zy/asrs/controller/OpenController.java
+++ b/src/main/java/com/zy/asrs/controller/OpenController.java
@@ -1,25 +1,29 @@
package com.zy.asrs.controller;
import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
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.WrkMast;
import com.zy.asrs.entity.param.*;
+import com.zy.asrs.entity.vo.OpenInventoryVo;
+import com.zy.asrs.entity.vo.TokenVo;
+import com.zy.asrs.mapper.LocDetlMapper;
import com.zy.asrs.service.OpenService;
import com.zy.asrs.service.WrkMastService;
-import com.zy.common.model.DetlDto;
+import com.zy.common.service.wms.Result;
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.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
+import java.util.concurrent.ConcurrentHashMap;
+import java.util.stream.Collectors;
/**
* Created by vincent on 2022/4/8
@@ -38,6 +42,19 @@
private OpenService openService;
@Autowired
private WrkMastService wrkMastService;
+ @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, TokenVo> TOKEN_CACHE = new ConcurrentHashMap<>();
+
+ @Autowired
+ private LocDetlMapper locDetlMapper;
@GetMapping("/order/delete/v1")
@AppAuth(memo = "璁㈠崟淇℃伅鍒犻櫎")
@@ -281,4 +298,196 @@
}
+ /*=============================================NEW===================================================*/
+ private void authNew(String appkey, Object obj, HttpServletRequest request, String url) {
+ log.info("{}鎺ュ彛琚闂紱appkey:{}锛涜姹傛暟鎹細{}", url, appkey, JSON.toJSONString(obj));
+ request.setAttribute("cache", obj);
+ if (!auth) {
+ return;
+ }
+ String authorization = request.getHeader("Authorization");
+ if (Cools.isEmpty(authorization)) {
+ authorization = request.getHeader("authorization");
+ }
+ 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 boolean validToken(String authorization) {
+ if (Cools.isEmpty(authorization)) {
+ return false;
+ }
+ TokenVo tokenInfo = TOKEN_CACHE.get(authorization);
+ if (tokenInfo == null) {
+ return false;
+ }
+ if (System.currentTimeMillis() > tokenInfo.getValidTime()) {
+ TOKEN_CACHE.remove(authorization);
+ return false;
+ }
+ return true;
+ }
+
+ /**
+ * 鑾峰彇Token
+ * @param appkey
+ * @param param
+ * @param request
+ * @return
+ */
+ @PostMapping("/getToken")
+ public synchronized R getToken(@RequestHeader(required = false) String appkey,
+ @RequestBody(required = false) TokenParam param,
+ HttpServletRequest request){
+// authNew(appkey, param, request, "鑾峰彇Token:/getToken");
+ log.info("鑾峰彇Token:/getToken鎺ュ彛琚闂紝appkey={},璇锋眰鏁版嵁={}", appkey, JSON.toJSONString(param));
+ if (Cools.isEmpty(param)){
+ return R.parse(BaseRes.PARAM);
+ }
+
+ String appId = param.getAppId();
+ String appSecret = param.getAppSecret();
+ 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("绯荤粺鏈厤缃畂pen-asrs.auth.app-id鎴杘pen-asrs.auth.app-secret");
+ }
+ if (!openAppId.equals(appId) || !openAppSecret.equals(appSecret)){
+ throw new CoolException("璁よ瘉澶辫触锛岃纭appId鎴朼ppSecret鏃犺锛�");
+ }
+
+ String token = UUID.randomUUID().toString().replaceAll("-", "");
+ long expireAt = System.currentTimeMillis() + tokenValidMinutes * 60L *1000L;
+ TOKEN_CACHE.put(token, new TokenVo(appId, expireAt));
+
+ Map<String, Object> result = new HashMap<>();
+ result.put("token", token);
+ result.put("expireAt", tokenValidMinutes);
+ return R.ok().add(result);
+ }
+
+ /**
+ *鐗╂枡鍩虹淇℃伅鍚屾
+ * @param appKey
+ * @param param
+ * @param request
+ * @return
+ */
+ @PostMapping("/erp/mat/sync")
+ public synchronized R syncMatInfoV2(@RequestHeader(required = false) String appKey,
+ @RequestBody(required = false) List<MatSyncParam.MatParam> param,
+ HttpServletRequest request){
+ authNew(appKey, param, request, "鐗╂枡鍩虹淇℃伅鍚屾:/erp/mat/sync");
+ if (Cools.isEmpty(param)) {
+ return R.parse(BaseRes.PARAM);
+ }
+ MatSyncParam matSyncParam = new MatSyncParam();
+ List<MatSyncParam.MatParam> objects = new ArrayList<>();
+ objects = param;
+ matSyncParam.matDetails = objects;
+
+ openService.syncMat(matSyncParam);
+ return R.ok();
+ }
+
+ /**
+ * 鍏�/鍑哄簱閫氱煡鍗曚笅鍙�
+ * @param appKey
+ * @param param
+ * @param request
+ * @return
+ */
+ @PostMapping("/erp/order/add")
+ public synchronized R addOrder(@RequestHeader(required = false) String appKey,
+ @RequestBody OpenOrderParam param,
+ HttpServletRequest request){
+ authNew(appKey, param, request, "鍏�/鍑哄簱閫氱煡鍗曚笅鍙�:/erp/order/add");
+ if (Cools.isEmpty(param)) {
+ return R.parse(BaseRes.PARAM);
+ }
+ if (Cools.isEmpty(param.getOrderNo())){
+ return R.error("鍗曟嵁缂栧彿[orderNo]涓嶈兘涓虹┖");
+ }
+ if (Cools.isEmpty(param.getOrderType())){
+ return R.error("鍗曟嵁绫诲瀷[orderType]涓嶈兘涓虹┖");
+ }
+ if (Cools.isEmpty(param.getWkType())){
+ return R.error("涓氬姟绫诲瀷[wkType]涓嶈兘涓虹┖");
+ }
+ if (Cools.isEmpty(param.getOrderItems())){
+ return R.error("璁㈠崟鏄庣粏[orderItems]涓嶈兘涓虹┖");
+ }
+ openService.orderCreate(param);
+ return R.ok();
+ }
+
+ /**
+ * 搴撳瓨鏄庣粏鏌ヨ
+ * @param appKey
+ * @param param
+ * @param request
+ * @return
+ */
+ @PostMapping("/erp/inventory/details")
+ public synchronized Result inventory(@RequestHeader(required = false) String appKey,
+ @RequestBody JSONObject param,
+ HttpServletRequest request){
+ authNew(appKey, param, request, "搴撳瓨鏄庣粏鏌ヨ:/erp/inventory/details");
+ try {
+ String wareHouseId = param == null ? null : param.getString("wareHouseId");
+ String locId = param == null ? null : param.getString("locId");
+ String matNr = param == null ? null : param.getString("matNr");
+ String orderNo = param == null ? null : param.getString("orderNo");
+ String batch = param == null ? null : param.getString("batch");
+ return new Result(200, "鎿嶄綔鎴愬姛", locDetlMapper.inventory(wareHouseId, locId, matNr, orderNo, batch));
+ }catch (Exception e){
+ return new Result(500, e.getMessage(), null);
+ }
+ }
+
+ /**
+ * 搴撳瓨姹囨�绘煡璇�
+ * @param appKey
+ * @param param
+ * @param request
+ * @return
+ */
+ @PostMapping("/erp/inventory/summary")
+ public synchronized Result invSummary(@RequestHeader(required = false) String appKey,
+ @RequestBody JSONObject param,
+ HttpServletRequest request){
+ authNew(appKey, param, request, "搴撳瓨姹囨�绘煡璇�:/erp/inventory/summary");
+ try {
+ String wareHouseId = param == null ? null : param.getString("wareHouseId");
+ String matNr = param == null ? null : param.getString("matNr");
+ Collection<String> matNrs = null;
+ if (!Cools.isEmpty(matNr)){
+ matNrs = Arrays.stream(matNr.split(","))
+ .map(String::trim)
+ .filter(s -> !s.isEmpty())
+ .collect(Collectors.toList());
+ }
+ return new Result(200, "鎿嶄綔鎴愬姛", locDetlMapper.invSummary(wareHouseId, matNrs));
+ }catch (Exception e){
+ return new Result(500, e.getMessage(), null);
+ }
+ }
}
--
Gitblit v1.9.1