Skip to content

Commit

Permalink
Merge pull request #2926 from atlanhq/exclude-classification-names
Browse files Browse the repository at this point in the history
feat: add feature to fetch classification names only instead of both classification objects and classificationNames
  • Loading branch information
sumandas0 authored Apr 9, 2024
2 parents ef84908 + bc9269e commit 2930528
Show file tree
Hide file tree
Showing 5 changed files with 40 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ public class SearchParams {
boolean excludeMeanings;
boolean excludeClassifications;

boolean includeClassificationNames = false;

RequestMetadata requestMetadata = new RequestMetadata();

Async async = new Async();
Expand Down Expand Up @@ -100,6 +102,14 @@ public void setExcludeMeanings(boolean excludeMeanings) {
this.excludeMeanings = excludeMeanings;
}

public boolean isIncludeClassificationNames() {
return includeClassificationNames;
}

public void setIncludeClassificationNames(boolean includeClassificationNames) {
this.includeClassificationNames = includeClassificationNames;
}

public boolean isSaveSearchLog() {
return requestMetadata.saveSearchLog;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -785,7 +785,18 @@ public static List<String> getTraitNames(AtlasVertex entityVertex) {
public static List<String> getPropagatedTraitNames(AtlasVertex entityVertex) {
return getTraitNames(entityVertex, true);
}

public static List<String> getAllTraitNamesFromAttribute(AtlasVertex entityVertex) {
List<String> ret = new ArrayList<>();
List<String> traitNames = entityVertex.getMultiValuedProperty(TRAIT_NAMES_PROPERTY_KEY, String.class);
if (traitNames != null) {
ret.addAll(traitNames);
}
List<String> propagatedTraitNames = entityVertex.getMultiValuedProperty(PROPAGATED_TRAIT_NAMES_PROPERTY_KEY, String.class);
if (propagatedTraitNames != null) {
ret.addAll(propagatedTraitNames);
}
return ret;
}
public static List<String> getAllTraitNames(AtlasVertex entityVertex) {
return getTraitNames(entityVertex, null);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1019,8 +1019,13 @@ private AtlasEntityHeader mapVertexToAtlasEntityHeader(AtlasVertex entityVertex,
ret.setTypeName(typeName);
ret.setGuid(guid);
ret.setStatus(GraphHelper.getStatus(entityVertex));
if(RequestContext.get().includeClassifications()){
ret.setClassificationNames(getAllTraitNames(entityVertex));
RequestContext context = RequestContext.get();
boolean includeClassifications = context.includeClassifications();
boolean includeClassificationNames = context.isIncludeClassificationNames();
if(includeClassifications){
ret.setClassificationNames(getAllTraitNamesFromAttribute(entityVertex));
} else if (!includeClassifications && includeClassificationNames) {
ret.setClassificationNames(getAllTraitNamesFromAttribute(entityVertex));
}
ret.setIsIncomplete(isIncomplete);
ret.setLabels(getLabels(entityVertex));
Expand Down
10 changes: 10 additions & 0 deletions server-api/src/main/java/org/apache/atlas/RequestContext.java
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,8 @@ public class RequestContext {
private boolean allowDeletedRelationsIndexsearch = false;
private boolean includeMeanings = true;
private boolean includeClassifications = true;

private boolean includeClassificationNames = false;
private String currentTypePatchAction = "";
private AtlasTask currentTask;
private String traceId;
Expand Down Expand Up @@ -719,6 +721,14 @@ public boolean isCacheEnabled() {
return this.cacheEnabled;
}

public boolean isIncludeClassificationNames() {
return includeClassificationNames;
}

public void setIncludeClassificationNames(boolean includeClassificationNames) {
this.includeClassificationNames = includeClassificationNames;
}

public class EntityGuidPair {
private final Object entity;
private final String guid;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -393,6 +393,7 @@ public AtlasSearchResult indexSearch(@Context HttpServletRequest servletRequest,

RequestContext.get().setIncludeMeanings(!parameters.isExcludeMeanings());
RequestContext.get().setIncludeClassifications(!parameters.isExcludeClassifications());
RequestContext.get().setIncludeClassificationNames(parameters.isIncludeClassificationNames());
try {
if (AtlasPerfTracer.isPerfTraceEnabled(PERF_LOG)) {
perf = AtlasPerfTracer.getPerfTracer(PERF_LOG, "DiscoveryREST.indexSearch(" + parameters + ")");
Expand Down

0 comments on commit 2930528

Please sign in to comment.