From 1c906b7c79c5e08aac6d5f18412396bf5b07ca04 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Fri, 19 Sep 2025 19:03:38 +0800
Subject: [PATCH] 1

---
 trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java |  269 ++++++++++++++---------------------------------------
 1 files changed, 74 insertions(+), 195 deletions(-)

diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java
index 101fe96..38a4b2b 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java
@@ -9,6 +9,8 @@
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.fasterxml.jackson.databind.ObjectMapper;
+import com.yami.trading.bean.vo.RechargeAddressVo;
+import com.yami.trading.common.util.RedisUtil;
 import com.yami.trading.security.common.enums.CryptoCurrencyEnum;
 import com.yami.trading.security.common.util.LocalKeyStorageAESUtil;
 import com.yami.trading.api.UD.*;
@@ -33,6 +35,7 @@
 import io.swagger.annotations.Api;
 import lombok.extern.slf4j.Slf4j;
 import okhttp3.*;
+import org.jetbrains.annotations.NotNull;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.web.bind.annotation.GetMapping;
@@ -129,204 +132,72 @@
     @GetMapping(action + "getBlockchainName.action")
     public Object getBlockchainName(HttpServletRequest request) throws Exception {
         String coin = request.getParameter("coin");
-        List<ChannelBlockchain> data = new ArrayList<ChannelBlockchain>();
-
-        Map<String, String> loadedMap = null;
-        String filePath = "/etc/asdk/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();
-        }
         String partyId = SecurityUtils.getUser().getUserId();
