新版仿ok交易所-后端
1
zj
7 days ago 1004f3d16011f69894196bfd180ea539b76ba4e7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package com.yami.trading.service.impl;
 
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.yami.trading.bean.model.ChannelBlockchain;
import com.yami.trading.dao.user.ChannelBlockchainMapper;
import com.yami.trading.common.exception.YamiShopBindException;
import com.yami.trading.service.ChannelBlockchainService;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service;
 
import java.util.ArrayList;
import java.util.List;
 
@Service
public class ChannelBlockchainServiceImpl  extends ServiceImpl<ChannelBlockchainMapper, ChannelBlockchain> implements ChannelBlockchainService {
 
 
 
    @Override
    public ChannelBlockchain findByNameAndCoinAndAdd(String blockchain_name, String coin, String address) {
        List<ChannelBlockchain> list = new ArrayList<ChannelBlockchain>();
        if (StringUtils.isEmpty(address)) {
 
            list=list(Wrappers.<ChannelBlockchain>query().lambda()
                    .eq(ChannelBlockchain::getBlockchainName,blockchain_name).eq(ChannelBlockchain::getCoin,coin));
        } else {
            list=list(Wrappers.<ChannelBlockchain>query().lambda().
                    eq(ChannelBlockchain::getBlockchainName,blockchain_name).eq(ChannelBlockchain::getCoin,coin).eq(ChannelBlockchain::getAddress,address));
        }
        if (list.size() > 0)
            return list.get(0);
        return null;
    }
 
    @Override
    public List<ChannelBlockchain> findByCoin(String coin) {
        return list(Wrappers.<ChannelBlockchain>query().lambda().eq(ChannelBlockchain::getCoin, coin));
    }
 
    @Override
    public ChannelBlockchain saveOrUpdateByCoinAndChain(String coin, String blockchainName, String address) {
        if (StringUtils.isBlank(coin) || StringUtils.isBlank(blockchainName)) {
            throw new YamiShopBindException("币种和链名称不能为空");
        }
        if (StringUtils.isBlank(address)) {
            throw new YamiShopBindException("充值地址不能为空");
        }
        String normalizedCoin = coin.trim().toLowerCase();
        String normalizedChain = blockchainName.trim();
        ChannelBlockchain existing = getOne(Wrappers.<ChannelBlockchain>lambdaQuery()
                .eq(ChannelBlockchain::getCoin, normalizedCoin)
                .eq(ChannelBlockchain::getBlockchainName, normalizedChain)
                .last("LIMIT 1"));
        if (existing != null) {
            existing.setAddress(address.trim());
            updateById(existing);
            return existing;
        }
        ChannelBlockchain entity = new ChannelBlockchain();
        entity.setCoin(normalizedCoin);
        entity.setBlockchainName(normalizedChain);
        entity.setAddress(address.trim());
        entity.setAuto(false);
        save(entity);
        return entity;
    }
}