Skip to content

Commit

Permalink
Improve code readability using Stream
Browse files Browse the repository at this point in the history
Signed-off-by: David Osorno <[email protected]>
  • Loading branch information
davidosorno committed Mar 13, 2024
1 parent 46c296f commit 0f1792b
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 22 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,13 @@
package org.opensearch.security.dlic.rest.api;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import java.util.Set;
import java.util.stream.Collectors;
import java.util.stream.IntStream;

import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
Expand Down Expand Up @@ -216,28 +216,19 @@ private void updateAndValidatesValues(final ConfigV7 config, final JsonNode json
}

private List<DashboardSignInOption> getNewSignInOptions(JsonNode newOptions, Authc authc) {
List<DashboardSignInOption> options = new ArrayList<>();
for (int i = 0; i < newOptions.size(); i++) {
try {
String option = newOptions.get(i).asText();
if (isOptionConfiguredAtBackEnd(authc, option)) {
options.add(DashboardSignInOption.valueOf(option));
}
} catch (Exception e) {
throw new IllegalArgumentException("Invalid sign-in option: " + e.getMessage());
}
}
return options;
}

private boolean isOptionConfiguredAtBackEnd(Authc authc, String option) {
for (String key : authc.getDomains().keySet()) {
if (key.contains(option.toLowerCase())) {
Set<String> domains = authc.getDomains().keySet();

return IntStream.range(0, newOptions.size()).mapToObj(newOptions::get).map(JsonNode::asText).filter(option -> {
// Checking if the new sign-in options are set in backend.
if (option.equals(DashboardSignInOption.ANONYMOUS.toString())
|| domains.stream().anyMatch(domain -> domain.contains(option.toLowerCase()))) {
return true;
} else {
throw new IllegalArgumentException(
"Validation failure: " + option.toUpperCase() + " authentication provider is not available for this cluster."
);
}
}
throw new IllegalArgumentException(
"Validation failure: " + option.toUpperCase() + " authentication provider is not available for this cluster."
);
}).map(DashboardSignInOption::valueOf).collect(Collectors.toList());
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -207,7 +207,7 @@ private void verifyTenantUpdateFailed(final Header... header) throws Exception {
assertThat(
invalidSignInOption.getBody(),
invalidSignInOption.findValueInJson("error.reason"),
containsString("Invalid sign-in option")
containsString("authentication provider is not available for this cluster")
);
}

Expand Down

0 comments on commit 0f1792b

Please sign in to comment.