AdmSystemController.java 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547
  1. package com.persagy.proxy.adm.controller;
  2. import cn.hutool.core.collection.CollUtil;
  3. import cn.hutool.core.util.StrUtil;
  4. import cn.hutool.json.JSONUtil;
  5. import com.alibaba.fastjson.JSONObject;
  6. import com.fasterxml.jackson.databind.node.ArrayNode;
  7. import com.fasterxml.jackson.databind.node.JsonNodeFactory;
  8. import com.fasterxml.jackson.databind.node.ObjectNode;
  9. import com.persagy.dmp.basic.dto.RequestData;
  10. import com.persagy.dmp.basic.model.QueryCriteria;
  11. import com.persagy.dmp.common.model.entity.BaseEntity;
  12. import com.persagy.dmp.define.client.DigitalDefineFacade;
  13. import com.persagy.dmp.define.entity.ObjectTypeDefine;
  14. import com.persagy.dmp.digital.client.DigitalObjectFacade;
  15. import com.persagy.dmp.digital.client.DigitalRelationFacade;
  16. import com.persagy.dmp.digital.entity.ObjectRelation;
  17. import com.persagy.dmp.simple.client.DigitalObjectSimpleFacade;
  18. import com.persagy.proxy.adm.model.*;
  19. import com.persagy.proxy.adm.request.AdmCreateRequest;
  20. import com.persagy.proxy.adm.request.AdmQueryCriteria;
  21. import com.persagy.proxy.adm.request.AdmResponse;
  22. import com.persagy.proxy.adm.service.IAdmBuildingService;
  23. import com.persagy.proxy.adm.service.IAdmDictService;
  24. import com.persagy.proxy.adm.service.IAdmFloorService;
  25. import com.persagy.proxy.adm.service.IAdmSystemService;
  26. import com.persagy.proxy.adm.utils.AdmContextUtil;
  27. import com.persagy.proxy.adm.utils.AdmQueryCriteriaHelper;
  28. import com.persagy.proxy.adm.utils.ObjectNameUtil;
  29. import com.persagy.proxy.common.entity.DmpResult;
  30. import org.springframework.beans.factory.annotation.Autowired;
  31. import org.springframework.web.bind.annotation.*;
  32. import javax.json.JsonObject;
  33. import javax.validation.constraints.NotNull;
  34. import javax.ws.rs.QueryParam;
  35. import java.util.ArrayList;
  36. import java.util.Arrays;
  37. import java.util.List;
  38. import java.util.Map;
  39. /**
  40. * Adm 系统 API
  41. * @author lvxy
  42. * @date 2021/8/16
  43. */
  44. @RestController
  45. @RequestMapping("/object/general-system")
  46. public class AdmSystemController {
  47. @Autowired
  48. private IAdmSystemService service;
  49. @Autowired
  50. private IAdmBuildingService buildingService;
  51. @Autowired
  52. private IAdmFloorService floorService;
  53. @Autowired
  54. private IAdmDictService dictService;
  55. /**
  56. * 统计
  57. * @param request
  58. * @return
  59. * @throws Exception
  60. */
  61. @PostMapping("/count")
  62. public AdmResponse count(@RequestBody AdmQueryCriteria request) throws Exception {
  63. request.setName(AdmSystem.OBJ_TYPE);
  64. request.setOnlyCount(true);
  65. return service.doQuery(AdmContextUtil.toDmpContext(), request, AdmSystem.class);
  66. }
  67. /**
  68. * 创建
  69. * @param createRequest
  70. * @return
  71. * @throws Exception
  72. */
  73. @PostMapping("/create")
  74. public AdmResponse create(@RequestBody AdmCreateRequest<AdmSystem> createRequest, @QueryParam("projectId") String projectId) throws Exception {
  75. List<AdmSystem> vos = CollUtil.newArrayList(createRequest.getContent());
  76. vos = service.doInsert(AdmContextUtil.toDmpContext(), AdmSystem.class, vos);
  77. return AdmResponse.success(vos);
  78. }
  79. /**
  80. * 创建系统信息-处理建筑楼层
  81. * @param createRequest
  82. * @return
  83. * @throws Exception
  84. */
  85. @PostMapping("/create-bd-fl")
  86. public AdmResponse createBdFl(@RequestBody AdmCreateRequest<AdmSystem> createRequest, @QueryParam("projectId") String projectId) throws Exception {
  87. List<AdmSystem> vos = CollUtil.newArrayList(createRequest.getContent());
  88. Map<String, AdmSystem> admSystemMap = CollUtil.fieldValueMap(vos, "classCode");
  89. QueryCriteria defineCriteria = new QueryCriteria();
  90. ObjectNode criteria = JsonNodeFactory.instance.objectNode();
  91. ArrayNode array = criteria.putObject("code").putArray("$in");
  92. admSystemMap.keySet().stream().forEach(classCode -> array.add(classCode));
  93. defineCriteria.setCriteria(criteria);
  94. List<ObjectTypeDefine> defineList = DigitalDefineFacade.queryObjectType(AdmContextUtil.toDmpContext().getGroupCode(),AdmContextUtil.toDmpContext().getProjectId(),AdmContextUtil.toDmpContext().getAppId(),null,defineCriteria);
  95. Map<String, ObjectTypeDefine> defineMap = CollUtil.fieldValueMap(defineList, "code");
  96. vos.stream().forEach(admSystem -> {
  97. if(StrUtil.isEmpty(admSystem.getName())){
  98. if(CollUtil.isNotEmpty(defineList) && defineMap.containsKey(admSystem.getClassCode())){
  99. admSystem.setName(ObjectNameUtil.objectName(defineMap.get(admSystem.getClassCode()).getName()+"系统-"));
  100. }else {
  101. admSystem.setName(ObjectNameUtil.objectName("系统-"));
  102. }
  103. }
  104. });
  105. vos = service.doInsert(AdmContextUtil.toDmpContext(), AdmSystem.class, vos);
  106. return AdmResponse.success(vos);
  107. }
  108. /**
  109. * 根据ID删除
  110. * @param vos
  111. * @return
  112. * @throws Exception
  113. */
  114. @PostMapping("/delete")
  115. public AdmResponse delete( @RequestBody List<AdmSystem> vos) throws Exception {
  116. service.doDelete(AdmContextUtil.toDmpContext(), vos);
  117. return AdmResponse.success();
  118. }
  119. /**
  120. * 更新
  121. * @param createRequest
  122. * @return
  123. * @throws Exception
  124. */
  125. @PostMapping("/update")
  126. public AdmResponse update(@RequestBody AdmCreateRequest<AdmSystem> createRequest, @QueryParam("projectId") String projectId) throws Exception {
  127. List<AdmSystem> vos = CollUtil.newArrayList(createRequest.getContent());
  128. vos = service.doUpdate(AdmContextUtil.toDmpContext(), AdmSystem.class, vos);
  129. return AdmResponse.success(vos);
  130. }
  131. /**
  132. * 系统绑定的动态信息点或静态信息点
  133. * type: static(静态),iot (动态)
  134. * @param request
  135. * @return
  136. * @throws Exception
  137. */
  138. @GetMapping("/export")
  139. public AdmResponse exportInfos(
  140. @RequestBody AdmQueryCriteria request) throws Exception {
  141. request.setName(AdmSystem.OBJ_TYPE);
  142. return service.doQuery(AdmContextUtil.toDmpContext(), request, AdmSystem.class);
  143. }
  144. /**
  145. * 创建系统下的设备关系
  146. * @param createRequest
  147. * @return
  148. * @throws Exception
  149. */
  150. @PostMapping("/link-equip")
  151. public AdmResponse createRelateEquip(@RequestBody JsonObject createRequest, @QueryParam("projectId") String projectId) throws Exception {
  152. String sysId = createRequest.get("sysId").toString();
  153. List<String> equipIdList = (List<String>)createRequest.get("equipIdList");
  154. List<ObjectNode> relations = new ArrayList<>(equipIdList.size());
  155. equipIdList.stream().forEach(euipId -> {
  156. ObjectNode objectNode = JsonNodeFactory.instance.objectNode();
  157. objectNode.put("relCode", "Sy2Eq");
  158. objectNode.put("graphCode","MechSubset");
  159. objectNode.put("objFrom", sysId);
  160. objectNode.put("objTo", euipId);
  161. });
  162. List<ObjectRelation> list = DigitalRelationFacade.create(AdmContextUtil.toDmpContext().getGroupCode(),AdmContextUtil.toDmpContext().getProjectId(), AdmContextUtil.toDmpContext().getAppId(), null, relations);
  163. return AdmResponse.success(list);
  164. }
  165. /**
  166. * 查询
  167. * @param request
  168. * @return
  169. * @throws Exception
  170. */
  171. @PostMapping("/query")
  172. public AdmResponse query(@RequestBody AdmQueryCriteria request) throws Exception {
  173. request.setName(AdmSystem.OBJ_TYPE);
  174. AdmResponse admResponse = service.doQuery(AdmContextUtil.toDmpContext(), request, AdmSystem.class);
  175. List<AdmSystem> systemList = (List<AdmSystem>) admResponse.getContent();
  176. if(CollUtil.isNotEmpty(systemList)){
  177. AdmDict admDict = new AdmDict();
  178. admDict.setType(AdmSystem.OBJ_TYPE);
  179. AdmResponse admResponseDic = dictService.queryCategory(AdmContextUtil.toDmpContext(), admDict, AdmObjectType.class);
  180. if(CollUtil.isNotEmpty(admResponseDic.getContent())){
  181. List<AdmObjectType> admDictList = (List<AdmObjectType>) admResponseDic.getContent();
  182. Map<String, AdmObjectType> admDictMap = CollUtil.fieldValueMap(admDictList, "code");
  183. systemList.stream().forEach(admSystem -> {
  184. if(admDictMap.keySet().contains(admSystem.getClassCode())){
  185. AdmObjectType admDictTemp = admDictMap.get(admSystem.getClassCode());
  186. admSystem.setCategoryName(admDictTemp.getName());
  187. }
  188. });
  189. admResponse.setContent(systemList);
  190. }
  191. }
  192. return admResponse;
  193. }
  194. /**
  195. * 查询系统信息-系统建筑楼层一对多
  196. * MajorName 专业名称 ,级联查询 系统分类名(categoryNames),系统下的设备(equipmentList),系统下的竖井(shaftList),业务空间(zoneSpaceBaseTableList)
  197. *
  198. * 明确建筑楼层的 adm级联 查询获取建筑楼层信息 使用正常接口 先查询楼层 再根据楼层信息拼接建筑
  199. * 未明确建筑/未明确楼层 中台定制接口
  200. *
  201. * 这个参见中心代码,
  202. * @param buildingId buildingId=1,未明确建筑
  203. * @param floorId floorId=1,未明确楼层
  204. * @param request
  205. * @return
  206. * @throws Exception
  207. */
  208. @PostMapping("/query-new")
  209. public AdmResponse queryNew(@QueryParam("buildingId") String buildingId,
  210. @QueryParam("floorId") String floorId, @RequestBody AdmQueryCriteria request) throws Exception {
  211. AdmResponse syses = new AdmResponse();
  212. List<AdmSystem> admSystemList = new ArrayList<>();
  213. if(StrUtil.isAllEmpty(buildingId,floorId)){
  214. //case one 查询全部系统,级联建筑,建筑级联楼层
  215. AdmQueryCriteria admQueryCriteriaBd = new AdmQueryCriteria();
  216. admQueryCriteriaBd.setName("buildingList");
  217. List<AdmQueryCriteria> cascadeBd = new ArrayList<>(1);
  218. AdmQueryCriteria admQueryCriteriaFl = new AdmQueryCriteria();
  219. admQueryCriteriaFl.setName("floor");
  220. cascadeBd.add(admQueryCriteriaFl);
  221. admQueryCriteriaBd.setCascade(cascadeBd);
  222. List<AdmQueryCriteria> cascade = new ArrayList<>(1);
  223. cascade.add(admQueryCriteriaBd);
  224. request.setCascade(cascade);
  225. syses = service.doQuery(AdmContextUtil.toDmpContext(),request,AdmSystem.class);
  226. //处理数据 BuildingFloorInfo
  227. if(CollUtil.isNotEmpty(syses.getContent())){
  228. admSystemList = (List<AdmSystem>) syses.getContent();
  229. admSystemList.stream().forEach(admSystem -> {
  230. List<ObjectNode> buildingFloorInfoList = new ArrayList<>();
  231. List<AdmBuilding> buildingList = admSystem.getBuildingList();
  232. if(CollUtil.isNotEmpty(buildingList)){
  233. buildingList.stream().forEach(admBuilding -> {
  234. List<AdmFloor> admFloorList = admBuilding.getFloor();
  235. if(CollUtil.isNotEmpty(admFloorList)){
  236. admFloorList.stream().forEach(floor -> {
  237. ObjectNode info = JsonNodeFactory.instance.objectNode();
  238. info.put("BuildID",admBuilding.getId());
  239. info.put("BuildName",admBuilding.getLocalName());
  240. info.put("FloorID",floor.getId());
  241. info.put("FloorName",floor.getLocalName());
  242. buildingFloorInfoList.add(info);
  243. });
  244. }else{
  245. ObjectNode info = JsonNodeFactory.instance.objectNode();
  246. info.put("BuildID",admBuilding.getId());
  247. info.put("BuildName",admBuilding.getLocalName());
  248. buildingFloorInfoList.add(info);
  249. }
  250. });
  251. admSystem.setBuildingFloorInfoList(buildingFloorInfoList);
  252. admSystem.setBuildingList(null);
  253. } else{
  254. admSystem.setBuildingFloorInfoList(buildingFloorInfoList);
  255. }
  256. });
  257. syses.setContent(CollUtil.isEmpty(admSystemList) ? new ArrayList<>(1) : admSystemList);
  258. }
  259. }else{
  260. QueryCriteria rwdQueryCriteria = AdmQueryCriteriaHelper.toDmpCriteria(request);
  261. ObjectNode criteria = rwdQueryCriteria.getCriteria();
  262. if(JSONUtil.isNull(criteria)){
  263. return AdmResponse.failure("请求参数错误");
  264. }
  265. criteria.put("objType", AdmSystem.OBJ_TYPE);
  266. if (StrUtil.isAllNotEmpty(buildingId, floorId)) {
  267. if(!"1".equals(floorId)){
  268. //case two 明确建筑、明确楼层的 系统
  269. JSONObject relationFrom = new JSONObject();
  270. relationFrom.put("relCode", "Sy2Fl");
  271. relationFrom.put("graphCode", "MechInArch");
  272. relationFrom.put("objTo", floorId);
  273. criteria.putPOJO("relationFrom",relationFrom);
  274. rwdQueryCriteria.setCriteria(criteria);
  275. syses = service.doQuery(AdmContextUtil.toDmpContext(), rwdQueryCriteria, AdmSystem.class);
  276. if (CollUtil.isNotEmpty(syses.getContent())) {
  277. admSystemList = (List<AdmSystem>) syses.getContent();
  278. }
  279. }else if("1".equals(floorId)){
  280. //case three 明确建筑 不明确楼层
  281. admSystemList = queryNotSureObj(buildingId, rwdQueryCriteria);
  282. //处理通用返回结果
  283. dealRespose(syses, request);
  284. }
  285. if(CollUtil.isNotEmpty(admSystemList)){
  286. //处理数据 BuildingFloorInfo
  287. admSystemList = dealBdFlInfo(floorId,buildingId,admSystemList);
  288. syses.setContent(admSystemList);
  289. }
  290. }else{
  291. //处理通用返回结果
  292. dealRespose(syses, request);
  293. if(StrUtil.isNotEmpty(buildingId) && buildingId.equals("1")){
  294. //case four 未明确建筑
  295. admSystemList = queryNotSureObj(null, rwdQueryCriteria);
  296. if(CollUtil.isNotEmpty(admSystemList)){
  297. //处理数据 BuildingFloorInfo
  298. admSystemList = dealBdFlInfo(null,null, admSystemList);
  299. }
  300. }
  301. }
  302. if(CollUtil.isNotEmpty(admSystemList))
  303. syses.setTotal(admSystemList.size()*1l);
  304. }
  305. if(CollUtil.isNotEmpty(admSystemList)){
  306. syses.setContent(admSystemList);
  307. }else{
  308. syses.setContent(new ArrayList<>(1));
  309. }
  310. return syses;
  311. }
  312. private void dealRespose(AdmResponse syses, AdmQueryCriteria request){
  313. syses.setPageSize(request.getPageSize());
  314. syses.setPageNumber(request.getPageNumber());
  315. syses.setResult(DmpResult.SUCCESS);
  316. syses.setTotal(0L);
  317. }
  318. /**
  319. * 查询不确定建筑/楼层的系统
  320. * @param buildingId
  321. * @param rwdQueryCriteria
  322. * @return
  323. */
  324. private List<AdmSystem> queryNotSureObj(String buildingId, QueryCriteria rwdQueryCriteria){
  325. RequestData requestData = new RequestData();
  326. String classCode = rwdQueryCriteria.getCriteria().get("classCode").textValue();
  327. if(StrUtil.isNotEmpty(classCode)){
  328. requestData.setClassCode(classCode);
  329. }
  330. if(StrUtil.isNotEmpty(buildingId)){
  331. requestData.setBuildingId(buildingId);
  332. }
  333. requestData.setObjType(AdmSystem.OBJ_TYPE);
  334. requestData.setPage(rwdQueryCriteria.getPage());
  335. requestData.setSize(rwdQueryCriteria.getSize());
  336. List result = DigitalObjectSimpleFacade.queryNotSureSystem(AdmContextUtil.toDmpContext().getGroupCode(), AdmContextUtil.toDmpContext().getProjectId(), AdmContextUtil.toDmpContext().getAppId(),null, requestData);
  337. if(CollUtil.isNotEmpty(result)){
  338. List<AdmSystem> admSystemList = JSONUtil.toList(result.toString(), AdmSystem.class);
  339. return admSystemList;
  340. }else{
  341. return null;
  342. }
  343. }
  344. /**
  345. * 处理建筑楼层信息 建筑确定,楼层可为空
  346. * @param floorId
  347. * @param buildingId
  348. * @param admSystemList
  349. * @return
  350. */
  351. private List<AdmSystem> dealBdFlInfo(String floorId, String buildingId, List<AdmSystem> admSystemList){
  352. if(CollUtil.isEmpty(admSystemList)){
  353. return null;
  354. }
  355. if(StrUtil.isEmpty(buildingId)){//处理成adm目标格式
  356. List<ObjectNode> nullList = new ArrayList<>(0);
  357. admSystemList.stream().forEach(admSystem -> {
  358. admSystem.setBuildingFloorInfoList(nullList);
  359. });
  360. return admSystemList;
  361. }
  362. AdmResponse buildings = null;
  363. if(StrUtil.isNotEmpty(buildingId)){
  364. AdmQueryCriteria admQueryCriteria = getAdmQueryCriteria(AdmBuilding.OBJ_TYPE, buildingId);
  365. buildings = buildingService.doQuery(AdmContextUtil.toDmpContext(), admQueryCriteria, AdmBuilding.class);
  366. }
  367. AdmResponse floors = null;
  368. if(StrUtil.isNotEmpty(floorId)){
  369. AdmQueryCriteria admQueryCriteria = getAdmQueryCriteria(AdmFloor.OBJ_TYPE, floorId);
  370. floors = floorService.doQuery(AdmContextUtil.toDmpContext(), admQueryCriteria, AdmFloor.class);
  371. }
  372. ObjectNode buildingFloorInfo = JsonNodeFactory.instance.objectNode();
  373. if (CollUtil.isNotEmpty(buildings.getContent())) {
  374. AdmBuilding admBuilding = (AdmBuilding) buildings.getContent().get(0);
  375. buildingFloorInfo.put("BuildID",admBuilding.getId());
  376. buildingFloorInfo.put("BuildName",admBuilding.getLocalName());
  377. }
  378. if (null!=floors && CollUtil.isNotEmpty(floors.getContent())) {
  379. AdmFloor floor = (AdmFloor) floors.getContent().get(0);
  380. buildingFloorInfo.put("FloorID",floor.getId());
  381. buildingFloorInfo.put("FloorName",floor.getLocalName());
  382. }
  383. admSystemList.stream().forEach(admSystem -> {
  384. admSystem.setBuildingFloorInfoList(Arrays.asList(buildingFloorInfo));
  385. });
  386. return admSystemList;
  387. }
  388. private AdmQueryCriteria getAdmQueryCriteria(String objType, String Id){
  389. AdmQueryCriteria admQueryCriteria = new AdmQueryCriteria();
  390. admQueryCriteria.setName(objType);
  391. admQueryCriteria.setFilters("id = " + Id);
  392. return admQueryCriteria;
  393. }
  394. /**
  395. * 查询系统信息-试图级联建筑楼层 暂未使用
  396. * @param request
  397. * @return
  398. * @throws Exception
  399. */
  400. @PostMapping("/query-bdfl")
  401. public AdmResponse queryUnBdFl(@RequestBody AdmQueryCriteria request) throws Exception {
  402. request.setName(AdmSystem.OBJ_TYPE);
  403. return service.doQuery(AdmContextUtil.toDmpContext(), request, AdmSystem.class);
  404. }
  405. /**
  406. * 查询没有和当前系统关联的设备
  407. * id 为系统id
  408. * @param request
  409. * @return
  410. * @throws Exception
  411. */
  412. @PostMapping("/un-sys-equip")
  413. public AdmResponse queryUnEquip( @NotNull @QueryParam("sysId") String sysId,
  414. @RequestBody AdmQueryCriteria request) throws Exception {
  415. AdmResponse admResponse = queryObjectByType(sysId,request,"Sy2Eq","MechSubset", AdmEquipment.OBJ_TYPE);
  416. return admResponse;
  417. }
  418. /**
  419. * 查询没有和当前系统关联的竖井
  420. * id 为系统id
  421. * @param request
  422. * @return
  423. * @throws Exception
  424. */
  425. @PostMapping("/un-sys-shaft")
  426. public AdmResponse queryUnSh( @NotNull @QueryParam("sysId") String sysId,
  427. @RequestBody AdmQueryCriteria request) throws Exception {
  428. AdmResponse admResponse = queryObjectByType(sysId,request,"Sy2Sh",null, AdmShaft.OBJ_TYPE);
  429. return admResponse;
  430. }
  431. /**
  432. * 查询没有和当前系统关联的业务空间
  433. * id 为系统id
  434. * @param request
  435. * @return
  436. * @throws Exception
  437. */
  438. @PostMapping("/un-sys-zoneSpaceBaseTable")
  439. public AdmResponse queryUnZoneSp(@NotNull @QueryParam("sysId") String sysId,
  440. @RequestBody AdmQueryCriteria request) throws Exception {
  441. AdmResponse admResponse = queryObjectByType(sysId,request,"Sy2Sp",null, AdmSpace.OBJ_TYPE);
  442. return admResponse;
  443. }
  444. /**
  445. * 查询没有和当前空间绑定的系统
  446. * 例如:prijectId=Pj4201050001,type=AirConditioningZone spaceId=Sp4201050001df2091cdf719443b80bb737aeabf0525 spaceId 为当前空间id type为当前空间类型
  447. * @param request
  448. * @return
  449. * @throws Exception
  450. */
  451. @PostMapping("/unspace-sys")
  452. public AdmResponse queryUnSpSy( @QueryParam("type") String type, @QueryParam("spaceId") String spaceId,
  453. @RequestBody AdmQueryCriteria request) throws Exception {
  454. if(StrUtil.isNotEmpty(spaceId)){
  455. AdmResponse admResponse = queryObjectByType(spaceId, request,"Sy2Sp",null, AdmSystem.OBJ_TYPE);
  456. return admResponse;
  457. }else{
  458. if(StrUtil.isNotEmpty(type)){
  459. QueryCriteria queryCriteriaObj = AdmQueryCriteriaHelper.toDmpCriteria(request);
  460. ObjectNode criteriaObj = JsonNodeFactory.instance.objectNode();
  461. criteriaObj.put("objType", AdmSpace.OBJ_TYPE);
  462. queryCriteriaObj.setCriteria(criteriaObj);
  463. List<ObjectNode> objs = DigitalObjectFacade.query(AdmContextUtil.toDmpContext().getGroupCode(),AdmContextUtil.toDmpContext().getProjectId(), AdmContextUtil.toDmpContext().getAppId(), null, queryCriteriaObj);
  464. QueryCriteria queryCriteriaObjSys = AdmQueryCriteriaHelper.toDmpCriteria(request);
  465. ObjectNode criteriaSys = JsonNodeFactory.instance.objectNode();
  466. criteriaObj.put("objType", AdmSystem.OBJ_TYPE);
  467. if(CollUtil.isNotEmpty(objs)){
  468. ArrayNode arrayNode = criteriaObj.putObject("id").putArray("$notcontains");
  469. for(ObjectNode objectNode: objs){
  470. arrayNode.add(objectNode.get("id").toString());
  471. }
  472. }
  473. queryCriteriaObj.setCriteria(criteriaObj);
  474. List<ObjectNode> syses = DigitalObjectFacade.query(AdmContextUtil.toDmpContext().getGroupCode(),AdmContextUtil.toDmpContext().getProjectId(), AdmContextUtil.toDmpContext().getAppId(), null, queryCriteriaObjSys);
  475. return AdmResponse.success(syses);
  476. }
  477. return AdmResponse.success();
  478. }
  479. }
  480. private AdmResponse queryObjectByType(String sysId, AdmQueryCriteria request, String relCode, String graphCode, String objType){
  481. QueryCriteria queryCriteria = new QueryCriteria();
  482. ObjectNode criteria = JsonNodeFactory.instance.objectNode();
  483. criteria.put("objFrom", sysId);
  484. criteria.put("relCode", relCode);
  485. if(StrUtil.isNotEmpty(graphCode)){
  486. criteria.put("graphCode", graphCode);
  487. }
  488. queryCriteria.setCriteria(criteria);
  489. queryCriteria.setSize(request.getPageSize()*1L);
  490. queryCriteria.setPage(request.getPageNumber()*1L);
  491. List<ObjectRelation> relations = DigitalRelationFacade.query(AdmContextUtil.toDmpContext().getGroupCode(),AdmContextUtil.toDmpContext().getProjectId(), AdmContextUtil.toDmpContext().getAppId(), null, queryCriteria);
  492. QueryCriteria queryCriteriaObj = AdmQueryCriteriaHelper.toDmpCriteria(request);
  493. ObjectNode criteriaObj = JsonNodeFactory.instance.objectNode();
  494. criteriaObj.put("objType", objType);
  495. if(CollUtil.isNotEmpty(relations)){
  496. Map<String, ObjectRelation> objectRelationMap = CollUtil.fieldValueMap(relations,BaseEntity.PROP_ID);
  497. ArrayNode arrayNode = criteriaObj.putObject("id").putArray("$notcontains");
  498. objectRelationMap.keySet().stream().forEach(id -> arrayNode.add(id));
  499. }
  500. queryCriteriaObj.setCriteria(criteriaObj);
  501. List<ObjectNode> obj = DigitalObjectFacade.query(AdmContextUtil.toDmpContext().getGroupCode(),AdmContextUtil.toDmpContext().getProjectId(), AdmContextUtil.toDmpContext().getAppId(), null, queryCriteriaObj);
  502. return AdmResponse.success(obj);
  503. }
  504. }