diff --git a/repository/src/main/java/org/apache/atlas/repository/store/graph/v2/EntityGraphRetriever.java b/repository/src/main/java/org/apache/atlas/repository/store/graph/v2/EntityGraphRetriever.java index 2da180cf62..a4482c88cb 100644 --- a/repository/src/main/java/org/apache/atlas/repository/store/graph/v2/EntityGraphRetriever.java +++ b/repository/src/main/java/org/apache/atlas/repository/store/graph/v2/EntityGraphRetriever.java @@ -1014,7 +1014,7 @@ private Map preloadProperties(AtlasVertex entityVertex, AtlasEnt Iterator> traversal = ((AtlasJanusVertex)entityVertex).getWrappedElement().properties(); // retrieve all the valid relationships for this entityType - Map relationshipsLookup = fetchEdgeNames(entityType); + Map> relationshipsLookup = fetchEdgeNames(entityType); // Fetch edges in both directions retrieveEdgeLabels(entityVertex, AtlasEdgeDirection.BOTH, attributes, relationshipsLookup, propertiesMap); @@ -1052,12 +1052,13 @@ private Map preloadProperties(AtlasVertex entityVertex, AtlasEnt return propertiesMap; } - private Map fetchEdgeNames(AtlasEntityType entityType){ + private Map> fetchEdgeNames(AtlasEntityType entityType){ Map> relationships = entityType.getRelationshipAttributes(); - Map edgeNames = new HashMap<>(); + Map> edgeNames = new HashMap<>(); relationships.forEach((k,v) -> { v.forEach((k1,v1) -> { - edgeNames.put(k1, k); + edgeNames.putIfAbsent(k1, new HashSet<>()); + edgeNames.get(k1).add(k); }); }); @@ -1065,7 +1066,7 @@ private Map fetchEdgeNames(AtlasEntityType entityType){ return edgeNames; } - private void retrieveEdgeLabels(AtlasVertex entityVertex, AtlasEdgeDirection edgeDirection, Set attributes, Map relationshipsLookup,Map propertiesMap) throws AtlasBaseException { + private void retrieveEdgeLabels(AtlasVertex entityVertex, AtlasEdgeDirection edgeDirection, Set attributes, Map> relationshipsLookup,Map propertiesMap) throws AtlasBaseException { Iterator edges = GraphHelper.getOnlyActiveEdges(entityVertex, edgeDirection); List edgeLabelsDebug = new ArrayList<>(); @@ -1091,7 +1092,7 @@ private void retrieveEdgeLabels(AtlasVertex entityVertex, AtlasEdgeDirection edg String edgeTypeName = edgesTypeName.get(edgeLabel); LOG.warn("edgeTypeName for attribute: {} :{}", edgeTypeName, relationshipsLookup.containsKey(edgeTypeName)); - if (MapUtils.isNotEmpty(relationshipsLookup) && relationshipsLookup.containsKey(edgeTypeName) && attribute.equals(relationshipsLookup.get(edgeTypeName))) { + if (MapUtils.isNotEmpty(relationshipsLookup) && relationshipsLookup.containsKey(edgeTypeName) && relationshipsLookup.get(edgeTypeName).contains(attribute)) { edgeLabels.add(attribute); LOG.warn("attribute matched by edgeTypeName"); }