From f7d8cb9ef07bf97ec502a78f1f8f1e98f43466b3 Mon Sep 17 00:00:00 2001 From: Jonathan Hui Date: Tue, 12 Nov 2024 16:51:06 -0800 Subject: [PATCH] Add no-internalModels-flag variants to methods used by GMS's --- .../metadata/restli/BaseEntityResource.java | 33 +++++++++++++++++++ .../restli/BaseSearchableEntityResource.java | 12 +++++++ 2 files changed, 45 insertions(+) diff --git a/restli-resources/src/main/java/com/linkedin/metadata/restli/BaseEntityResource.java b/restli-resources/src/main/java/com/linkedin/metadata/restli/BaseEntityResource.java index 8d29c98d8..3f8a6785c 100644 --- a/restli-resources/src/main/java/com/linkedin/metadata/restli/BaseEntityResource.java +++ b/restli-resources/src/main/java/com/linkedin/metadata/restli/BaseEntityResource.java @@ -1075,6 +1075,24 @@ protected Map getInternal(@Nonnull Collection urns, : toValue(newSnapshot(e.getKey(), e.getValue())))); } + /** + * Same as the above but doesn't require the callee to provide the 'isInternalModelsEnabled' flag. + * + * @param urns collection of urns + * @param aspectClasses set of aspect classes + * @return All {@link VALUE} objects keyed by {@link URN} obtained from DB + */ + @Nonnull + protected Map getInternal(@Nonnull Collection urns, + @Nonnull Set> aspectClasses) { + final boolean isInternalModelsEnabled = getResourceLix().testGetAll(_urnClass.getSimpleName()); + return getUrnAspectMap(urns, aspectClasses, isInternalModelsEnabled).entrySet() + .stream() + .collect(Collectors.toMap(Map.Entry::getKey, + e -> isInternalModelsEnabled ? toInternalValue(newInternalSnapshot(e.getKey(), e.getValue())) + : toValue(newSnapshot(e.getKey(), e.getValue())))); + } + /** * Similar to {@link #getInternal(Collection, Set, boolean)} but filter out {@link URN}s which are not in the DB. */ @@ -1089,6 +1107,21 @@ protected Map getInternalNonEmpty(@Nonnull Collection urns, : toValue(newSnapshot(e.getKey(), e.getValue())))); } + /** + * Same as the above but doesn't require the callee to provide the 'isInternalModelsEnabled' flag. + */ + @Nonnull + protected Map getInternalNonEmpty(@Nonnull Collection urns, + @Nonnull Set> aspectClasses) { + final boolean isInternalModelsEnabled = getResourceLix().testGetAll(_urnClass.getSimpleName()); + return getUrnAspectMap(urns, aspectClasses, isInternalModelsEnabled).entrySet() + .stream() + .filter(e -> !e.getValue().isEmpty()) + .collect(Collectors.toMap(Map.Entry::getKey, + e -> isInternalModelsEnabled ? toInternalValue(newInternalSnapshot(e.getKey(), e.getValue())) + : toValue(newSnapshot(e.getKey(), e.getValue())))); + } + @Nonnull private Map> getUrnAspectMap(@Nonnull Collection urns, @Nonnull Set> aspectClasses, boolean isInternalModelsEnabled) { diff --git a/restli-resources/src/main/java/com/linkedin/metadata/restli/BaseSearchableEntityResource.java b/restli-resources/src/main/java/com/linkedin/metadata/restli/BaseSearchableEntityResource.java index 5bbcd16a3..5bf46e2e1 100644 --- a/restli-resources/src/main/java/com/linkedin/metadata/restli/BaseSearchableEntityResource.java +++ b/restli-resources/src/main/java/com/linkedin/metadata/restli/BaseSearchableEntityResource.java @@ -225,6 +225,18 @@ public CollectionResult getSearchQueryCollectionRes ); } + /** + * Same as the above but doesn't require the callee to provide the 'isInternalModelsEnabled' flag. + * @param searchResult Search result returned from search infra, such as Elasticsearch. + * @param aspectNames List of aspect names that need to be returned. + * @return CollectionResult which contains: 1. aspect values fetched from MySQL DB, 2. Total count 3. Search result metadata. + */ + @Nonnull + public CollectionResult getSearchQueryCollectionResult(@Nonnull SearchResult searchResult, + @Nullable String[] aspectNames) { + return getSearchQueryCollectionResult(searchResult, aspectNames, getResourceLix().testSearch(_urnClass.getSimpleName())); + } + private URN toEntitySpecificUrn(Urn urn) { try { return (URN) (_urnClass.getMethod("createFromUrn", Urn.class).invoke(null, urn));