TrackingFlowTask.java 20.4 KB
Newer Older
lzxry committed
1 2 3 4 5
package track.task;

import common.model.CalculationFlow;
import common.model.Contract;
import common.model.TkioFlow;
kangxiaoshan committed
6
import common.repository.*;
lzxry committed
7 8 9 10 11 12 13
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import tkio.model.Account;
import tkio.repository.AccountRepository;
import tkio.repository.AppRepository;
import tkio.service.AccountFlowRestrictService;
14
import tkio.service.FlowService;
15
import util.Constant;
lzxry committed
16
import util.DateUtil;
17
import util.StringUtil;
lzxry committed
18

lzxry committed
19
import java.math.BigDecimal;
lzxry committed
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
import java.math.BigInteger;
import java.text.ParseException;
import java.util.ArrayList;
import java.util.List;

/**
 * @author liyin
 * @description
 * @date
 */
public class TrackingFlowTask {

    private final Logger logger = LoggerFactory.getLogger(TrackingFlowTask.class);

    @Autowired
    private ContractRepository contractRepository;
    @Autowired
    private AccountRepository accountRepository;
    @Autowired
    private AppRepository appRepository;
40 41
    /*@Autowired
    private AccountFlowRestrictService accountFlowRestrictService;*/
lzxry committed
42
    @Autowired
43
    private FlowService flowService;
lzxry committed
44 45 46 47 48 49
    @Autowired
    private TkioFlowRepository tkioFlowRepository;
    @Autowired
    private ContractChangeRepository contractChangeRepository;
    @Autowired
    private CalculationFlowRepository calculationFlowRepository;
kangxiaoshan committed
50 51
    @Autowired
    private TkioFlowHistoryRepository tkioFlowHistoryRepository;
lzxry committed
52

53
    public void syncFlow() {
lzxry committed
54
        List<CalculationFlow> calculationFlows = calculationFlowRepository.findByStatus(0);
lzxry committed
55 56 57 58 59 60
        for (CalculationFlow calculationFlow : calculationFlows) {
            List<TkioFlow> tkioFlowList = new ArrayList<>();
            calculationFlow.setStatus(1);
            calculationFlowRepository.save(calculationFlow);
            tkioFlowRepository.deleteByEmail(calculationFlow.getEmail());
            String email = calculationFlow.getEmail();
61

lzxry committed
62
            //查询用户下所有appkey
63
            try {
lzxry committed
64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
                Account account = accountRepository.findByEmail(email);
                List<Account> accountList = accountRepository.findByRootParent(account.getRootParent());
                List<Long> idList = new ArrayList<>();
                for (Account ac : accountList) {
                    idList.add(ac.getId());
                }
                List<String> appkeys = appRepository.findAppkeysNotDebug(idList);
                String appkeyStr = String.join("','", appkeys);
                appkeyStr = "'" + appkeyStr + "'";

                String ago = DateUtil.format(account.getCreateTime(), DateUtil.C_DATE_PATTON_DEFAULT);//查找最早一天的流量
                if (ago == null) {
                    calculationFlow.setStatus(2);
                    calculationFlowRepository.save(calculationFlow);
                    continue;
                }
lzxry committed
80

lzxry committed
81 82 83 84 85 86 87 88 89 90 91 92
                int between = 0;
                try {
                    between = DateUtil.daysBetween(ago, DateUtil.getBeforeDays(1)) + 1;
                } catch (ParseException e) {
                    logger.error("强转错误:", e);
                }
                int startInt = 0;
                if (Integer.valueOf(DateUtil.getHH()) > 10) {
                    startInt = -1;
                }
                for (int ii = between; ii > startInt; ii--) {
                    String yesterday = DateUtil.getBeforeDays(ii);//昨日
93 94
                    //BigInteger clickNum = accountFlowRestrictService.getTotalNum(yesterday, yesterday, appkeyStr, "account_track_flow_restrict", "click_sum");
                    BigInteger clickNum = flowService.getFlowByAccount(yesterday,yesterday,appkeys);
lzxry committed
95 96 97 98 99 100
                    if (clickNum != null && clickNum.longValue() > 0) {
                        List<Contract> contracts = contractRepository.findByPlatformAndEmail("tkio", email);
                        if (contracts.size() == 1) {//只有一个合同
                            TkioFlow tkioFlow = getTkioFlow(clickNum, yesterday, contracts.get(0));
                            if (tkioFlow != null) {
                                tkioFlowList.add(tkioFlow);
lzxry committed
101
                                tkioFlowRepository.save(tkioFlow);
lzxry committed
102
                            }
lzxry committed
103 104 105 106 107 108 109 110 111 112
                        } else {
                            //多个合同
                            //看昨日被哪几个合同包含了
                            List<Contract> correlationContract = new ArrayList<>();
                            for (Contract contract : contracts) {
                                /*if (ContractStatusEnum.CANCEL.getKey().equals(contract.getStatus()) || ContractStatusEnum.SUSPEND.getKey().equals(contract.getStatus())) {
                                    //中止或作废合同处理结束时间,以方便昨日流量的归属计算
                                    ContractChange contractChange = contractChangeRepository.findByContentCode(ContractStatusEnum.CANCEL.getValue(), contract.getContractCode());
                                    if (contractChange != null) {
                                        contract.setEndDate(new DateTime(contractChange.getCreateTime()).toString("yyyy-MM-dd"));
lzxry committed
113
                                    }
lzxry committed
114 115 116 117 118
                                }*/
                                String startDate = contract.getStartDate();
                                String endDate = contract.getEndDate();
                                if (DateUtil.getDate(yesterday).getTime() >= DateUtil.getDate(startDate).getTime() && DateUtil.getDate(yesterday).getTime() <= DateUtil.getDate(endDate).getTime()) {
                                    correlationContract.add(contract);
lzxry committed
119 120
                                }
                            }
lzxry committed
121 122 123 124 125 126
                            //多个合同时,进行排序,如果第一个合同流量超出就要看第二个合同,以此往下
                            if (correlationContract.size() > 1) {
                                //冒泡
                                //第一优先级:合同开始日期,第二优先级,合同编号大小
                                Contract[] contractsArray = new Contract[correlationContract.size()];
                                contractsArray = correlationContract.toArray(contractsArray);
lzxry committed
127

lzxry committed
128
                                contractsArray = orderByContract(contractsArray);
lzxry committed
129

lzxry committed
130 131
                                for (int i = 0; i < contractsArray.length; i++) {
                                    TkioFlow tkioFlow = getTkioFlow(clickNum, yesterday, contractsArray[i]);
132
                                    if (tkioFlow != null && i < contractsArray.length - 1 && tkioFlow.getCostFlow() != null && tkioFlow.getCostFlow() > 0L) {//处理成本流量,如果超出了,依次算在下一个合同上
lzxry committed
133 134
                                        clickNum = BigInteger.valueOf(tkioFlow.getCostFlow());
                                        tkioFlow.setCostFlow(null);
135
                                        if (tkioFlow.getFlow() > 0) {
lzxry committed
136 137 138
                                            tkioFlowList.add(tkioFlow);
                                            tkioFlowRepository.save(tkioFlow);
                                        }
lzxry committed
139 140
                                    } else {
                                        if (tkioFlow != null) {
lzxry committed
141
                                            tkioFlowList.add(tkioFlow);
lzxry committed
142
                                            tkioFlowRepository.save(tkioFlow);
lzxry committed
143 144 145
                                        }
                                        break;
                                    }
lzxry committed
146

lzxry committed
147
                                }
lzxry committed
148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
                            } else {
                                if (correlationContract.size() == 0) {//昨日不包含在所有合同中
                                    //排序
                                    Contract[] contractsArray = new Contract[contracts.size()];
                                    contractsArray = contracts.toArray(contractsArray);
                                    contractsArray = orderByContract(contractsArray);
                                    //如果昨日日期在第一个合同之前,则归属到第一个合同的成本,其余区间都归属到前一个合同的成本上
                                    for (int i = 0; i < contractsArray.length; i++) {
                                        if (DateUtil.getDate(yesterday).getTime() <= DateUtil.getDate(contractsArray[i].getStartDate()).getTime() || i == contractsArray.length - 1) {
                                            int j = 0;

                                            if (i != 0) {
                                                j = i - 1;
                                            }

                                            if (i == contractsArray.length - 1) {
                                                j = i;
                                            }

                                            TkioFlow tkioFlow = getTkioFlow(clickNum, yesterday, contractsArray[j]);
                                            if (tkioFlow != null) {
                                                tkioFlowList.add(tkioFlow);
lzxry committed
170
                                                tkioFlowRepository.save(tkioFlow);
lzxry committed
171 172 173 174 175 176 177 178
                                            }
                                            break;
                                        }
                                    }
                                } else {
                                    TkioFlow tkioFlow = getTkioFlow(clickNum, yesterday, correlationContract.get(0));
                                    if (tkioFlow != null) {
                                        tkioFlowList.add(tkioFlow);
lzxry committed
179
                                        tkioFlowRepository.save(tkioFlow);
lzxry committed
180
                                    }
lzxry committed
181 182
                                }

lzxry committed
183
                            }
lzxry committed
184 185 186
                        }
                    }
                }
lzxry committed
187
                if (tkioFlowList.size() > 0) {
lzxry committed
188
                    //tkioFlowRepository.save(tkioFlowList);
lzxry committed
189 190 191
                }
                calculationFlow.setStatus(2);
                calculationFlowRepository.save(calculationFlow);
192 193
            } catch (Exception e) {
                logger.error("CalculationFlow:Id::" + calculationFlow.getId() + ":全流量同步失败", e);
lzxry committed
194 195
                calculationFlow.setStatus(3);
                calculationFlowRepository.save(calculationFlow);
lzxry committed
196 197 198 199
            }
        }
    }

200
    public void task() {
lzxry committed
201 202 203
        List<String> emails = contractRepository.findDistinctEmailByPlatform("tkio");

        List<TkioFlow> tkioFlowList = new ArrayList<>();
lzxry committed
204
        String yesterday = DateUtil.getBeforeDays(1);//昨日
205
        logger.info("昨日流量同步:" + yesterday);
lzxry committed
206 207 208 209 210 211 212 213 214 215 216
        for (String email : emails) {

            //查询用户下所有appkey
            Account account = accountRepository.findByEmail(email);
            List<Account> accountList = accountRepository.findByRootParent(account.getRootParent());
            List<Long> idList = new ArrayList<>();
            for (Account ac : accountList) {
                idList.add(ac.getId());
            }
            List<String> appkeys = appRepository.findAppkeysNotDebug(idList);
            String appkeyStr = String.join("','", appkeys);
217
            appkeyStr = "'" + appkeyStr + "'";
lzxry committed
218

219 220 221
            //BigInteger clickNum = accountFlowRestrictService.getTotalNum(yesterday, yesterday, appkeyStr, "account_track_flow_restrict", "click_sum");
            BigInteger clickNum = flowService.getFlowByAccount(yesterday,yesterday,appkeys);
            if (clickNum != null && clickNum.longValue() > 0) {
lzxry committed
222
                List<Contract> contracts = contractRepository.findByPlatformAndEmail("tkio", email);
223
                if (contracts.size() == 1) {//只有一个合同
lzxry committed
224
                    TkioFlow tkioFlow = getTkioFlow(clickNum, yesterday, contracts.get(0));
225
                    if (tkioFlow != null) {
lzxry committed
226
                        tkioFlowList.add(tkioFlow);
lzxry committed
227
                        tkioFlowRepository.save(tkioFlow);
lzxry committed
228
                    }
229
                } else {//多个合同
lzxry committed
230
                    //看昨日被哪几个合同包含了
231
                    List<Contract> correlationContract = new ArrayList<>();
lzxry committed
232
                    for (Contract contract : contracts) {
lzxry committed
233
                        /*if (ContractStatusEnum.CANCEL.getKey().equals(contract.getStatus()) || ContractStatusEnum.SUSPEND.getKey().equals(contract.getStatus())) {
lzxry committed
234 235 236
                            //中止或作废合同处理结束时间,以方便昨日流量的归属计算
                            ContractChange contractChange = contractChangeRepository.findByContentCode(ContractStatusEnum.CANCEL.getValue(), contract.getContractCode());
                            if(contractChange!=null){
lzxry committed
237
                                contract.setEndDate(new DateTime(contractChange.getCreateTime()).toString("yyyy-MM-dd"));
lzxry committed
238
                            }
lzxry committed
239
                        }*/
lzxry committed
240 241
                        String startDate = contract.getStartDate();
                        String endDate = contract.getEndDate();
242
                        if (DateUtil.getDate(yesterday).getTime() >= DateUtil.getDate(startDate).getTime() && DateUtil.getDate(yesterday).getTime() <= DateUtil.getDate(endDate).getTime()) {
lzxry committed
243 244 245 246
                            correlationContract.add(contract);
                        }
                    }
                    //多个合同时,进行排序,如果第一个合同流量超出就要看第二个合同,以此往下
247
                    if (correlationContract.size() > 1) {
lzxry committed
248 249 250 251 252 253 254 255 256
                        //冒泡
                        //第一优先级:合同开始日期,第二优先级,合同编号大小
                        Contract[] contractsArray = new Contract[correlationContract.size()];
                        contractsArray = correlationContract.toArray(contractsArray);

                        contractsArray = orderByContract(contractsArray);

                        for (int i = 0; i < contractsArray.length; i++) {
                            TkioFlow tkioFlow = getTkioFlow(clickNum, yesterday, contractsArray[i]);
257
                            if (tkioFlow != null && i < contractsArray.length - 1 && tkioFlow.getCostFlow() != null && tkioFlow.getCostFlow() > 0L) {//处理成本流量,如果超出了,依次算在下一个合同上
lzxry committed
258 259
                                clickNum = BigInteger.valueOf(tkioFlow.getCostFlow());
                                tkioFlow.setCostFlow(null);
260
                                if (tkioFlow.getFlow() > 0) {
lzxry committed
261 262 263
                                    tkioFlowList.add(tkioFlow);
                                    tkioFlowRepository.save(tkioFlow);
                                }
264 265
                            } else {
                                if (tkioFlow != null) {
lzxry committed
266
                                    tkioFlowList.add(tkioFlow);
lzxry committed
267
                                    tkioFlowRepository.save(tkioFlow);
lzxry committed
268 269 270 271 272
                                }
                                break;
                            }

                        }
273 274
                    } else {
                        if (correlationContract.size() == 0) {//昨日不包含在所有合同中
lzxry committed
275 276 277 278 279 280
                            //排序
                            Contract[] contractsArray = new Contract[contracts.size()];
                            contractsArray = contracts.toArray(contractsArray);
                            contractsArray = orderByContract(contractsArray);
                            //如果昨日日期在第一个合同之前,则归属到第一个合同的成本,其余区间都归属到前一个合同的成本上
                            for (int i = 0; i < contractsArray.length; i++) {
281
                                if (DateUtil.getDate(yesterday).getTime() <= DateUtil.getDate(contractsArray[i].getStartDate()).getTime() || i == contractsArray.length - 1) {
lzxry committed
282 283
                                    int j = 0;

284 285
                                    if (i != 0) {
                                        j = i - 1;
lzxry committed
286 287
                                    }

288
                                    if (i == contractsArray.length - 1) {
lzxry committed
289 290 291 292
                                        j = i;
                                    }

                                    TkioFlow tkioFlow = getTkioFlow(clickNum, yesterday, contractsArray[j]);
293
                                    if (tkioFlow != null) {
lzxry committed
294
                                        tkioFlowList.add(tkioFlow);
lzxry committed
295
                                        tkioFlowRepository.save(tkioFlow);
lzxry committed
296 297 298 299 300 301
                                    }
                                    break;
                                }
                            }


302
                        } else {
lzxry committed
303
                            TkioFlow tkioFlow = getTkioFlow(clickNum, yesterday, correlationContract.get(0));
304
                            if (tkioFlow != null) {
lzxry committed
305
                                tkioFlowList.add(tkioFlow);
lzxry committed
306
                                tkioFlowRepository.save(tkioFlow);
lzxry committed
307 308 309 310 311 312 313 314 315
                            }
                        }

                    }
                }
            }


        }
316
        if (tkioFlowList.size() > 0) {
lzxry committed
317
            //tkioFlowRepository.save(tkioFlowList);
lzxry committed
318 319 320 321 322
        }

    }

