/
zj
2025-05-02 9102aa7e0b42ce5b9667fa3b67fede889df60fc0
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
package project.monitor.bonus.job.transfer;
 
import java.util.List;
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
 
import kernel.util.StringUtils;
import kernel.util.ThreadUtils;
import project.monitor.bonus.BonusSettlementService;
import project.monitor.bonus.SettleOrderService;
import project.monitor.bonus.model.SettleOrder;
import project.monitor.erc20.service.Erc20Service;
 
public class SettleTransferConfirmJob implements Runnable {
    
    private static final Logger logger = LoggerFactory.getLogger(SettleTransferConfirmJob.class);
    
    private SettleOrderService settleOrderService;
 
    private Erc20Service erc20Service;
 
    private BonusSettlementService bonusSettlementService;
 
    public void start() {
        new Thread(this, "SettleTransferConfirmJob").start();
        if (logger.isInfoEnabled()) {
            logger.info("结算确认线程启动");
        }
 
    }
 
    public void run() {
        while (true) {
            try {
 
                List<SettleOrder> list = settleOrderService.findBySucceeded(0);
                for (SettleOrder item : list) {
                    this.handle(item);
                }
 
            } catch (Throwable e) {
 
                logger.error("BonusTransferConfirmJob run fail", e);
 
            } finally {
 
                ThreadUtils.sleep(1000 * 60);
            }
        }
 
    }
 
    public void handle(SettleOrder item) {
        try {
 
            if (StringUtils.isNullOrEmpty(item.getTxn_hash())) {
                return;
            }
 
            // 1.交易成功 0.交易失败
            Integer status = erc20Service.getEthTxStatus(item.getTxn_hash());
 
            if (status != null && (status == 1 || status == 0)) {
 
                bonusSettlementService.saveConfirm(item, status);
 
            }
 
        } catch (Throwable t) {
 
            logger.error("BonusTransferConfirmServer run() bonusOrderNo:" + item.getOrder_no() + " fail", t);
        } finally {
            
            ThreadUtils.sleep(1000 * 3);
        }
    }
 
    public void setSettleOrderService(SettleOrderService settleOrderService) {
        this.settleOrderService = settleOrderService;
    }
 
    public void setErc20Service(Erc20Service erc20Service) {
        this.erc20Service = erc20Service;
    }
 
    public void setBonusSettlementService(BonusSettlementService bonusSettlementService) {
        this.bonusSettlementService = bonusSettlementService;
    }
 
}