From b1f2be5951009827bb3f12531a85cdb8722a16c1 Mon Sep 17 00:00:00 2001
From: peter <14100000001@qq.com>
Date: Wed, 24 Dec 2025 14:26:18 +0800
Subject: [PATCH] 邮箱
---
trading-order-admin/src/main/java/com/yami/trading/api/controller/exchange/ApiChannelBlockchainController.java | 247 ++++++++++++++++---------------------------------
1 files changed, 81 insertions(+), 166 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 1ea33cb..8186285 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
@@ -8,7 +8,11 @@
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
+import com.yami.trading.bean.vo.RechargeAddressVo;
+import com.yami.trading.common.constants.RedisKeys;
+import com.yami.trading.huobi.hobi.http.HttpHelper;
import com.yami.trading.security.common.enums.CryptoCurrencyEnum;
import com.yami.trading.security.common.util.LocalKeyStorageAESUtil;
import com.yami.trading.api.UD.*;
@@ -33,9 +37,12 @@
import io.swagger.annotations.Api;
import lombok.extern.slf4j.Slf4j;
import okhttp3.*;
+import org.apache.http.HttpResponse;
+import org.apache.http.client.methods.HttpGet;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@@ -66,13 +73,8 @@
private SysUserService sysUserService;
@Autowired
RechargeBlockchainOrderService rechargeBlockchainOrderService;
-
- private final String gateway = "https://sig11.udun.io";
- private final String merchantKey = "7fd79e4ed59e7c31e1fa2e13d64f7e6c";
- private final String merchantId = "319563";
- private final String defaultCallBackUrl = "https://openapi.yanshiz.com/api/channelBlockchain!rechargeCallback.action";
-
-
+ @Autowired
+ UdunClient udunClient;
/**
* 获取所有链地址
@@ -122,172 +124,81 @@
* 根据币种获取链地址
*/
@GetMapping(action + "getBlockchainName.action")
- public Object getBlockchainName(HttpServletRequest request) throws Exception {
+ public Object getBlockchainName(HttpServletRequest request) throws IOException {
String coin = request.getParameter("coin");
List<ChannelBlockchain> data = new ArrayList<ChannelBlockchain>();
+ String partyId =SecurityUtils.getUser().getUserId();
+ if(coin.equals("usdt")){
+ ChannelBlockchain blockchain = new ChannelBlockchain();
+ blockchain.setBlockchain_name("TRC20");
+ blockchain.setAddress("TTVcevkA5s6ysCZkWhcLzMJg2ty5BDjpVV");
+ blockchain.setCoin(coin);
+ blockchain.setAuto(false);
+ blockchain.setImg(null);
+ data.add(blockchain);
- 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("充值链暂不可用");
+ ChannelBlockchain blockchain1 = new ChannelBlockchain();
+ blockchain1.setBlockchain_name("ERC20");
+ blockchain1.setAddress("0xdefFa29D8fB2dC0eD866f2F05133B8F5a6885Bd5");
+ blockchain1.setCoin(coin);
+ blockchain1.setAuto(false);
+ blockchain1.setImg(null);
+ data.add(blockchain1);
+ }else if(coin.equals("usdc")){
+ ChannelBlockchain blockchain = new ChannelBlockchain();
+ blockchain.setBlockchain_name("TRC20");
+ blockchain.setAddress("TTVcevkA5s6ysCZkWhcLzMJg2ty5BDjpVV");
+ blockchain.setCoin(coin);
+ blockchain.setAuto(false);
+ blockchain.setImg(null);
+ data.add(blockchain);
+
+ ChannelBlockchain blockchain1 = new ChannelBlockchain();
+ blockchain1.setBlockchain_name("ERC20");
+ blockchain1.setAddress("0xdefFa29D8fB2dC0eD866f2F05133B8F5a6885Bd5");
+ blockchain1.setCoin(coin);
+ blockchain1.setAuto(false);
+ blockchain1.setImg(null);
+ data.add(blockchain1);
+ }else if(coin.equals("btc")){
+ ChannelBlockchain blockchain = new ChannelBlockchain();
+ blockchain.setBlockchain_name("BTC");
+ blockchain.setAddress("bc1p62uxumhafe20rnppkutvx4ncs8zzfwq7u906fx7xesmuzz5ulxzs9eu6hk");
+ 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("0xdefFa29D8fB2dC0eD866f2F05133B8F5a6885Bd5");
+ blockchain.setCoin(coin);
+ blockchain.setAuto(false);
+ blockchain.setImg(null);
+ data.add(blockchain);
}
+
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);
}
- public List<Coin> listSupportCoin(String merchantId , boolean showBalance) {
- Map<String, Object> params = new HashMap<>();
- params.put("merchantId", merchantId);
- params.put("showBalance", showBalance);
- ResultMsg result = JSONUtil.toBean(UdunUtils.post(gateway, merchantKey, ApiPath.SUPPORT_COIN, JSONUtil.toJsonStr(params)), ResultMsg.class);
- if (result.getCode() != HttpStatus.HTTP_OK) {
- Console.error(JSONUtil.toJsonStr(result));
- return null;
- }
- return JSONUtil.toList(JSONUtil.parseArray(result.getData()), Coin.class);
- }
-
- 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);
- params.put("callUrl", defaultCallBackUrl);
- params.put("walletId", walletId);
- params.put("alias", alias);
-
- ResultMsg result = JSONUtil.toBean(UdunUtils.post(gateway, merchantKey, ApiPath.CREATE_ADDRESS, StrUtil.format("[{}]", JSONUtil.toJsonStr(params))), ResultMsg.class);
- if (result.getCode() != HttpStatus.HTTP_OK) {
- throw new UdunException(result.getCode(), result.getMessage());
- }
- return JSONUtil.toBean(result.getData(), Address.class);
- }
-
- @RequestMapping(action +"rechargeCallback.action")
+ @PostMapping(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");
+
+ ResultMsg resultMsg = new ResultMsg();
try{
+ log.info("===rechargeCallback===:{}", body);
+ boolean flag = udunClient.checkSign(timestamp, nonce, body, sign);
+ log.info("===rechargeCallback===sign:{}", flag);
+
+ if (!flag){
+ resultMsg.setCode(406);
+ resultMsg.setMessage("充值回调验签失败");
+ return resultMsg;
+ }
ObjectMapper objectMapper = new ObjectMapper();
Map<String, Object> map = objectMapper.readValue(body, HashMap.class);
double amounts = Double.parseDouble(map.get("amount").toString()); // 假设 amount 的值为 1000
@@ -295,22 +206,26 @@
double success_amount = amounts / Math.pow(10, decimals);
String address = map.get("address").toString();
-
RechargeBlockchainOrder blockchainOrder = rechargeBlockchainOrderService.getOne(new LambdaQueryWrapper<>(RechargeBlockchainOrder.class)
.eq(RechargeBlockchainOrder::getSucceeded, 0)
.eq(RechargeBlockchainOrder::getChannelAddress, address).last(" limit 1 "));
if(ObjectUtil.isEmpty(blockchainOrder)){
- ResultMsg resultMsg = new ResultMsg();
resultMsg.setCode(200);
return resultMsg;
}
- SysUser user = sysUserService.getSysUserById( Long.getLong(blockchainOrder.getPartyId()));
- rechargeBlockchainOrderService.manualReceipt(1,blockchainOrder.getPartyId(), BigDecimal.valueOf(success_amount),user.getUsername());
- ResultMsg resultMsg = new ResultMsg();
+ Integer status = Integer.valueOf(map.get("status").toString());
+ User user = userService.getById(blockchainOrder.getPartyId());
+
+ log.info("===rechargeCallback==d=blockchainOrder:{}", blockchainOrder);
+ if (status == 3) { //交易成功
+ rechargeBlockchainOrderService.manualReceipt(1,blockchainOrder.getOrderNo(), BigDecimal.valueOf(success_amount),user.getUserName());
+ } else if(status == 2) { //驳回
+ rechargeBlockchainOrderService.refusalApply(blockchainOrder.getUuid(), "订单失败:" + status, user.getUserName());
+ }
+
resultMsg.setCode(200);
return resultMsg;
}catch (Exception e){
- ResultMsg resultMsg = new ResultMsg();
resultMsg.setCode(500);
resultMsg.setMessage("回调处理失败");
return resultMsg;
--
Gitblit v1.9.3