    //排序
323 324 325
    public Contract[] orderByContract(Contract[] contractsArray) {
        for (int i = 0; i < contractsArray.length - 1; i++) {
            for (int j = 0; j < contractsArray.length - 1 - i; j++) {
lzxry committed
326 327
                String startDate1 = contractsArray[j].getSignedDate() == null ? contractsArray[j].getStartDate() : contractsArray[j].getSignedDate();
                String startDate2 = contractsArray[j + 1].getSignedDate() == null ? contractsArray[j + 1].getStartDate() : contractsArray[j + 1].getSignedDate();
328
                if (DateUtil.getDate(startDate1).getTime() > DateUtil.getDate(startDate2).getTime()) {
lzxry committed
329
                    Contract temp = contractsArray[j];
330
                    contractsArray[j] = contractsArray[j + 1];
lzxry committed
331
                    contractsArray[j + 1] = temp;
332
                } else if (DateUtil.getDate(startDate1).getTime() == DateUtil.getDate(startDate2).getTime()) {
333 334

                    String contractCode = StringUtil.matchNumber(contractsArray[j].getContractCode());
335 336
                    String contractCodeMin = StringUtil.matchNumber(contractsArray[j + 1].getContractCode());
                    if (Long.valueOf(contractCode) > Long.valueOf(contractCodeMin)) {
lzxry committed
337
                        Contract temp = contractsArray[j];
338
                        contractsArray[j] = contractsArray[j + 1];
lzxry committed
339 340 341 342 343 344 345 346
                        contractsArray[j + 1] = temp;
                    }
                }
            }
        }
        return contractsArray;
    }

347
    public TkioFlow getTkioFlow(BigInteger clickNum, String yesterday, Contract contract) {
lzxry committed
348 349 350 351 352
        TkioFlow tkioFlow = new TkioFlow();
        tkioFlow.setDs(yesterday);
        tkioFlow.setEmail(contract.getEmail());
        tkioFlow.setContractCode(contract.getContractCode());
        try {
353
            if (DateUtil.daysBetween(contract.getStartDate(), yesterday) < 0 || DateUtil.daysBetween(contract.getEndDate(), yesterday) > 0) {//昨日日期早于合同开始日期
lzxry committed
354 355
                //设置为成本流量
                tkioFlow.setCostFlow(clickNum.longValue());
356
            } else {
lzxry committed
357
                //查看历史总消耗流量是否超出
358 359
                BigDecimal totalFlow = tkioFlowRepository.sumFlowByEmailAndContractCode(contract.getEmail(), contract.getContractCode());
                totalFlow = totalFlow == null ? new BigDecimal(0) : totalFlow;
360
                Double contractTrackFlow = contract.getTrackFlow() * 10000;
361
                if (contractTrackFlow.longValue() - totalFlow.longValue() - clickNum.longValue() >= 0 || contract.getPriceLevel() == Constant.tkioPriceLevelNotLimit) {
362
                    tkioFlow.setFlow(clickNum.longValue());
363
                } else {
364
                    tkioFlow.setFlow(contractTrackFlow.longValue() - totalFlow.longValue());
365
                    tkioFlow.setCostFlow(clickNum.longValue() - tkioFlow.getFlow());
366
                }
lzxry committed
367 368 369
            }
            return tkioFlow;
        } catch (ParseException e) {
370
            logger.error("合同编号-" + contract.getContractCode() + "-同步昨日流量错误:", e);
lzxry committed
371 372 373 374 375 376
        }
        return null;
    }

    public static void main(String[] args) throws ParseException {
        String ago = "2020-10-01";
377
        int between = DateUtil.daysBetween(ago, DateUtil.getBeforeDays(1)) + 1;
lzxry committed
378 379 380 381 382 383
        System.out.println(between);
        for (int i = between; i > 0; i--) {
            System.out.println(DateUtil.getBeforeDays(i));
        }
    }
}