PanoService.java 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. package fcb.project.manager.base.service.custom;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONArray;
  4. import com.alibaba.fastjson.JSONObject;
  5. import fcb.project.manager.base.entity.CommonRspBean;
  6. import fcb.project.manager.base.entity.PanoSceneBean;
  7. import fcb.project.manager.base.entity.SevenTwoZeroSceneRspBean;
  8. import fcb.project.manager.core.feignInterfaces.PanoFeign;
  9. import lombok.extern.log4j.Log4j2;
  10. import org.apache.commons.lang3.StringUtils;
  11. import org.springframework.beans.factory.annotation.Autowired;
  12. import org.springframework.stereotype.Service;
  13. import org.springframework.util.CollectionUtils;
  14. import java.util.*;
  15. /**
  16. * 2 * @Author: Abner
  17. * 3 * @Date: 2021/1/26 19:09
  18. * 4
  19. */
  20. @Service
  21. @Log4j2
  22. public class PanoService {
  23. @Autowired
  24. PanoFeign panoFeign;
  25. public boolean noticeVrAuditStatus(String houseId, String token , int status){
  26. if(StringUtils.isBlank(houseId)){
  27. return false;
  28. }
  29. CommonRspBean rspBean = panoFeign.auditedVrNotice(houseId, status , token );
  30. log.info("通知720VR项目审核结果{},720返回结果:{}" , status , JSON.toJSONString(rspBean));
  31. if(null == rspBean || null == rspBean.getCode() || rspBean.getCode().compareTo(0) != 0){
  32. return false;
  33. }
  34. log.info("成功通知720VR项目审核结果");
  35. return true;
  36. }
  37. public boolean noticeDeleteVr(String houseId, String token){
  38. if(StringUtils.isBlank(houseId)){
  39. return false;
  40. }
  41. CommonRspBean rspBean = panoFeign.deleteVrNotice(houseId , token);
  42. log.info("通知720删除V项目,720返回结果:{}" , JSON.toJSONString(rspBean));
  43. if(null == rspBean || null == rspBean.getCode() || rspBean.getCode().compareTo(0) != 0){
  44. return false;
  45. }
  46. log.info("成功通知720VR项目已经删除");
  47. return true;
  48. }
  49. public List<String> getKanKanSceneNums(String houseId, String token) {
  50. if (StringUtils.isBlank(houseId)) {
  51. return null;
  52. }
  53. SevenTwoZeroSceneRspBean sevenTwoZeroSceneRspBean = null;
  54. try {
  55. sevenTwoZeroSceneRspBean = panoFeign.getFdkanaknSceneNum(token , houseId , "3" , "house");
  56. }catch (Exception e){
  57. log.info("调用720出现异常:{}" , e);
  58. return null;
  59. }
  60. log.info("720返回结果:{}", JSON.toJSONString(sevenTwoZeroSceneRspBean));
  61. if (null == sevenTwoZeroSceneRspBean || null == sevenTwoZeroSceneRspBean.getCode()) {
  62. log.info("720返回结果解析失败");
  63. return null;
  64. }
  65. if (sevenTwoZeroSceneRspBean.getCode().compareTo(0) != 0) {
  66. log.info("720返回非成功:code={},msg={}", sevenTwoZeroSceneRspBean.getCode(), sevenTwoZeroSceneRspBean.getMsg());
  67. return null;
  68. }
  69. if (CollectionUtils.isEmpty(sevenTwoZeroSceneRspBean.getData())) {
  70. log.info("720返回的list为空,无需操作");
  71. return null;
  72. }
  73. return sevenTwoZeroSceneRspBean.getData();
  74. }
  75. public TreeMap<String , Object> getHouseVrlinks(List<String> houseIds , String token){
  76. if(CollectionUtils.isEmpty(houseIds)){
  77. return new TreeMap<>();
  78. }
  79. Map<String , Object> body = new HashMap<>();
  80. body.put("houseIds" , houseIds);
  81. body.put("pageNum" , 1);
  82. body.put("pageSize" , houseIds.size());
  83. CommonRspBean rspBean = panoFeign.getVrLinks(body , token);
  84. log.info("从720获取最新vrlink的预览路径的返回值为:{}" , JSON.toJSONString(rspBean));
  85. if(null == rspBean || null == rspBean.getCode() || rspBean.getCode() != 0){
  86. log.info("调用720获取最新的预览路径失败");
  87. return new TreeMap<>();
  88. }
  89. Map<String ,Object> jsonObject = null;
  90. try {
  91. jsonObject = (Map<String, Object>) rspBean.getData();
  92. }catch (Exception e){
  93. log.info("解析data数据失败");
  94. return new TreeMap<>();
  95. }
  96. if(null == jsonObject){
  97. log.info("解析720返回的data失败");
  98. return new TreeMap<>();
  99. }
  100. if(!jsonObject.containsKey("list")){
  101. log.info("解析720返回的data缺失list");
  102. return new TreeMap<>();
  103. }
  104. List<Map<String, Object>> list = null;
  105. try {
  106. list = (List<Map<String, Object>>) jsonObject.get("list");
  107. }catch (Exception e){
  108. log.info("720返回的data的list转换失败");
  109. return new TreeMap<>();
  110. }
  111. if(null == list || list.isEmpty()){
  112. log.info("720返回的data的list为空");
  113. return new TreeMap<>();
  114. }
  115. TreeMap<String , Object> resultTree = new TreeMap<>();
  116. for (int i = 0; i < list.size(); i++) {
  117. resultTree.putAll(list.get(i));
  118. }
  119. return resultTree;
  120. }
  121. public String getOneVrLink(String houseId , String token){
  122. if(StringUtils.isNoneBlank(houseId , token)){
  123. CommonRspBean rspBean = panoFeign.getOneVrlink(houseId , token);
  124. log.info("从720获取最新单个vrlink的预览路径的返回值为:{}" , JSON.toJSONString(rspBean));
  125. if(null == rspBean || null == rspBean.getCode() || rspBean.getCode() != 0){
  126. log.info("调用720获单个取最新的预览路径失败");
  127. return "";
  128. }
  129. PanoSceneBean panoSceneBean = null;
  130. try {
  131. panoSceneBean = JSONObject.parseObject(JSON.toJSONString(rspBean.getData()) , PanoSceneBean.class);
  132. }catch (Exception e){
  133. log.info("720返回的data转换失败");
  134. return "";
  135. }
  136. if(null == panoSceneBean){
  137. log.info("720返回的data为空");
  138. return "";
  139. }
  140. return panoSceneBean.getWebSite();
  141. }
  142. return "";
  143. }
  144. }