|
@@ -3,6 +3,7 @@ package com.zanxiang.game.back.serve.service.impl;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
import com.zanxiang.advertising.tencent.base.AdvertisingTencentServer;
|
|
|
import com.zanxiang.advertising.tencent.base.pojo.dto.DataReportOfAppIdRpcDTO;
|
|
|
import com.zanxiang.advertising.tencent.base.pojo.dto.UserActionRpcDTO;
|
|
@@ -13,19 +14,25 @@ import com.zanxiang.game.back.base.pojo.enums.OrderStatusEnum;
|
|
|
import com.zanxiang.game.back.serve.pojo.dto.GameTencentOrderDTO;
|
|
|
import com.zanxiang.game.back.serve.pojo.entity.GameBackPolicy;
|
|
|
import com.zanxiang.game.back.serve.pojo.entity.GameTencentBackLog;
|
|
|
+import com.zanxiang.game.back.serve.pojo.entity.GameTencentMiniGameOrder;
|
|
|
import com.zanxiang.game.back.serve.pojo.entity.GameTencentOrder;
|
|
|
import com.zanxiang.game.back.serve.dao.mapper.GameTencentOrderMapper;
|
|
|
import com.zanxiang.game.back.serve.pojo.enums.ActionTypeEnum;
|
|
|
import com.zanxiang.game.back.serve.pojo.enums.BackStatusEnum;
|
|
|
+import com.zanxiang.game.back.serve.pojo.vo.GameTencentMiniGameOrderVO;
|
|
|
import com.zanxiang.game.back.serve.pojo.vo.GameTencentOrderVO;
|
|
|
import com.zanxiang.game.back.serve.service.IGameBackPolicyService;
|
|
|
import com.zanxiang.game.back.serve.service.IGameTencentBackLogService;
|
|
|
import com.zanxiang.game.back.serve.service.IGameTencentOrderService;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
import com.zanxiang.game.back.serve.utils.BackPolicyUtil;
|
|
|
+import com.zanxiang.game.module.base.ServerInfo;
|
|
|
+import com.zanxiang.game.module.base.pojo.vo.AgentRpcVO;
|
|
|
+import com.zanxiang.game.module.base.rpc.IAgentRpc;
|
|
|
import com.zanxiang.module.util.bean.BeanUtil;
|
|
|
import com.zanxiang.module.util.pojo.ResultVO;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
+import org.apache.commons.collections4.CollectionUtils;
|
|
|
import org.apache.commons.lang3.StringUtils;
|
|
|
import org.apache.dubbo.config.annotation.DubboReference;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
@@ -33,10 +40,15 @@ import org.springframework.stereotype.Service;
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
import java.time.LocalDateTime;
|
|
|
+import java.util.ArrayList;
|
|
|
+import java.util.Collections;
|
|
|
import java.util.HashMap;
|
|
|
import java.util.List;
|
|
|
import java.util.Map;
|
|
|
import java.util.Objects;
|
|
|
+import java.util.Set;
|
|
|
+import java.util.function.Function;
|
|
|
+import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
|
* <p>
|
|
@@ -57,6 +69,8 @@ public class GameTencentOrderServiceImpl extends ServiceImpl<GameTencentOrderMap
|
|
|
private IGameTencentBackLogService gameTencentBackLogService;
|
|
|
@Autowired
|
|
|
private IGameBackPolicyService gameBackPolicyService;
|
|
|
+ @DubboReference(providedBy = ServerInfo.SERVER_DUBBO_NAME)
|
|
|
+ private IAgentRpc agentRpc;
|
|
|
|
|
|
@Override
|
|
|
@Transactional(rollbackFor = Exception.class)
|
|
@@ -109,7 +123,7 @@ public class GameTencentOrderServiceImpl extends ServiceImpl<GameTencentOrderMap
|
|
|
|
|
|
@Override
|
|
|
public IPage<GameTencentOrderVO> tencentOrderLogList(GameTencentOrderDTO dto) {
|
|
|
- return page(dto.toPage(), new LambdaQueryWrapper<GameTencentOrder>()
|
|
|
+ IPage<GameTencentOrder> page = page(dto.toPage(), new LambdaQueryWrapper<GameTencentOrder>()
|
|
|
.eq(StringUtils.isNotBlank(dto.getChannel()), GameTencentOrder::getChannel, dto.getChannel())
|
|
|
.eq(null != dto.getGameId(), GameTencentOrder::getGameId, dto.getGameId())
|
|
|
.eq(null != dto.getAdAccountId(), GameTencentOrder::getAdAccountId, dto.getAdAccountId())
|
|
@@ -119,11 +133,39 @@ public class GameTencentOrderServiceImpl extends ServiceImpl<GameTencentOrderMap
|
|
|
.eq(null != dto.getIsBack(), GameTencentOrder::getIsBack, dto.getIsBack())
|
|
|
.eq(null != dto.getOrderStatus(), GameTencentOrder::getOrderStatus, dto.getOrderStatus())
|
|
|
.orderByDesc(GameTencentOrder::getCreateTime)
|
|
|
- ).convert(item -> {
|
|
|
- GameTencentOrderVO copy = BeanUtil.copy(item, GameTencentOrderVO.class);
|
|
|
- copy.setUpdateName(null == item.getUpdateBy() ? null : sysUserRpc.getById(item.getUpdateBy()).getData().getNickName());
|
|
|
- return copy;
|
|
|
- });
|
|
|
+ );
|
|
|
+ IPage<GameTencentOrderVO> result = new Page<>(page.getCurrent(), page.getSize(), page.getTotal());
|
|
|
+ if (CollectionUtils.isEmpty(page.getRecords())) {
|
|
|
+ return result;
|
|
|
+ }
|
|
|
+ result.setRecords(toVOBatch(page.getRecords()));
|
|
|
+ return result;
|
|
|
+ }
|
|
|
+
|
|
|
+ private List<GameTencentOrderVO> toVOBatch(List<GameTencentOrder> logList) {
|
|
|
+ if (CollectionUtils.isEmpty(logList)) {
|
|
|
+ return Collections.emptyList();
|
|
|
+ }
|
|
|
+ Set<String> agentKeys = logList.stream().map(GameTencentOrder::getChannel).filter(StringUtils::isNotBlank).collect(Collectors.toSet());
|
|
|
+ Map<String, AgentRpcVO> agentMap = CollectionUtils.isEmpty(agentKeys) ? Collections.emptyMap() : agentRpc.getByAgentKeys(new ArrayList<>(agentKeys))
|
|
|
+ .getData().stream().collect(Collectors.toMap(AgentRpcVO::getAgentKey, Function.identity()));
|
|
|
+ return logList.stream().map(log -> {
|
|
|
+ GameTencentOrderVO vo = toVOSimple(log);
|
|
|
+ if (StringUtils.isNotBlank(log.getChannel())) {
|
|
|
+ AgentRpcVO agent = agentMap.get(log.getChannel());
|
|
|
+ if (agent != null) {
|
|
|
+ vo.setAgentName(agent.getAgentName());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return vo;
|
|
|
+ }).collect(Collectors.toList());
|
|
|
+ }
|
|
|
+
|
|
|
+ private GameTencentOrderVO toVOSimple(GameTencentOrder log) {
|
|
|
+ if (log == null) {
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+ return BeanUtil.copy(log, GameTencentOrderVO.class);
|
|
|
}
|
|
|
|
|
|
@Override
|