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