123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423 |
- package com.fdkankan.scene.service.impl;
- import cn.hutool.core.collection.CollUtil;
- import cn.hutool.core.util.StrUtil;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
- import com.fdkankan.common.constant.ErrorCode;
- import com.fdkankan.common.constant.SceneSource;
- import com.fdkankan.common.constant.ServerCode;
- import com.fdkankan.common.exception.BusinessException;
- import com.fdkankan.common.response.PageInfo;
- import com.fdkankan.common.response.ResultData;
- import com.fdkankan.common.user.SSOLoginHelper;
- import com.fdkankan.common.user.SSOUser;
- import com.fdkankan.common.util.PageInfoUtils;
- import com.fdkankan.platform.api.feign.PlatformGoodsClient;
- import com.fdkankan.platform.api.feign.PlatformUserClient;
- import com.fdkankan.platform.api.vo.Camera;
- import com.fdkankan.platform.api.vo.User;
- import com.fdkankan.scene.api.vo.SceneCnt;
- import com.fdkankan.scene.entity.Folder;
- import com.fdkankan.scene.entity.FolderScene;
- import com.fdkankan.scene.entity.Scene;
- import com.fdkankan.scene.entity.SceneCooperation;
- import com.fdkankan.scene.entity.SceneEditInfoExt;
- import com.fdkankan.scene.entity.ScenePro;
- import com.fdkankan.scene.entity.SceneProExt;
- import com.fdkankan.scene.entity.SceneProPO;
- import com.fdkankan.scene.mapper.ISceneProMapper;
- import com.fdkankan.scene.service.IFolderSceneService;
- import com.fdkankan.scene.service.IFolderService;
- import com.fdkankan.scene.service.ISceneCooperationService;
- import com.fdkankan.scene.service.ISceneEditInfoExtService;
- import com.fdkankan.scene.service.ISceneProExtService;
- import com.fdkankan.scene.service.ISceneProService;
- import com.fdkankan.scene.service.ISceneService;
- import com.fdkankan.scene.service.IUserSceneService;
- import com.fdkankan.scene.vo.FolderVO;
- import com.fdkankan.scene.vo.SceneParamVO;
- import com.fdkankan.scene.vo.SceneVO;
- import java.util.ArrayList;
- import java.util.Arrays;
- import java.util.HashMap;
- import java.util.Map;
- import java.util.Objects;
- import java.util.concurrent.locks.Condition;
- import lombok.extern.slf4j.Slf4j;
- import org.apache.commons.lang3.StringUtils;
- import org.springframework.beans.BeanUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import java.util.List;
- import java.util.stream.Collectors;
- import org.springframework.util.CollectionUtils;
- import org.springframework.util.ObjectUtils;
- @Service
- @Slf4j
- public class UserSceneServiceImpl implements IUserSceneService {
- @Autowired
- private SSOLoginHelper ssoLoginHelper;
- @Autowired
- private PlatformGoodsClient platformGoodsClient;
- @Autowired
- private PlatformUserClient platformUserClient;
- @Autowired
- private ISceneCooperationService sceneCooperationService;
- @Autowired
- private ISceneService sceneService;
- @Autowired
- private ISceneProService sceneProService;
- @Autowired
- private ISceneProExtService sceneProExtService;
- @Autowired
- private IFolderService folderService;
- @Autowired
- private IFolderSceneService folderSceneService;
- @Autowired
- private ISceneProMapper sceneProMapper;
- @Autowired
- private ISceneEditInfoExtService sceneEditInfoExtService;
- @Override
- public Page<SceneVO> getScenes(String token, SceneParamVO param) {
- SSOUser ssoUser = ssoLoginHelper.loginCheck(token);
- if(ssoUser == null){
- throw new BusinessException(ErrorCode.USER_NOT_LOGIN);
- }
- Long userId = ssoUser.getId();
- param.setUserId(userId);
- String cameraId = null;
- String nums = null;
- log.info("搜索条件是:"+ param.getSearchKey());
- //type为12表示一键换装的请求,不查询相机数据
- if(StringUtils.isNotEmpty(param.getSearchKey()) && !"11".equals(param.getType())){
- List<Camera> cameraEntityList = platformGoodsClient.getCameraLikeSnCode(param.getSearchKey()).getData();
- cameraId = cameraEntityList.parallelStream().map(entity->"'"+entity.getId()+"'").collect(Collectors.joining(","));
- List<User> userList = platformUserClient.getUserLikeUserName(param.getSearchKey()).getData();
- List<Long> userIds = userList.parallelStream().map(User::getId).collect(Collectors.toList());
- if(userIds.size() > 0){
- List<SceneCooperation> cooperationList = sceneCooperationService.getListByUserId(userIds);
- nums = cooperationList.parallelStream().map(entity->"'"+entity.getNum()+"'").collect(Collectors.joining(","));
- param.setNums(nums);
- }
- }
- param.setCameraIds(cameraId);
- Page<SceneProPO> proPOPage = sceneService.findAllScene( param);
- Page<SceneVO> pageInfo = new Page<>(proPOPage.getCurrent(),proPOPage.getSize());
- pageInfo.setTotal(proPOPage.getTotal());
- pageInfo.setRecords(proPOPage.getRecords().stream().map(sceneProPO -> {
- SceneVO sceneVO = new SceneVO();
- BeanUtils.copyProperties(sceneProPO,sceneVO);
- return sceneVO;
- }).collect(Collectors.toList()));
- List<SceneVO> list = pageInfo.getRecords();
- list.parallelStream().forEach(responseScene->{
- if(responseScene.getCameraId() != null){
- Camera cameraEntity = platformGoodsClient.getCameraById(responseScene.getCameraId()).getData();
- if(cameraEntity != null){
- responseScene.setChildName(cameraEntity.getChildName());
- responseScene.setSnCode(cameraEntity.getSnCode());
- }
- }
- if(responseScene.getUserId()!=null){
- String username = platformUserClient.getUserByUserId(responseScene.getUserId()).getData().getUserName();
- responseScene.setUserName(username);
- }
- SceneCooperation sceneCooperationEntity = sceneCooperationService.findBySceneNum(responseScene.getNum());
- if(sceneCooperationEntity != null){
- responseScene.setCooperationUserId(String.valueOf(sceneCooperationEntity.getUserId()));
- responseScene.setCooperationUserName(sceneCooperationService.findUserName(responseScene.getNum()));
- }
- });
- return pageInfo;
- }
- @Override
- public SceneCnt getSceneCnt(Long userId, Long cameraId) {
- //双目场景数量
- LambdaQueryWrapper<Scene> sceneWrapper =
- new LambdaQueryWrapper<Scene>()
- .eq(Scene::getUserId, userId);
- if(Objects.nonNull(cameraId)){
- sceneWrapper.eq(Scene::getCameraId, cameraId);
- }
- long sceneCount = sceneService.count(sceneWrapper);
- //八目场景数量
- LambdaQueryWrapper<ScenePro> sceneProWrapper =
- new LambdaQueryWrapper<ScenePro>()
- .select(ScenePro::getId)
- .eq(ScenePro::getUserId, userId);
- if(Objects.nonNull(cameraId)){
- sceneWrapper.eq(Scene::getCameraId, cameraId);
- }
- List<ScenePro> SceneProList = sceneProService.list(sceneProWrapper);
- long sceneProCount = 0;
- if(CollUtil.isNotEmpty(SceneProList)){
- List<Long> proIdList = SceneProList.stream().map(pro -> {
- return pro.getId();
- }).collect(Collectors.toList());
- sceneProCount = sceneProExtService.count(
- new LambdaQueryWrapper<SceneProExt>()
- .eq(SceneProExt::getSceneSource,SceneSource.YJHZ.code())
- .in(SceneProExt::getSceneProId, proIdList));
- }
- //协作场景数量
- long cooperaCount = sceneCooperationService.count(
- new LambdaQueryWrapper<SceneCooperation>().eq(SceneCooperation::getUserId, userId));
- return SceneCnt.builder().sceneCnt(sceneCount).sceneProCnt(sceneProCount).CooperSceneCnt(cooperaCount).build();
- }
- @Override
- public ResultData findSceneNumber(long userId, String snCode) throws Exception{
- Map<String, Object> map = new HashMap<>();
- Camera camera = null;
- if (!ObjectUtils.isEmpty(snCode)) {
- ResultData<Camera> cameraResultData = platformGoodsClient.getCameraBySnCode(snCode);
- if(!cameraResultData.getSuccess()){
- throw new Exception(ServerCode.FEIGN_REQUEST_FAILD.message());
- }
- camera = cameraResultData.getData();
- if(ObjectUtils.isEmpty(camera)){
- map.put("sceneNum", 0);
- map.put("cooperatimeNum", 0);
- return ResultData.ok(map);
- }
- }
- //双目场景数量
- SceneCnt sceneCnt = this.getSceneCnt(userId, Objects.isNull(camera) ? null : camera.getId());
- map.put("sceneNum", sceneCnt.getSceneCnt() + sceneCnt.getSceneProCnt());
- map.put("cooperatimeNum", sceneCnt.getCooperSceneCnt());
- return ResultData.ok(map);
- }
- @Override
- public ResultData getNewScenes(SceneParamVO param) throws Exception {
- Long userId = param.getUserId();
- if(param.getKeywordType().equals("userName") && StringUtils.isNotEmpty(param.getSearchKey())){
- ResultData<List<User>> userLikeUserName = platformUserClient
- .getUserLikeUserName("%" + param.getSearchKey() + "%");
- if(!userLikeUserName.getSuccess()){
- throw new Exception(ServerCode.FEIGN_REQUEST_FAILD.message());
- }
- List<User> userList = userLikeUserName.getData();
- List<Long> userIds = userList.parallelStream().map(User::getId).collect(Collectors.toList());
- List<SceneCooperation> sceneCooperationList = sceneCooperationService.list(
- new LambdaQueryWrapper<SceneCooperation>()
- .select(SceneCooperation::getNum)
- .in(SceneCooperation::getUserId, userIds));
- //获取所有协作场景的场景码集合
- param.setNumList(sceneCooperationList.parallelStream().map(SceneCooperation::getNum).collect(Collectors.toList()));
- }
- Map<String, Object> map = this.getNewScenesPagerByUserId(userId, param);
- Page<Object> page = (Page<Object>) map.get("pageInfo");
- List<Object> list = page.getRecords();
- list.parallelStream().filter(object -> object instanceof SceneVO).forEach(object -> {
- SceneVO responseScene = (SceneVO) object;
- // 当计算时,返回给前端的状态为计算中
- if (responseScene.getStatus() == -1) {
- responseScene.setStatus(0);
- } else if (responseScene.getStatus() == 500) {
- responseScene.setStatus(-1);
- }
- // 获取VrThumb
- SceneEditInfoExt sceneEditInfoExt
- = sceneEditInfoExtService.getOne(
- new LambdaQueryWrapper<SceneEditInfoExt>()
- .select(SceneEditInfoExt::getVrNum)
- .eq(SceneEditInfoExt::getSceneProId, responseScene.getId()));
- if (!ObjectUtils.isEmpty(sceneEditInfoExt)) {
- responseScene.setVrNum(sceneEditInfoExt.getVrNum());
- }
- if (responseScene.getCameraId() != null) {
- ResultData<Camera> cameraResultData = platformGoodsClient
- .getCameraById(responseScene.getCameraId());
- if(!cameraResultData.getSuccess()){
- throw new BusinessException(ErrorCode.SYSTEM_BUSY);
- }
- Camera camera = cameraResultData.getData();
- if (camera != null) {
- responseScene.setChildName(camera.getChildName());
- responseScene.setSnCode(camera.getSnCode());
- }
- }
- SceneCooperation sceneCooperation = sceneCooperationService.findBySceneNum(responseScene.getNum());
- if (sceneCooperation != null) {
- responseScene.setCooperationUserId(String.valueOf(sceneCooperation.getUserId()));
- responseScene.setCooperationUserName(sceneCooperationService.findUserName(responseScene.getNum()));
- }
- });
- map.put("pageInfo", PageInfo.PageInfo(page));
- return ResultData.ok(map);
- }
- public Map<String, Object> getNewScenesPagerByUserId(Long userId, SceneParamVO param) throws Exception {
- List<SceneProPO> sceneList = new ArrayList<>();
- List<Folder> folderList = new ArrayList<>();
- boolean searchCamera = false;
- List<Camera> cameraList = new ArrayList<>();
- String sceneName = "";
- if (StringUtils.isNotEmpty(param.getKeywordType())) {
- if (param.getKeywordType().equals("sceneName")) {
- sceneName = param.getSearchKey();
- } else if (param.getKeywordType().equals("snCode") && Objects
- .nonNull(param.getSearchKey())) {
- ResultData<List<Camera>> cameraResult = platformGoodsClient
- .getCameraLikeSnCode(param.getSearchKey());
- if (!cameraResult.getSuccess())
- throw new Exception(ServerCode.FEIGN_REQUEST_FAILD.message());
- cameraList = cameraResult.getData();
- searchCamera = true;
- }
- }
- //根目录时,需要排除已经归类的场景
- if(param.getFolderId() == null){
- //查出所有已经归类的场景id
- List<Folder> allFolderList = folderService.list(
- new LambdaQueryWrapper<Folder>()
- .eq(Folder::getUserId, param.getUserId())
- .eq(Folder::getFolderType, param.getFolderType()));
- folderList = allFolderList.parallelStream().filter(folder->ObjectUtils.isEmpty(folder.getParentId())).collect(Collectors.toList());
- // 查找所有的文件夹
- List<Long> folderIds = allFolderList.parallelStream().map(Folder::getId).collect(Collectors.toList());
- List<Long> sceneIdList = new ArrayList<>();
- if(CollUtil.isNotEmpty(folderIds)){
- List<FolderScene> folderSceneList = folderSceneService.list(
- new LambdaQueryWrapper<FolderScene>()
- .select(FolderScene::getSceneId)
- .in(FolderScene::getFolderId, folderIds));
- sceneIdList = folderSceneList.parallelStream().map(FolderScene::getSceneId).collect(Collectors.toList());
- }
- if(sceneIdList.size() > 0){
- param.setSceneIdList(sceneIdList);
- }
- //协作者 检索
- if(param.getKeywordType().equals("userName") && StringUtils.isNotEmpty(param.getSearchKey())){
- if(CollUtil.isEmpty(param.getNumList())){
- param.setNum("");
- }
- }
- if(Objects.nonNull(param.getSceneSource())){
- param.setSceneSourceList(
- Arrays.stream(param.getSceneSource().split(","))
- .map(source->Integer.parseInt(source))
- .collect(Collectors.toList()));
- }
- if(searchCamera){
- if(CollUtil.isEmpty(cameraList)){
- sceneList = new ArrayList<>();
- }else{
- param.setCameraIdList(cameraList.stream().map(Camera::getId).collect(Collectors.toList()));
- sceneList = sceneProMapper.selectSceneList(param);
- }
- }else{
- sceneList = sceneProMapper.selectSceneList(param);
- }
- }else {
- //进入目录层级后,根据目录获取当前目录的所有场景
- List<Long> sceneIdList = folderSceneService
- .getSceneIdListByFolderId(param.getFolderId());
- if(CollUtil.isNotEmpty(sceneIdList)){
- param.setSceneIdList(sceneIdList);
- if(searchCamera){
- if(CollUtil.isEmpty(cameraList)){
- sceneList = new ArrayList<>();
- }else{
- param.setCameraIdList(cameraList.stream().map(Camera::getId).collect(Collectors.toList()));
- sceneList = sceneProMapper.selectSceneList(param);
- }
- }else{
- sceneList = sceneProMapper.selectSceneList(param);
- }
- }
- //获取文件夹数量
- folderList= folderService.list(
- new LambdaQueryWrapper<Folder>().eq(Folder::getUserId, param.getUserId())
- .eq(Folder::getParentId, param.getFolderId())
- .orderByDesc(Folder::getId));
- }
- List<SceneVO> responseScenes = sceneService.convertPro(sceneList);
- //当前文件夹所包含的所有场景数量
- Long sceneNum = 0L;
- List<FolderVO> responseFolderList = new ArrayList<>();
- List<Object> result = new ArrayList<>();
- if(Objects.nonNull(param.getSceneSource()) && StrUtil.isEmpty(param.getSceneType()) &&
- param.getStartTime() == null && param.getEndTime() == null){
- responseFolderList = folderService.convert(folderList);
- result.addAll(responseFolderList);
- //根目录判断是否有双目文件夹
- if(param.getFolderId() == null && param.getSceneSource().contains("1")){
- //判断是否有双目场景,有则增加双目的文件夹
- Long sceneCnt = sceneService
- .count(new LambdaQueryWrapper<Scene>().eq(Scene::getUserId, userId));
- if(sceneCnt > 0){
- FolderVO sceneFolder = new FolderVO();
- sceneFolder.setName("双目文件夹");
- //type为3,表示旧版双目相机场景
- sceneFolder.setType(3);
- sceneFolder.setIsFolder(1);
- sceneFolder.setSceneNum(Integer.parseInt(String.valueOf(sceneCnt)));
- result.add(sceneFolder);
- }
- }
- }
- //统计当前目录所有场景数量
- sceneNum += responseFolderList.parallelStream().mapToLong(FolderVO::getSceneNum).sum();
- sceneNum += sceneList.size();
- sceneNum += responseScenes.size();
- result.addAll(responseScenes);
- Page<Object> data = PageInfoUtils.list2PageInfo(result, param.getPageNum(), param.getPageSize());
- Map<String, Object> map = new HashMap<>();
- map.put("sceneNum", sceneNum);
- map.put("pageInfo", data);
- return map;
- }
- }
|