Skip to content

Commit

Permalink
Merge pull request #3379 from atlanhq/LIN-1022
Browse files Browse the repository at this point in the history
LIN-1022 : [add] add relationship attributes search in lineage list API
  • Loading branch information
akshaysw authored Aug 7, 2024
2 parents bd1056d + fcafe07 commit d350671
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -22,18 +22,20 @@ public class LineageListRequest {
private SearchParameters.FilterCriteria entityTraversalFilters;
private SearchParameters.FilterCriteria relationshipTraversalFilters;
private Set<String> attributes;
private Set<String> relationAttributes;
private Boolean excludeMeanings;
private Boolean excludeClassifications;

public enum LineageDirection {INPUT, OUTPUT}

public LineageListRequest() {
this.attributes = new HashSet<>();
this.relationAttributes = new HashSet<>();
}

public LineageListRequest(String guid, Integer size, Integer from, Integer depth, LineageDirection direction, SearchParameters.FilterCriteria entityFilters,
SearchParameters.FilterCriteria entityTraversalFilters, SearchParameters.FilterCriteria relationshipTraversalFilters,
Set<String> attributes, boolean excludeMeanings, boolean excludeClassifications) {
Set<String> attributes, boolean excludeMeanings, boolean excludeClassifications, Set<String> relationAttributes) {
this.guid = guid;
this.size = size;
this.from = from;
Expand All @@ -45,6 +47,7 @@ public LineageListRequest(String guid, Integer size, Integer from, Integer depth
this.attributes = attributes;
this.excludeMeanings = excludeMeanings;
this.excludeClassifications = excludeClassifications;
this.relationAttributes = relationAttributes;
}

public String getGuid() {
Expand Down Expand Up @@ -119,6 +122,14 @@ public void setAttributes(Set<String> attributes) {
this.attributes = attributes;
}

public Set<String> getRelationAttributes() {
return relationAttributes;
}

public void setRelationAttributes(Set<String> relationAttributes) {
this.relationAttributes = relationAttributes;
}

public Boolean isExcludeMeanings() {
return excludeMeanings;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ public final class AtlasLineageListContext {
private Predicate vertexTraversalPredicate;
private Predicate edgeTraversalPredicate;
private Set<String> attributes;
private Set<String> relationAttributes;
private int currentFromCounter;
private int currentEntityCounter;
private boolean depthLimitReached;
Expand All @@ -33,6 +34,7 @@ public AtlasLineageListContext(LineageListRequest lineageListRequest, AtlasTypeR
this.vertexTraversalPredicate = constructInMemoryPredicate(typeRegistry, lineageListRequest.getEntityTraversalFilters());
this.edgeTraversalPredicate = constructInMemoryPredicate(typeRegistry, lineageListRequest.getRelationshipTraversalFilters());
this.attributes = lineageListRequest.getAttributes();
this.relationAttributes = lineageListRequest.getRelationAttributes();
}

public String getGuid() {
Expand Down Expand Up @@ -111,6 +113,14 @@ public void setAttributes(Set<String> attributes) {
this.attributes = attributes;
}

public Set<String> getRelationAttributes() {
return relationAttributes;
}

public void setRelationAttributes(Set<String> relationAttributes) {
this.relationAttributes = relationAttributes;
}

public int getCurrentFromCounter() {
return currentFromCounter;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -193,6 +193,8 @@ public AtlasLineageListInfo getLineageListInfoOnDemand(String guid, LineageListR
AtlasPerfMetrics.MetricRecorder metricRecorder = RequestContext.get().startMetricRecord("getLineageListInfoOnDemand");

AtlasLineageListInfo ret = new AtlasLineageListInfo(new ArrayList<>());
RequestContext.get().setRelationAttrsForSearch(lineageListRequest.getRelationAttributes());

traverseEdgesUsingBFS(guid, new AtlasLineageListContext(lineageListRequest, atlasTypeRegistry), ret);
ret.setSearchParameters(lineageListRequest);

Expand Down

0 comments on commit d350671

Please sign in to comment.