From 286ea89f5f6cade73276f865effa5dcd2b19406d Mon Sep 17 00:00:00 2001 From: zainali5120 <512061637@qq.com> Date: Fri, 25 Sep 2020 15:19:11 +0800 Subject: [PATCH] 撮合交易代码提交 --- src/main/java/com/xcong/excoin/modules/blackchain/model/RocTransferDetail.java | 41 ++++++++++ src/main/java/com/xcong/excoin/utils/dingtalk/DingTalkUtils.java | 2 src/main/java/com/xcong/excoin/configurations/RabbitMqConfig.java | 23 +++++ src/main/resources/mapper/member/MemberCoinAddressDao.xml | 14 +++ src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java | 52 ++++++++++++ src/main/java/com/xcong/excoin/modules/coin/service/BlockCoinService.java | 4 src/main/java/com/xcong/excoin/modules/member/dao/MemberCoinAddressDao.java | 2 src/main/resources/application-test.yml | 2 src/main/java/com/xcong/excoin/rabbit/consumer/RocBlockUpdateConsumer.java | 51 ++++++++++++ src/main/java/com/xcong/excoin/modules/member/service/impl/MemberServiceImpl.java | 9 +- src/main/java/com/xcong/excoin/utils/mail/SubMailSend.java | 10 +- src/main/java/com/xcong/excoin/utils/mail/Sms106Send.java | 11 +- src/main/java/com/xcong/excoin/trade/CoinTrader.java | 2 13 files changed, 200 insertions(+), 23 deletions(-) diff --git a/src/main/java/com/xcong/excoin/configurations/RabbitMqConfig.java b/src/main/java/com/xcong/excoin/configurations/RabbitMqConfig.java index 1389b69..3549a5f 100644 --- a/src/main/java/com/xcong/excoin/configurations/RabbitMqConfig.java +++ b/src/main/java/com/xcong/excoin/configurations/RabbitMqConfig.java @@ -89,6 +89,13 @@ // 交易订单处理 public static final String ROUTINGKEY_HANDLE_TRADE = "ROUTINGKEY_HANDLE_TRADE"; + public static final String EXCHANGE_ROC = "roc-transfer"; + + public static final String QUEUE_ROC= "roc-queue"; + + public static final String ROUTING_KEY_ROC = "roc-transfer-routingKey"; + + @Resource private ConnectionFactory connectionFactory; @@ -351,4 +358,20 @@ return BindingBuilder.bind(queueHandleTrade()).to(matchTradeExchange()).with(RabbitMqConfig.ROUTINGKEY_HANDLE_TRADE); } + @Bean + public DirectExchange rocExchange() { + return new DirectExchange(EXCHANGE_ROC); + } + + + @Bean + public Queue rocQueue() { + return new Queue(QUEUE_ROC, true); + } + + @Bean + public Binding bindingRoc() { + return BindingBuilder.bind(rocQueue()).to(rocExchange()).with(ROUTING_KEY_ROC); + } + } diff --git a/src/main/java/com/xcong/excoin/modules/blackchain/model/RocTransferDetail.java b/src/main/java/com/xcong/excoin/modules/blackchain/model/RocTransferDetail.java new file mode 100644 index 0000000..40a1d68 --- /dev/null +++ b/src/main/java/com/xcong/excoin/modules/blackchain/model/RocTransferDetail.java @@ -0,0 +1,41 @@ +package com.xcong.excoin.modules.blackchain.model; + +import lombok.Data; + +import java.math.BigDecimal; + +/** + * @description 钱包表 + * @author admin + * @date 2020-09-17 14:31 + */ + +@Data +public class RocTransferDetail { + + + /** + * 主键 + */ + private Long id; + + + /** + * 主地址 + */ + private String address; + + + /** + * 币种 + */ + private String symbol; + + + /** + * 余额 + */ + private BigDecimal balance; + + +} \ No newline at end of file diff --git a/src/main/java/com/xcong/excoin/modules/coin/service/BlockCoinService.java b/src/main/java/com/xcong/excoin/modules/coin/service/BlockCoinService.java index ce314cd..1567cce 100644 --- a/src/main/java/com/xcong/excoin/modules/coin/service/BlockCoinService.java +++ b/src/main/java/com/xcong/excoin/modules/coin/service/BlockCoinService.java @@ -1,5 +1,7 @@ package com.xcong.excoin.modules.coin.service; +import com.xcong.excoin.modules.blackchain.model.RocTransferDetail; + public interface BlockCoinService { public void updateEthUsdt(); @@ -16,6 +18,6 @@ public void updateTrc20(); - public void updateRoc(); + public void updateRoc(RocTransferDetail transferDetail); } diff --git a/src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java b/src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java index 9e50fb4..5d1e101 100644 --- a/src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java +++ b/src/main/java/com/xcong/excoin/modules/coin/service/impl/BlockCoinServiceImpl.java @@ -482,8 +482,58 @@ } @Override - public void updateRoc() { + public void updateRoc(RocTransferDetail transferDetail) { // 更新ROC + // 增加用户余额 + String address = transferDetail.getAddress(); + BigDecimal balance = transferDetail.getBalance(); + String symbol = transferDetail.getSymbol(); + if(org.apache.commons.lang.StringUtils.isBlank(address) || org.apache.commons.lang.StringUtils.isBlank(symbol) || balance ==null ){ + return; + } + + if(balance.compareTo(new BigDecimal("0.0001"))<=0){ + return; + } + + MemberCoinAddressEntity memberCoinAddress = memberCoinAddressDao.selectCoinAddressByAddressAndSymbol(address, symbol); + if(memberCoinAddress==null){ + return; + } + Long memberId = memberCoinAddress.getMemberId(); + // 查询钱包 并更新 + MemberWalletCoinEntity walletCoinEntity = memberWalletCoinDao.selectWalletCoinBymIdAndCode(memberId, CoinTypeEnum.ROC.name()); + if (walletCoinEntity == null) { + // 创建一个钱包 + // 创建这个钱包 + walletCoinEntity = new MemberWalletCoinEntity(); + walletCoinEntity.setAvailableBalance(BigDecimal.ZERO); + walletCoinEntity.setFrozenBalance(BigDecimal.ZERO); + walletCoinEntity.setTotalBalance(BigDecimal.ZERO); + walletCoinEntity.setBorrowedFund(BigDecimal.ZERO); + walletCoinEntity.setMemberId(memberId); + walletCoinEntity.setWalletCode(symbol); + memberWalletCoinDao.insert(walletCoinEntity); + } + + memberWalletCoinDao.updateBlockBalance(walletCoinEntity.getId(), balance, BigDecimal.ZERO, 0); + + String orderNo = insertCoinCharge(address, memberId, balance, CoinTypeEnum.ROC.name(), "", BigDecimal.ZERO,null); + // 插入财务记录 + LogRecordUtils.insertMemberAccountMoneyChange(memberId, "转入", balance, CoinTypeEnum.ROC.name(), 1, 1); + + try{ + ThreadPoolUtils.sendDingTalk(5); + MemberEntity member = memberDao.selectById(memberId); + if (StrUtil.isNotBlank(member.getPhone())) { + String amount = balance.toPlainString() + "ROC"; + Sms106Send.sendRechargeMsg(member.getPhone(), DateUtil.format(new Date(), DatePattern.NORM_DATETIME_MINUTE_PATTERN), orderNo); + } else { + SubMailSend.sendRechargeMail(member.getEmail(), DateUtil.format(new Date(), DatePattern.NORM_DATETIME_MINUTE_PATTERN), orderNo); + } + }catch (Exception e){ + //e.printStackTrace(); + } } diff --git a/src/main/java/com/xcong/excoin/modules/member/dao/MemberCoinAddressDao.java b/src/main/java/com/xcong/excoin/modules/member/dao/MemberCoinAddressDao.java index b9fea92..a53bba9 100644 --- a/src/main/java/com/xcong/excoin/modules/member/dao/MemberCoinAddressDao.java +++ b/src/main/java/com/xcong/excoin/modules/member/dao/MemberCoinAddressDao.java @@ -15,6 +15,8 @@ MemberCoinAddressEntity selectBlockAddress(@Param("memberId") Long memberId, @Param("symbol") String symbol); + MemberCoinAddressEntity selectCoinAddressByAddressAndSymbol(@Param("address") String address, @Param("symbol") String symbol); + List<MemberCoinAddressEntity> selectCoinAddressListByMap(@Param("symbol") String symbol, @Param("memberId") Long memberId); List<MemberCoinAddressEntity> selectAllBlockAddressBySymbolAndTag(@Param("symbol") String symbol, @Param("tag") String tag); diff --git a/src/main/java/com/xcong/excoin/modules/member/service/impl/MemberServiceImpl.java b/src/main/java/com/xcong/excoin/modules/member/service/impl/MemberServiceImpl.java index e317ffa..3d28419 100644 --- a/src/main/java/com/xcong/excoin/modules/member/service/impl/MemberServiceImpl.java +++ b/src/main/java/com/xcong/excoin/modules/member/service/impl/MemberServiceImpl.java @@ -41,6 +41,7 @@ import com.xcong.excoin.utils.ThreadPoolUtils; import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; import org.springframework.security.core.context.SecurityContextHolder; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -144,12 +145,10 @@ // } if (!AppContants.SYSTEM_REFERER.equals(registerDto.getRefererId())) { MemberEntity isExist = memberDao.selectMemberInfoByInviteId(registerDto.getRefererId()); - if (isExist == null) { - return Result.fail("推荐人不存在"); + if (isExist != null) { + member.setRefererId(registerDto.getRefererId()); } } - - member.setRefererId(registerDto.getRefererId()); member.setAccountStatus(MemberEntity.ACCOUNT_STATUS_ENABLE); member.setAccountType(MemberEntity.ACCOUNT_TYPE_NORMAL); member.setAgentLevel(MemberEntity.ACCOUNT_AGENT_LEVEL); @@ -171,7 +170,7 @@ boolean flag = false; String parentId = member.getRefererId(); String ids = ""; - while (!flag) { + while (!flag && StringUtils.isNotBlank(parentId)) { ids += ("," + parentId); MemberEntity parentMember = memberDao.selectMemberInfoByInviteId(parentId); if (parentMember == null) { diff --git a/src/main/java/com/xcong/excoin/rabbit/consumer/RocBlockUpdateConsumer.java b/src/main/java/com/xcong/excoin/rabbit/consumer/RocBlockUpdateConsumer.java new file mode 100644 index 0000000..bbf2717 --- /dev/null +++ b/src/main/java/com/xcong/excoin/rabbit/consumer/RocBlockUpdateConsumer.java @@ -0,0 +1,51 @@ +package com.xcong.excoin.rabbit.consumer; + +import com.alibaba.fastjson.JSONObject; +import com.rabbitmq.client.Channel; +import com.xcong.excoin.configurations.RabbitMqConfig; +import com.xcong.excoin.modules.blackchain.model.RocTransferDetail; +import com.xcong.excoin.modules.coin.service.BlockCoinService; +import com.xcong.excoin.modules.member.dao.MemberCoinAddressDao; +import com.xcong.excoin.modules.member.entity.MemberCoinAddressEntity; +import com.xcong.excoin.rabbit.pricequeue.OrderModel; +import com.xcong.excoin.rabbit.pricequeue.OrderOperatePriceService; +import org.apache.commons.lang.StringUtils; +import org.springframework.amqp.core.Message; +import org.springframework.amqp.rabbit.annotation.RabbitListener; +import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; +import org.springframework.stereotype.Component; + +import javax.annotation.Resource; +import java.math.BigDecimal; +import java.util.List; + + +/** + * 用户修改止损止盈价格、提价限价委托、下单爆仓价等消息 + * 后台打包开启 APP 不开启 + * @author helius + */ +@Component +//@ConditionalOnProperty(prefix = "app", name = "newest-price-update-job-contract", havingValue = "true") +public class RocBlockUpdateConsumer { + + @Resource + private BlockCoinService blockCoinService; + /** + * ROC币种同步 + * + * @param message 消息体 + * @param channel 信道 + * @date 2019年4月19日 + */ + @RabbitListener(queues = RabbitMqConfig.QUEUE_ROC) + public void onMessageMorePro(Message message, Channel channel) { + String content = new String(message.getBody()); + // 操作前的map + // 转为model + RocTransferDetail transferDetail = JSONObject.parseObject(content, RocTransferDetail.class); + blockCoinService.updateRoc(transferDetail); + } + + +} diff --git a/src/main/java/com/xcong/excoin/trade/CoinTrader.java b/src/main/java/com/xcong/excoin/trade/CoinTrader.java index 6c4f979..3e249f0 100644 --- a/src/main/java/com/xcong/excoin/trade/CoinTrader.java +++ b/src/main/java/com/xcong/excoin/trade/CoinTrader.java @@ -261,7 +261,6 @@ while (iterator.hasNext()) { OrderCoinsEntity matchOrder = iterator.next(); ExchangeTrade trade = processMatch(focusedOrder, matchOrder); - logger.info(">>>>>" + trade); if (trade != null) { exchangeTrades.add(trade); } @@ -410,7 +409,6 @@ availAmount = calculateTradedAmount(matchOrder, dealPrice); //计算成交量 取少的 BigDecimal tradedAmount = (availAmount.compareTo(needAmount) >= 0 ? needAmount : availAmount); - System.out.println("成交量:"+tradedAmount); //logger.info("dealPrice={},amount={}", dealPrice, tradedAmount); //如果成交额为0说明剩余额度无法成交,退出 if (tradedAmount.compareTo(BigDecimal.ZERO) == 0) { diff --git a/src/main/java/com/xcong/excoin/utils/dingtalk/DingTalkUtils.java b/src/main/java/com/xcong/excoin/utils/dingtalk/DingTalkUtils.java index 70ed481..17e428f 100644 --- a/src/main/java/com/xcong/excoin/utils/dingtalk/DingTalkUtils.java +++ b/src/main/java/com/xcong/excoin/utils/dingtalk/DingTalkUtils.java @@ -46,7 +46,7 @@ request.setActionCard(actionCard); OapiRobotSendResponse response = client.execute(request); - log.info(JSONObject.toJSONString(response)); + //log.info(JSONObject.toJSONString(response)); } catch (Exception e) { log.error("#dingtalk send error#", e); } finally { diff --git a/src/main/java/com/xcong/excoin/utils/mail/Sms106Send.java b/src/main/java/com/xcong/excoin/utils/mail/Sms106Send.java index a470e77..2e12b4a 100644 --- a/src/main/java/com/xcong/excoin/utils/mail/Sms106Send.java +++ b/src/main/java/com/xcong/excoin/utils/mail/Sms106Send.java @@ -20,7 +20,7 @@ private static final String URL = "http://www.qf106.com/sms.aspx"; private static final String ID = "16606"; - private static final String ACCOUNT = "Biue"; + private static final String ACCOUNT = "golden"; private static final String PASSWORD = "123456"; @@ -37,13 +37,13 @@ } public static boolean sendRechargeMsg(String phone, String time, String orderNo) { - String msg = "尊敬的用户,您的帐号于{}有一笔成功充值订单,如有疑问请联系客服,订单编号为{}"; + String msg = "尊敬的用户,您的帐号于{}有一笔成功充值订单,订单编号{}"; String content = StrUtil.format(msg, time, orderNo); return request(phone, content, "充值"); } public static boolean sendWithdrawalMsg(String phone, String time, String orderNo) { - String msg = "尊敬的用户,您的帐号于{}有一笔成功提现订单,如有疑问请联系客服,订单编号为{}"; + String msg = "尊敬的用户,您的帐号于{}有一笔成功提现订单,订单编号为{}"; String content = StrUtil.format(msg, time, orderNo); return request(phone, content, "提现"); } @@ -64,7 +64,7 @@ param.put("telephonenumber", 0); String response = HttpUtil.post(URL, param); - log.info("短信发送:{}, {}", tagName, response); + //log.info("短信发送:{}, {}", tagName, response); if ("Success".equals(XmlUtil.xmlToMap(response).get("returnstatus"))) { return true; } else { @@ -72,7 +72,4 @@ } } - public static void main(String[] args) { - System.out.println(sendVerifyCode("15773002834", "123456", 2)); - } } diff --git a/src/main/java/com/xcong/excoin/utils/mail/SubMailSend.java b/src/main/java/com/xcong/excoin/utils/mail/SubMailSend.java index 4663a48..3c1b926 100644 --- a/src/main/java/com/xcong/excoin/utils/mail/SubMailSend.java +++ b/src/main/java/com/xcong/excoin/utils/mail/SubMailSend.java @@ -43,7 +43,7 @@ private static final String APP_ID = "16082"; private static final String APP_KEY = "f34c792a1112c16c190ed7190d386c4f"; - private static final String FROM = "biue@submail.biue.me"; + private static final String FROM = "goldenFlame@submail.goldflame.cc"; private static final String SIGN_TYPE = ""; /** @@ -57,7 +57,7 @@ JSONObject vars = new JSONObject(); vars.put("code", code); - String project = "zoKVB"; + String project = "qNv3f4"; return request(vars, project, to); } @@ -73,14 +73,14 @@ JSONObject vars = new JSONObject(); vars.put("time", time); vars.put("orderNo", orderNo); - String project = "x820C2"; + String project = "6dH3j"; return request(vars, project, to); } public static boolean sendWithdrawalMail(String to, String time) { JSONObject vars = new JSONObject(); vars.put("time", time); - String project = "e3BO91"; + String project = "Vyk0y2"; return request(vars, project, to); } @@ -165,6 +165,6 @@ public static void main(String[] args) { // System.out.println(sendMail("546766039@qq.com", "123456")); - System.out.println(sendRechargeMail("546766039@qq.com", DateUtil.format(new Date(), DatePattern.NORM_DATETIME_PATTERN), "123456")); + System.out.println(sendRechargeMail("512061637@qq.com", "wewewewe","123456")); } } diff --git a/src/main/resources/application-test.yml b/src/main/resources/application-test.yml index 732bfb1..d36e69b 100644 --- a/src/main/resources/application-test.yml +++ b/src/main/resources/application-test.yml @@ -100,7 +100,7 @@ day-line: false other-job: true loop-job: true - rabbit-consumer: true + rabbit-consumer: false block-job: true aliyun: diff --git a/src/main/resources/mapper/member/MemberCoinAddressDao.xml b/src/main/resources/mapper/member/MemberCoinAddressDao.xml index 4a3237a..edb4a57 100644 --- a/src/main/resources/mapper/member/MemberCoinAddressDao.xml +++ b/src/main/resources/mapper/member/MemberCoinAddressDao.xml @@ -36,6 +36,20 @@ </if> </where> </select> + + <select id="selectCoinAddressByAddressAndSymbol" resultType="com.xcong.excoin.modules.member.entity.MemberCoinAddressEntity"> + select * + from member_coin_address + <where> + is_biyict = 1 + <if test="symbol != null and symbol != ''"> + and symbol = #{symbol} + </if> + <if test="address != null and address != ''"> + and address = #{address} + </if> + </where> + </select> <select id="selectCoinAddressListByMap" resultType="com.xcong.excoin.modules.member.entity.MemberCoinAddressEntity"> select * from member_coin_address -- Gitblit v1.9.1