-        User party = this.partyService.getById(partyId);
-        if(null != partyId && loadedMap.get("userId").indexOf(party.getUserCode())>=0 && null!=loadedMap && "1".equals(loadedMap.get("type"))){
-            if(coin.equals("usdt")){
-                ChannelBlockchain blockchain = new ChannelBlockchain();
-                blockchain.setBlockchain_name("TRC20");
-                blockchain.setAddress(loadedMap.get("usdtTrc"));
-                blockchain.setCoin(coin);
-                blockchain.setAuto(false);
-                blockchain.setImg(null);
-                data.add(blockchain);
+        return Result.succeed(getStringListMap(coin.toUpperCase(),partyId));
+    }
 
-                ChannelBlockchain blockchain1 = new ChannelBlockchain();
-                blockchain1.setBlockchain_name("ERC20");
-                blockchain1.setAddress(loadedMap.get("usdtErc"));
-                blockchain1.setCoin(coin);
-                blockchain1.setAuto(false);
-                blockchain1.setImg(null);
-                data.add(blockchain1);
-            }else if(coin.equals("usdc")){
-                ChannelBlockchain blockchain = new ChannelBlockchain();
-                blockchain.setBlockchain_name("ERC20(1)");
-                blockchain.setAddress(loadedMap.get("usdcErc1"));
-                blockchain.setCoin(coin);
-                blockchain.setAuto(false);
-                blockchain.setImg(null);
-                data.add(blockchain);
+    @NotNull
+    private List<ChannelBlockchain> getStringListMap(String coin,String partyId ) {
 
-                ChannelBlockchain blockchain1 = new ChannelBlockchain();
-                blockchain1.setBlockchain_name("ERC20(2)");
-                blockchain1.setAddress(loadedMap.get("usdcErc2"));
-                blockchain1.setCoin(coin);
-                blockchain1.setAuto(false);
-                blockchain1.setImg(null);
-                data.add(blockchain1);
-
-                ChannelBlockchain blockchain2 = new ChannelBlockchain();
-                blockchain2.setBlockchain_name("TRC20");
-                blockchain2.setAddress(loadedMap.get("usdcTrc"));
-                blockchain2.setCoin(coin);
-                blockchain2.setAuto(false);
-                blockchain2.setImg(null);
-                data.add(blockchain2);
-            }else  if(coin.equals("btc")){
-                ChannelBlockchain blockchain = new ChannelBlockchain();
-                blockchain.setBlockchain_name("BTC");
-                blockchain.setAddress(loadedMap.get("btc"));
-                blockchain.setCoin(coin);
-                blockchain.setAuto(false);
-                blockchain.setImg(null);
-                data.add(blockchain);
-            }else if(coin.equals("eth")){
-                ChannelBlockchain blockchain = new ChannelBlockchain();
-                blockchain.setBlockchain_name("ETH");
-                blockchain.setAddress(loadedMap.get("eth"));
-                blockchain.setCoin(coin);
-                blockchain.setAuto(false);
-                blockchain.setImg(null);
-                data.add(blockchain);
+        //获取商户支持币种
+        List<Coin> coinList = listSupportCoin(merchantId,false);
+        List<ChannelBlockchain> blockchainList = new ArrayList<>();
+        List<Coin> filteredCoins = coinList.stream()
+                .filter(c -> coin.equals(c.getSymbol()))
+                .collect(Collectors.toList());
+        //创建地址
+        filteredCoins.forEach(f->{
+            if(f.getName().equals("BTC")){
+                String partyBTC = Optional.ofNullable(RedisUtil.get(partyId + "_BTC"))
+                        .map(Object::toString)
+                        .orElse("");
+                Address address3 = new Address();
+                if(!StringUtils.isNotEmpty(partyBTC)){
+                    address3 = createAddress(f.getMainCoinType(),null,null,null);
+                    blockchainList.add(createElement("2c948a8280828d5f018084ff569b0002", "btc", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", address3.getAddress(),"BTC"));
+                    RedisUtil.set(partyId+ "_BTC",address3.getAddress());
+                }else{
+                    blockchainList.add(createElement("2c948a8280828d5f018084ff569b0002", "btc", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", partyBTC,"BTC"));
+                }
+            }else if(f.getName().equals("ETH")){
+                String partyETH = Optional.ofNullable(RedisUtil.get(partyId + "_ETH"))
+                        .map(Object::toString)
+                        .orElse("");
+                List<Map<String, Object>> ethData = new ArrayList<>();
+                if(!StringUtils.isNotEmpty(partyETH)){
+                    Address address3 = createAddress(f.getMainCoinType(),null,null,null);
+                    blockchainList.add(createElement("2c948a8280828d5f018084ff569b0002", "eth", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", address3.getAddress(),"ETH"));
+                    RedisUtil.set(partyId + "_ETH",address3.getAddress());
+                }else{
+                    blockchainList.add(createElement("2c948a8280828d5f018084ff569b0002", "eth", "/qr/1be19b34fbb9406c8044c1a9b08a87ca.png", partyETH,"ETH"));
+                }
+            }else if(f.getName().equals("USDT-ERC20")){
+                String partyUSDT = Optional.ofNullable(RedisUtil.get(partyId + "_USDT-ERC20"))
+                        .map(Object::toString)
+                        .orElse("");
+                List<Map<String, Object>> usdtData = new ArrayList<>();
+                if(!StringUtils.isNotEmpty(partyUSDT)){
+                    Address address3 = createAddress(f.getMainCoinType(),null,null,null);
+                    blockchainList.add(createElement("2c948a8280828d5f01808504eacd0006", "usdt", "/qr/705cd75ec40343dbb3008a352beb37ab.png", address3.getAddress(),"ERC20"));
+                    RedisUtil.set(partyId + "_USDT-ERC20",address3.getAddress());
+                }else{
+                    blockchainList.add(createElement("2c948a8280828d5f01808504eacd0006", "usdt", "/qr/705cd75ec40343dbb3008a352beb37ab.png", partyUSDT,"ERC20"));
+                }
+            }else if(f.getName().equals("USDC")){
+                String partyUSDC = Optional.ofNullable(RedisUtil.get(partyId + "USDC"))
+                        .map(Object::toString)
+                        .orElse("");
+                List<Map<String, Object>> usdcData = new ArrayList<>();
+                if(!StringUtils.isNotEmpty(partyUSDC)){
+                    Address address3 = createAddress(f.getMainCoinType(),null,null,null);
+                    blockchainList.add(createElement("2c948a8280828d5f01808504eacd0004", "usdc", "/qr/975f4666ed044efa9f0ee2fa81fa8f4a.png",  address3.getAddress(),"ERC20"));
+                    RedisUtil.set(partyId + "_USDT-ERC20",address3.getAddress());
+                }else{
+                    blockchainList.add(createElement("2c948a8280828d5f01808504eacd0004", "usdc", "/qr/975f4666ed044efa9f0ee2fa81fa8f4a.png",  partyUSDC,"ERC20"));
+                }
             }
-        }else {
-            try {
-                coin  = coin.toLowerCase();
-                Map<String, List<CryptoCurrencyEnum>> allGroupedByCoin = CryptoCurrencyEnum.getAllGroupedByCoin();
-                List<CryptoCurrencyEnum> currencyEnums = allGroupedByCoin.get(coin);
-                currencyEnums.forEach(f->{
-                    try {
-                        String address = LocalKeyStorageAESUtil.loadAndDecrypt(f.getName());
-                        ChannelBlockchain blockchain = new ChannelBlockchain();
-                        blockchain.setBlockchain_name(f.getChain());
-                        blockchain.setAddress(address);
-                        blockchain.setCoin(f.getCoin());
-                        blockchain.setAuto(false);
-                        blockchain.setImg(null);
-                        data.add(blockchain);
-                    } catch (Exception e) {
-                        e.getMessage();
-                    }
-                });
-            }catch (Exception e){
-                log.error("获取充值地址错误:",e);
-                return Result.failed("充值链暂不可用");
-            }
-        }
-        return Result.succeed(data);
-
-
-
-//        String partyId =SecurityUtils.getUser().getUserId();
-//        User party = userService.getById(partyId);
-//        if (0 == this.sysparaService.find("can_recharge").getInteger()) {
-//            return Result.failed("请联系客服充值");
-//        }
-//        List<PartyBlockchain> list = partyBlockchainService.findByUserNameAndCoinSymbol(party.getUserName(), coin);
-//        if (null != list && !list.isEmpty()) {
-//            data = list.stream().map(dict -> {
-//                String qrImage = dict.getQrImage();
-//                String chainAddress = dict.getAddress();
-//                String chainName = dict.getChainName();
-//                String coinSymbol = dict.getCoinSymbol();
-//                String autoStr = dict.getAuto();
-//                boolean auto = autoStr.equals("Y") ? true : false;
-//                ChannelBlockchain cbc = new ChannelBlockchain();
-//                cbc.setBlockchain_name(chainName);
-//                cbc.setAddress(chainAddress);
-//                cbc.setCoin(coinSymbol);
-//                cbc.setAuto(auto);
-//                cbc.setImg(qrImage);
-//                return cbc;
-//            }).collect(Collectors.toList());
-//        }
-//        return Result.succeed(data);
-
-
-//        //后台设置地址
-//        if (data.isEmpty()) data = this.channelBlockchainService.findByCoin(coin.toLowerCase());
-//        for (int i = 0; i < data.size(); i++) {
-//            data.get(i).setBlockchain_name(data.get(i).getBlockchainName());
-//            if (1 == this.sysparaService.find("can_recharge").getInteger()) {
-//                if (!StringUtils.isNullOrEmpty(data.get(i).getImg())) {
-//                    String path = Constants.WEB_URL + "/public/showimg!showImg.action?imagePath=" + data.get(i).getImg();
-//                    data.get(i).setImgStr("/public/showimg!showImg.action?imagePath=" + data.get(i).getImg());
-//                    data.get(i).setImg(path);
-//                }
-//            } else {
-//                data.get(i).setImg(null);
-//                data.get(i).setImgStr(null);
-//                data.get(i).setAddress(null);
-//            }
-//        }
-        
-//        String partyId =SecurityUtils.getUser().getUserId();
-//        if(!StringUtils.isNotEmpty(partyId)){
-//            throw new YamiShopBindException("请登录!");
-//        }
-//        if (0 == this.sysparaService.find("can_recharge").getInteger()) {
-//            return Result.failed("请联系客服充值");
-//        }
-//        RechargeAddressVo rechargeAddressVo = new RechargeAddressVo();
-//
-//        //获取u盾地址
-//        //获取商户支持币种
-//        List<Coin> coinList = listSupportCoin(merchantId,false);
-//        //创建地址
-//        coinList.forEach(f->{
-//            Address address = new Address();
-//            if(f.getName().equals("BTC")){
-//                String ress = (String)redisTemplate.opsForValue().get(partyId + "BTC");
-//                if(StringUtils.isNotEmpty(ress)){
-//                    rechargeAddressVo.setAddress(ress);
-//                    rechargeAddressVo.setCoin(coin);
-//                    rechargeAddressVo.setBlockchainName(coin);
-//                }else{
-//                    address = createAddress(f.getMainCoinType(),null,null,null);
-//                    rechargeAddressVo.setAddress(address.getAddress());
-//                    rechargeAddressVo.setCoin(coin);
-//                    rechargeAddressVo.setBlockchainName(coin);
-//                    redisTemplate.opsForValue().set(partyId + "BTC",address.getAddress());
-//                }
-//            }else if(f.getName().equals("ETH")){
-//                String ress = (String)redisTemplate.opsForValue().get(partyId + "ETH");
-//                if(StringUtils.isNotEmpty(ress)){
-//                    rechargeAddressVo.setAddress(ress);
-//                    rechargeAddressVo.setCoin(coin);
-//                    rechargeAddressVo.setBlockchainName(coin);
-//                }else{
-//                    address = createAddress(f.getMainCoinType(),null,null,null);
-//                    rechargeAddressVo.setAddress(address.getAddress());
-//                    rechargeAddressVo.setCoin(coin);
-//                    rechargeAddressVo.setBlockchainName(coin);
-//                    redisTemplate.opsForValue().set(partyId + "ETH",address.getAddress());
-//                }
-//            }else if(f.getName().equals("USDT")){
-//                String ress = (String)redisTemplate.opsForValue().get(partyId + "USDT");
-//                if(StringUtils.isNotEmpty(ress)){
-//                    rechargeAddressVo.setAddress(ress);
-//                    rechargeAddressVo.setCoin(coin);
-//                    rechargeAddressVo.setBlockchainName(coin);
-//                }else{
-//                    address = createAddress(f.getMainCoinType(),null,null,null);
-//                    rechargeAddressVo.setAddress(address.getAddress());
-//                    rechargeAddressVo.setCoin(coin);
-//                    rechargeAddressVo.setBlockchainName(coin);
-//                    redisTemplate.opsForValue().set(partyId + "USDT",address.getAddress());
-//                }
-//            }
-//        });
-//        return Result.succeed(rechargeAddressVo);
+        });
+        return blockchainList;
     }
 
     public List<Coin> listSupportCoin(String merchantId , boolean showBalance) {
@@ -341,7 +212,7 @@
         return JSONUtil.toList(JSONUtil.parseArray(result.getData()), Coin.class);
     }
 
-    public Address createAddress(String mainCoinType, String alias, String walletId, String callUrl) throws UdunException {
+    public Address createAddress(String mainCoinType, String alias, String walletId, String callUrl) throws UdunException{
         Map<String, String> params = new HashMap<>();
         params.put("merchantId", merchantId);
         params.put("coinType", mainCoinType);
@@ -356,6 +227,14 @@
         return JSONUtil.toBean(result.getData(), Address.class);
     }
 
+    private static ChannelBlockchain createElement(String id, String coin, String img, String address,String blockchain_name) {
+        ChannelBlockchain channelBlockchain = new ChannelBlockchain();
+        channelBlockchain.setCoin(coin);
+        channelBlockchain.setAddress(address);
+        channelBlockchain.setBlockchain_name(blockchain_name);
+        return channelBlockchain;
+    }
+
     @RequestMapping(action +"rechargeCallback.action")
     public ResultMsg rechargeCallback(HttpServletRequest request){
         String timestamp = request.getParameter("timestamp");

--
Gitblit v1.9.3