Skip to content

Commit

Permalink
Extract route paths prefixes into constants (opensearch-project#4173)
Browse files Browse the repository at this point in the history
Signed-off-by: Andrey Pleskach <[email protected]>
  • Loading branch information
willyborankin authored Mar 27, 2024
1 parent 864d8be commit aa56d26
Show file tree
Hide file tree
Showing 7 changed files with 46 additions and 20 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -137,7 +137,9 @@ private AuthTokenProcessorAction.Response handleImpl(
String samlResponseBase64,
String samlRequestId,
String acsEndpoint,
Saml2Settings saml2Settings
Saml2Settings saml2Settings,
String requestPath // the parameter will be removed in the future as soon as we will read of legacy paths aka
// /_opendistro/_security/...
) {
if (token_log.isDebugEnabled()) {
try {
Expand All @@ -156,7 +158,7 @@ private AuthTokenProcessorAction.Response handleImpl(
final SamlResponse samlResponse = new SamlResponse(saml2Settings, acsEndpoint, samlResponseBase64);

if (!samlResponse.isValid(samlRequestId)) {
log.warn("Error while validating SAML response in /_opendistro/_security/api/authtoken");
log.warn("Error while validating SAML response in {}", requestPath);
return null;
}

Expand All @@ -178,17 +180,14 @@ private Optional<SecurityResponse> handleLowLevel(RestRequest restRequest) throw

if (restRequest.getMediaType() != XContentType.JSON) {
throw new OpenSearchSecurityException(
"/_opendistro/_security/api/authtoken expects content with type application/json",
restRequest.path() + " expects content with type application/json",
RestStatus.UNSUPPORTED_MEDIA_TYPE
);

}

if (restRequest.method() != Method.POST) {
throw new OpenSearchSecurityException(
"/_opendistro/_security/api/authtoken expects POST requests",
RestStatus.METHOD_NOT_ALLOWED
);
throw new OpenSearchSecurityException(restRequest.path() + " expects POST requests", RestStatus.METHOD_NOT_ALLOWED);
}

Saml2Settings saml2Settings = this.saml2SettingsProvider.getCached();
Expand Down Expand Up @@ -218,7 +217,13 @@ private Optional<SecurityResponse> handleLowLevel(RestRequest restRequest) throw
acsEndpoint = getAbsoluteAcsEndpoint(((ObjectNode) jsonRoot).get("acsEndpoint").textValue());
}

AuthTokenProcessorAction.Response responseBody = this.handleImpl(samlResponseBase64, samlRequestId, acsEndpoint, saml2Settings);
AuthTokenProcessorAction.Response responseBody = this.handleImpl(
samlResponseBase64,
samlRequestId,
acsEndpoint,
saml2Settings,
restRequest.path()
);

if (responseBody == null) {
return Optional.empty();
Expand All @@ -228,7 +233,7 @@ private Optional<SecurityResponse> handleLowLevel(RestRequest restRequest) throw

return Optional.of(new SecurityResponse(HttpStatus.SC_OK, null, responseBodyString, XContentType.JSON.mediaType()));
} catch (JsonProcessingException e) {
log.warn("Error while parsing JSON for /_opendistro/_security/api/authtoken", e);
log.warn("Error while parsing JSON for {}", restRequest.path(), e);
return Optional.of(new SecurityResponse(HttpStatus.SC_BAD_REQUEST, "JSON could not be parsed"));
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,13 +32,14 @@
import org.opensearch.security.identity.SecurityTokenManager;

import static org.opensearch.rest.RestRequest.Method.POST;
import static org.opensearch.security.dlic.rest.support.Utils.PLUGIN_API_ROUTE_PREFIX;
import static org.opensearch.security.dlic.rest.support.Utils.addRoutesPrefix;

public class CreateOnBehalfOfTokenAction extends BaseRestHandler {

private static final List<Route> routes = addRoutesPrefix(
ImmutableList.of(new NamedRoute.Builder().method(POST).path("/generateonbehalfoftoken").uniqueName("security:obo/create").build()),
"/_plugins/_security/api"
PLUGIN_API_ROUTE_PREFIX
);

public static final long OBO_DEFAULT_EXPIRY_SECONDS = 5 * 60;
Expand Down
14 changes: 12 additions & 2 deletions src/main/java/org/opensearch/security/dlic/rest/support/Utils.java
Original file line number Diff line number Diff line change
Expand Up @@ -55,9 +55,19 @@
import org.opensearch.security.user.User;

import static org.opensearch.core.xcontent.DeprecationHandler.THROW_UNSUPPORTED_OPERATION;
import static org.opensearch.security.OpenSearchSecurityPlugin.LEGACY_OPENDISTRO_PREFIX;
import static org.opensearch.security.OpenSearchSecurityPlugin.PLUGINS_PREFIX;

public class Utils {

public final static String PLUGIN_ROUTE_PREFIX = "/" + PLUGINS_PREFIX;

public final static String LEGACY_PLUGIN_ROUTE_PREFIX = "/" + LEGACY_OPENDISTRO_PREFIX;

public final static String PLUGIN_API_ROUTE_PREFIX = PLUGIN_ROUTE_PREFIX + "/api";

public final static String LEGACY_PLUGIN_API_ROUTE_PREFIX = LEGACY_PLUGIN_ROUTE_PREFIX + "/api";

private static final ObjectMapper internalMapper = new ObjectMapper();

public static Map<String, Object> convertJsonToxToStructuredMap(ToXContent jsonContent) {
Expand Down Expand Up @@ -217,7 +227,7 @@ public static Set<String> generateFieldResourcePaths(final Set<String> fields, f
*Total number of routes is expanded as twice as the number of routes passed in
*/
public static List<Route> addRoutesPrefix(List<Route> routes) {
return addRoutesPrefix(routes, "/_opendistro/_security/api", "/_plugins/_security/api");
return addRoutesPrefix(routes, LEGACY_PLUGIN_API_ROUTE_PREFIX, PLUGIN_API_ROUTE_PREFIX);
}

/**
Expand Down Expand Up @@ -248,7 +258,7 @@ public static List<Route> addRoutesPrefix(List<Route> routes, final String... pr
*Total number of routes is expanded as twice as the number of routes passed in
*/
public static List<DeprecatedRoute> addDeprecatedRoutesPrefix(List<DeprecatedRoute> deprecatedRoutes) {
return addDeprecatedRoutesPrefix(deprecatedRoutes, "/_opendistro/_security/api", "/_plugins/_security/api");
return addDeprecatedRoutesPrefix(deprecatedRoutes, LEGACY_PLUGIN_API_ROUTE_PREFIX, PLUGIN_API_ROUTE_PREFIX);
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,15 +50,19 @@

import static org.opensearch.rest.RestRequest.Method.GET;
import static org.opensearch.rest.RestRequest.Method.POST;
import static org.opensearch.security.dlic.rest.support.Utils.LEGACY_PLUGIN_ROUTE_PREFIX;
import static org.opensearch.security.dlic.rest.support.Utils.PLUGIN_ROUTE_PREFIX;
import static org.opensearch.security.dlic.rest.support.Utils.addRoutesPrefix;

public class DashboardsInfoAction extends BaseRestHandler {

private static final List<Route> routes = ImmutableList.<Route>builder()
.addAll(
addRoutesPrefix(ImmutableList.of(new Route(GET, "/dashboardsinfo"), new Route(POST, "/dashboardsinfo")), "/_plugins/_security")
addRoutesPrefix(ImmutableList.of(new Route(GET, "/dashboardsinfo"), new Route(POST, "/dashboardsinfo")), PLUGIN_ROUTE_PREFIX)
)
.addAll(
addRoutesPrefix(ImmutableList.of(new Route(GET, "/kibanainfo"), new Route(POST, "/kibanainfo")), LEGACY_PLUGIN_ROUTE_PREFIX)
)
.addAll(addRoutesPrefix(ImmutableList.of(new Route(GET, "/kibanainfo"), new Route(POST, "/kibanainfo")), "/_opendistro/_security"))
.build();

private final Logger log = LogManager.getLogger(this.getClass());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -44,13 +44,15 @@

import static org.opensearch.rest.RestRequest.Method.GET;
import static org.opensearch.rest.RestRequest.Method.POST;
import static org.opensearch.security.dlic.rest.support.Utils.LEGACY_PLUGIN_ROUTE_PREFIX;
import static org.opensearch.security.dlic.rest.support.Utils.PLUGIN_ROUTE_PREFIX;
import static org.opensearch.security.dlic.rest.support.Utils.addRoutesPrefix;

public class SecurityHealthAction extends BaseRestHandler {
private static final List<Route> routes = addRoutesPrefix(
ImmutableList.of(new Route(GET, "/health"), new Route(POST, "/health")),
"/_opendistro/_security",
"/_plugins/_security"
LEGACY_PLUGIN_ROUTE_PREFIX,
PLUGIN_ROUTE_PREFIX
);

private final BackendRegistry registry;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -57,13 +57,15 @@

import static org.opensearch.rest.RestRequest.Method.GET;
import static org.opensearch.rest.RestRequest.Method.POST;
import static org.opensearch.security.dlic.rest.support.Utils.LEGACY_PLUGIN_ROUTE_PREFIX;
import static org.opensearch.security.dlic.rest.support.Utils.PLUGIN_ROUTE_PREFIX;
import static org.opensearch.security.dlic.rest.support.Utils.addRoutesPrefix;

public class SecurityInfoAction extends BaseRestHandler {
private static final List<Route> routes = addRoutesPrefix(
ImmutableList.of(new Route(GET, "/authinfo"), new Route(POST, "/authinfo")),
"/_opendistro/_security",
"/_plugins/_security"
LEGACY_PLUGIN_ROUTE_PREFIX,
PLUGIN_ROUTE_PREFIX
);

private final Logger log = LogManager.getLogger(this.getClass());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -61,13 +61,15 @@

import static org.opensearch.rest.RestRequest.Method.GET;
import static org.opensearch.rest.RestRequest.Method.POST;
import static org.opensearch.security.dlic.rest.support.Utils.LEGACY_PLUGIN_ROUTE_PREFIX;
import static org.opensearch.security.dlic.rest.support.Utils.PLUGIN_ROUTE_PREFIX;
import static org.opensearch.security.dlic.rest.support.Utils.addRoutesPrefix;

public class TenantInfoAction extends BaseRestHandler {
private static final List<Route> routes = addRoutesPrefix(
ImmutableList.of(new Route(GET, "/tenantinfo"), new Route(POST, "/tenantinfo")),
"/_opendistro/_security",
"/_plugins/_security"
LEGACY_PLUGIN_ROUTE_PREFIX,
PLUGIN_ROUTE_PREFIX
);

private final Logger log = LogManager.getLogger(this.getClass());
Expand Down

0 comments on commit aa56d26

Please sign in to comment.