|  | @@ -3,7 +3,6 @@ package com.zanxiang.game.data.serve.service.impl;
 | 
											
												
													
														|  |  import com.google.common.base.CaseFormat;
 |  |  import com.google.common.base.CaseFormat;
 | 
											
												
													
														|  |  import com.zanxiang.erp.base.ErpServer;
 |  |  import com.zanxiang.erp.base.ErpServer;
 | 
											
												
													
														|  |  import com.zanxiang.erp.base.rpc.ISysUserRpc;
 |  |  import com.zanxiang.erp.base.rpc.ISysUserRpc;
 | 
											
												
													
														|  | -import com.zanxiang.erp.security.util.SecurityUtil;
 |  | 
 | 
											
												
													
														|  |  import com.zanxiang.game.data.serve.component.DataPowerComponent;
 |  |  import com.zanxiang.game.data.serve.component.DataPowerComponent;
 | 
											
												
													
														|  |  import com.zanxiang.game.data.serve.pojo.dto.*;
 |  |  import com.zanxiang.game.data.serve.pojo.dto.*;
 | 
											
												
													
														|  |  import com.zanxiang.game.data.serve.pojo.entity.AdsGameServerDay;
 |  |  import com.zanxiang.game.data.serve.pojo.entity.AdsGameServerDay;
 | 
											
										
											
												
													
														|  | @@ -15,8 +14,6 @@ import com.zanxiang.game.data.serve.pojo.vo.*;
 | 
											
												
													
														|  |  import com.zanxiang.game.data.serve.service.IGameServerService;
 |  |  import com.zanxiang.game.data.serve.service.IGameServerService;
 | 
											
												
													
														|  |  import com.zanxiang.game.data.serve.utils.Page;
 |  |  import com.zanxiang.game.data.serve.utils.Page;
 | 
											
												
													
														|  |  import com.zanxiang.game.module.base.ServerInfo;
 |  |  import com.zanxiang.game.module.base.ServerInfo;
 | 
											
												
													
														|  | -import com.zanxiang.game.module.base.pojo.enums.GameAuthEnum;
 |  | 
 | 
											
												
													
														|  | -import com.zanxiang.game.module.base.pojo.vo.GameAuthUserVO;
 |  | 
 | 
											
												
													
														|  |  import com.zanxiang.game.module.base.rpc.GameAuthRpc;
 |  |  import com.zanxiang.game.module.base.rpc.GameAuthRpc;
 | 
											
												
													
														|  |  import com.zanxiang.module.util.pojo.ResultVO;
 |  |  import com.zanxiang.module.util.pojo.ResultVO;
 | 
											
												
													
														|  |  import lombok.extern.slf4j.Slf4j;
 |  |  import lombok.extern.slf4j.Slf4j;
 | 
											
										
											
												
													
														|  | @@ -558,12 +555,12 @@ public class GameServerServiceImpl implements IGameServerService {
 | 
											
												
													
														|  |          //把所有gsIds取出来用,拼起来
 |  |          //把所有gsIds取出来用,拼起来
 | 
											
												
													
														|  |          String gsIds = vos.stream().filter(i -> StringUtils.isNotEmpty(i.getGsIds())).map(GSGameServerDayVO::getGsIds).collect(Collectors.joining(","));
 |  |          String gsIds = vos.stream().filter(i -> StringUtils.isNotEmpty(i.getGsIds())).map(GSGameServerDayVO::getGsIds).collect(Collectors.joining(","));
 | 
											
												
													
														|  |          ResultVO<Map<Long, String>> userMap = null;
 |  |          ResultVO<Map<Long, String>> userMap = null;
 | 
											
												
													
														|  | -        if (StringUtils.isNotEmpty(gsIds)) {
 |  | 
 | 
											
												
													
														|  | -            //转换为Long类型
 |  | 
 | 
											
												
													
														|  | -            List<Long> userIds = Arrays.stream(gsIds.split(",")).map(Long::parseLong).toList();
 |  | 
 | 
											
												
													
														|  | -            //发送RPC接口查询所有用户
 |  | 
 | 
											
												
													
														|  | -            userMap = sysUserRpc.getUserNameByIds(userIds);
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | 
 |  | +//        if (StringUtils.isNotEmpty(gsIds)) {
 | 
											
												
													
														|  | 
 |  | +//            //转换为Long类型
 | 
											
												
													
														|  | 
 |  | +//            List<Long> userIds = Arrays.stream(gsIds.split(",")).map(Long::parseLong).toList();
 | 
											
												
													
														|  | 
 |  | +//            //发送RPC接口查询所有用户
 | 
											
												
													
														|  | 
 |  | +//            userMap = sysUserRpc.getUserNameByIds(userIds);
 | 
											
												
													
														|  | 
 |  | +//        }
 | 
											
												
													
														|  |          for (GSGameServerDayVO vo : vos) {
 |  |          for (GSGameServerDayVO vo : vos) {
 | 
											
												
													
														|  |              List<GSGameServerDayRVO> rDataList = collect.get(vo.getSourceSystem() + vo.getServerId() + vo.getParentGameId());
 |  |              List<GSGameServerDayRVO> rDataList = collect.get(vo.getSourceSystem() + vo.getServerId() + vo.getParentGameId());
 | 
											
												
													
														|  |              for (int i = 0; i < fieldList.size(); i++) {
 |  |              for (int i = 0; i < fieldList.size(); i++) {
 | 
											
										
											
												
													
														|  | @@ -577,7 +574,7 @@ public class GameServerServiceImpl implements IGameServerService {
 | 
											
												
													
														|  |                          GSGameServerDayRVO gsGameServerDayRVO = rDataList.get(i);
 |  |                          GSGameServerDayRVO gsGameServerDayRVO = rDataList.get(i);
 | 
											
												
													
														|  |                          rData = getRDataStr(gsGameServerDayRVO, Long.valueOf(split[split.length - 1]));
 |  |                          rData = getRDataStr(gsGameServerDayRVO, Long.valueOf(split[split.length - 1]));
 | 
											
												
													
														|  |                      } else {
 |  |                      } else {
 | 
											
												
													
														|  | -                        rData = "0/0/0/0/0/0/0/0";
 |  | 
 | 
											
												
													
														|  | 
 |  | +                        rData = "0/0/0/0/0/0/0/0/0/0";
 | 
											
												
													
														|  |                      }
 |  |                      }
 | 
											
												
													
														|  |                      value += "/" + rData;
 |  |                      value += "/" + rData;
 | 
											
												
													
														|  |  //                    field.set(vo, value + "/" + rData);
 |  |  //                    field.set(vo, value + "/" + rData);
 | 
											
										
											
												
													
														|  | @@ -595,6 +592,8 @@ public class GameServerServiceImpl implements IGameServerService {
 | 
											
												
													
														|  |                              .mediumRNum(split[10])
 |  |                              .mediumRNum(split[10])
 | 
											
												
													
														|  |                              .largeRNum(split[11])
 |  |                              .largeRNum(split[11])
 | 
											
												
													
														|  |                              .superRNum(split[12])
 |  |                              .superRNum(split[12])
 | 
											
												
													
														|  | 
 |  | +                            .rTotal(split[13])
 | 
											
												
													
														|  | 
 |  | +                            .rTotalRetention(split[14])
 | 
											
												
													
														|  |                              .build();
 |  |                              .build();
 | 
											
												
													
														|  |                      fieldObjectList.get(i).set(vo, retentionVO);
 |  |                      fieldObjectList.get(i).set(vo, retentionVO);
 | 
											
												
													
														|  |                  } catch (IllegalAccessException e) {
 |  |                  } catch (IllegalAccessException e) {
 | 
											
										
											
												
													
														|  | @@ -712,6 +711,8 @@ public class GameServerServiceImpl implements IGameServerService {
 | 
											
												
													
														|  |                          .mediumRNum(split[10])
 |  |                          .mediumRNum(split[10])
 | 
											
												
													
														|  |                          .largeRNum(split[11])
 |  |                          .largeRNum(split[11])
 | 
											
												
													
														|  |                          .superRNum(split[12])
 |  |                          .superRNum(split[12])
 | 
											
												
													
														|  | 
 |  | +                        .rTotal(split[13])
 | 
											
												
													
														|  | 
 |  | +                        .rTotalRetention(split[14])
 | 
											
												
													
														|  |                          .build();
 |  |                          .build();
 | 
											
												
													
														|  |                  fieldObjectList.get(i).set(vo, retentionVO);
 |  |                  fieldObjectList.get(i).set(vo, retentionVO);
 | 
											
												
													
														|  |  //                field.set(vo, value + "/" + rData);
 |  |  //                field.set(vo, value + "/" + rData);
 | 
											
										
											
												
													
														|  | @@ -764,14 +765,18 @@ public class GameServerServiceImpl implements IGameServerService {
 | 
											
												
													
														|  |              Long mediumRCount = rvo.getMediumR();
 |  |              Long mediumRCount = rvo.getMediumR();
 | 
											
												
													
														|  |              Long largeRCont = rvo.getLargeR();
 |  |              Long largeRCont = rvo.getLargeR();
 | 
											
												
													
														|  |              Long superRCount = rvo.getSuperR();
 |  |              Long superRCount = rvo.getSuperR();
 | 
											
												
													
														|  | 
 |  | +            //R总
 | 
											
												
													
														|  | 
 |  | +            long rCount = smallRCount + mediumRCount + largeRCont + superRCount;
 | 
											
												
													
														|  |              //R留存率
 |  |              //R留存率
 | 
											
												
													
														|  |              BigDecimal smallR = new BigDecimal(smallRCount).divide(new BigDecimal(totalNum), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.DOWN);
 |  |              BigDecimal smallR = new BigDecimal(smallRCount).divide(new BigDecimal(totalNum), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.DOWN);
 | 
											
												
													
														|  |              BigDecimal mediumR = new BigDecimal(mediumRCount).divide(new BigDecimal(totalNum), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.DOWN);
 |  |              BigDecimal mediumR = new BigDecimal(mediumRCount).divide(new BigDecimal(totalNum), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.DOWN);
 | 
											
												
													
														|  |              BigDecimal largeR = new BigDecimal(largeRCont).divide(new BigDecimal(totalNum), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.DOWN);
 |  |              BigDecimal largeR = new BigDecimal(largeRCont).divide(new BigDecimal(totalNum), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.DOWN);
 | 
											
												
													
														|  |              BigDecimal superR = new BigDecimal(superRCount).divide(new BigDecimal(totalNum), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.DOWN);
 |  |              BigDecimal superR = new BigDecimal(superRCount).divide(new BigDecimal(totalNum), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.DOWN);
 | 
											
												
													
														|  | -            return smallR + "/" + mediumR + "/" + largeR + "/" + superR + "/" + smallRCount + "/" + mediumRCount + "/" + largeRCont + "/" + superRCount;
 |  | 
 | 
											
												
													
														|  | 
 |  | +            //R总留存
 | 
											
												
													
														|  | 
 |  | +            BigDecimal r = new BigDecimal(rCount).divide(new BigDecimal(totalNum), 4, RoundingMode.HALF_UP).multiply(BigDecimal.valueOf(100)).setScale(2, RoundingMode.DOWN);
 | 
											
												
													
														|  | 
 |  | +            return smallR + "/" + mediumR + "/" + largeR + "/" + superR + "/" + smallRCount + "/" + mediumRCount + "/" + largeRCont + "/" + superRCount+"/"+rCount+"/"+r;
 | 
											
												
													
														|  |          } else {
 |  |          } else {
 | 
											
												
													
														|  | -            return "0/0/0/0/0/0/0/0";
 |  | 
 | 
											
												
													
														|  | 
 |  | +            return "0/0/0/0/0/0/0/0/0/0";
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -823,13 +828,13 @@ public class GameServerServiceImpl implements IGameServerService {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      private Criteria getGameServerDayCriteria(GSGameServerDayDTO dto) {
 |  |      private Criteria getGameServerDayCriteria(GSGameServerDayDTO dto) {
 | 
											
												
													
														|  | -        GameAuthUserVO userGameInfo = gameAuthRpc.getGameAuthByUserIds().getData();
 |  | 
 | 
											
												
													
														|  | 
 |  | +//        GameAuthUserVO userGameInfo = gameAuthRpc.getGameAuthByUserIds().getData();
 | 
											
												
													
														|  |          List<Long> serverIdByGS = null;
 |  |          List<Long> serverIdByGS = null;
 | 
											
												
													
														|  |          //判断是不是GS
 |  |          //判断是不是GS
 | 
											
												
													
														|  | -        if (GameAuthEnum.getByValue(userGameInfo.getGameAuthEnum().getValue()) != null) {
 |  | 
 | 
											
												
													
														|  | -            //查询GS管理的区服列表
 |  | 
 | 
											
												
													
														|  | -            serverIdByGS = getServerIdByGSId(SecurityUtil.getUserId()).stream().filter(StringUtils::isNotEmpty).map(Long::parseLong).collect(Collectors.toList());
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | 
 |  | +//        if (GameAuthEnum.getByValue(userGameInfo.getGameAuthEnum().getValue()) != null) {
 | 
											
												
													
														|  | 
 |  | +//            //查询GS管理的区服列表
 | 
											
												
													
														|  | 
 |  | +//            serverIdByGS = getServerIdByGSId(SecurityUtil.getUserId()).stream().filter(StringUtils::isNotEmpty).map(Long::parseLong).collect(Collectors.toList());
 | 
											
												
													
														|  | 
 |  | +//        }
 | 
											
												
													
														|  |          //创建查询条件
 |  |          //创建查询条件
 | 
											
												
													
														|  |          Criteria cri = Cnd.cri();
 |  |          Criteria cri = Cnd.cri();
 | 
											
												
													
														|  |          if (CollectionUtils.isNotEmpty(serverIdByGS)) {
 |  |          if (CollectionUtils.isNotEmpty(serverIdByGS)) {
 | 
											
										
											
												
													
														|  | @@ -897,6 +902,7 @@ public class GameServerServiceImpl implements IGameServerService {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      /**
 |  |      /**
 | 
											
												
													
														|  |       * 获取每天活跃留存率/付费留存率的sql
 |  |       * 获取每天活跃留存率/付费留存率的sql
 | 
											
												
													
														|  | 
 |  | +     * -
 | 
											
												
													
														|  |       */
 |  |       */
 | 
											
												
													
														|  |      private String getRemainDaySql() {
 |  |      private String getRemainDaySql() {
 | 
											
												
													
														|  |          StringBuilder sql = new StringBuilder(StringUtils.EMPTY);
 |  |          StringBuilder sql = new StringBuilder(StringUtils.EMPTY);
 |