| | |
| | | BigDecimal lotNumber = cacheSettingUtils.getSymbolSku(holdOrderEntity.getSymbol()); |
| | | Long tradeMemberId = holdOrderEntity.getMemberId(); |
| | | if (CollUtil.isNotEmpty(followerSettings)) { |
| | | List<Object> followerMemberId = redisUtils.lGet(AppContants.MEMBER_HAS_FOLLOW, 0, -1); |
| | | List<Object> hasExist = new ArrayList<>(); |
| | | for (FollowFollowerSettingEntity followerSetting : followerSettings) { |
| | | // 加redis锁,同一个用户不能同时触发两个跟单任务,否则会出现金额问题 |
| | | while(true) { |
| | | log.info("#跟单用户任务已存在:{}, 当前:{}#", followerMemberId, followerSetting.getMemberId()); |
| | | log.info("#------->{}#", followerMemberId.contains(followerSetting.getMemberId().intValue())); |
| | | if (CollUtil.isEmpty(followerMemberId) || !followerMemberId.contains(followerSetting.getMemberId().intValue())) { |
| | | while (true) { |
| | | boolean flag = redisUtils.setNotExist(AppContants.MEMBER_HAS_FOLLOW + "_" + followerSetting.getMemberId(), "1", 5); |
| | | // List<Object> followerMemberId = redisUtils.lGet(AppContants.MEMBER_HAS_FOLLOW, 0, -1); |
| | | // log.info("#跟单用户任务已存在:{}, 当前:{}#", followerMemberId, followerSetting.getMemberId()); |
| | | // log.info("#------->{}#", followerMemberId.contains(followerSetting.getMemberId().intValue())); |
| | | // if (CollUtil.isEmpty(followerMemberId) || !followerMemberId.contains(followerSetting.getMemberId().intValue())) { |
| | | // log.info("跳出"); |
| | | // hasExist.add(followerSetting.getMemberId()); |
| | | // redisUtils.lSet(AppContants.MEMBER_HAS_FOLLOW, hasExist); |
| | | // break; |
| | | // } |
| | | |
| | | if (flag) { |
| | | log.info("跳出"); |
| | | followerMemberId.add(followerSetting.getMemberId()); |
| | | redisUtils.lSet(AppContants.MEMBER_HAS_FOLLOW, followerMemberId); |
| | | break; |
| | | } |
| | | try { |
| | | Thread.sleep(500); |
| | | } catch (InterruptedException e) { |
| | | e.printStackTrace(); |
| | | } |
| | | } |
| | | |
| | |
| | | |
| | | // 预付款 |
| | | BigDecimal prePaymentAmount = bondAmount.add(openFeePrice).add(openFeePrice); |
| | | log.info("可用的余额:{}, {}", prePaymentAmount, walletContract.getAvailableBalance()); |
| | | if (prePaymentAmount.compareTo(walletContract.getAvailableBalance()) > -1) { |
| | | log.info("可用金额不足"); |
| | | LogRecordUtils.insertFollowerNotice(followerSetting.getMemberId(), NoticeConstant.MONEY_NOT_ENOUGH_TITLE, StrUtil.format(NoticeConstant.MONEY_NOT_ENOUGH_CONTENT, followTraderInfoEntity.getNickname())); |
| | | continue; |
| | | } |
| | | |
| | | boolean flag = false; |
| | | while(true) { |
| | | MemberWalletContractEntity updateEntity = new MemberWalletContractEntity(); |
| | | updateEntity.setAvailableBalance(prePaymentAmount.negate()); |
| | | updateEntity.setTotalBalance(openFeePrice.negate()); |
| | | updateEntity.setId(walletContract.getId()); |
| | | updateEntity.setVersion(walletContract.getVersion()); |
| | | int i = memberWalletContractDao.updateWalletContractWithVersion(updateEntity); |
| | | if (i > 0) { |
| | | break; |
| | | } |
| | | |
| | | walletContract = memberWalletContractDao.findWalletContractByMemberIdAndSymbol(followerSetting.getMemberId(), CoinTypeEnum.USDT.name()); |
| | | if (prePaymentAmount.compareTo(walletContract.getAvailableBalance()) > -1) { |
| | | log.info("可用金额不足"); |
| | | LogRecordUtils.insertFollowerNotice(followerSetting.getMemberId(), NoticeConstant.MONEY_NOT_ENOUGH_TITLE, StrUtil.format(NoticeConstant.MONEY_NOT_ENOUGH_CONTENT, followTraderInfoEntity.getNickname())); |
| | | flag = true; |
| | | break; |
| | | } |
| | | } |
| | | |
| | | if (flag) { |
| | | continue; |
| | | } |
| | | |
| | |
| | | contractHoldOrderDao.insert(followHoldOrder); |
| | | int i = contractOrderDao.insert(contractOrderEntity); |
| | | if (i > 0) { |
| | | memberWalletContractDao.increaseWalletContractBalanceById(prePaymentAmount.negate(), openFeePrice.negate(), null, walletContract.getId()); |
| | | // memberWalletContractDao.increaseWalletContractBalanceById(prePaymentAmount.negate(), openFeePrice.negate(), null, walletContract.getId()); |
| | | |
| | | FollowFollowerOrderRelationEntity relationEntity = new FollowFollowerOrderRelationEntity(); |
| | | relationEntity.setIsShow(FollowFollowerOrderRelationEntity.IS_SHOW_Y); |
| | |
| | | LogRecordUtils.insertFollowerNotice(memberEntity.getId(), NoticeConstant.OPEN_ORDER_TITLE, StrUtil.format(NoticeConstant.OPEN_ORDER_CONTENT, holdOrderEntity.getSymbol() + "开空", openPrice.setScale(2, BigDecimal.ROUND_HALF_UP).toString(), followTraderInfoEntity.getNickname())); |
| | | } |
| | | } |
| | | redisUtils.del(AppContants.MEMBER_HAS_FOLLOW + "_" + followerSetting.getMemberId()); |
| | | } |
| | | redisUtils.del(AppContants.MEMBER_HAS_FOLLOW); |
| | | // redisUtils.del(AppContants.MEMBER_HAS_FOLLOW); |
| | | } |
| | | } |
| | | |