Skip to content

Commit

Permalink
Clarify SECURITY-3315 error code on client side
Browse files Browse the repository at this point in the history
  • Loading branch information
jglick committed Oct 31, 2024
1 parent 3a25593 commit f9e830e
Showing 1 changed file with 17 additions and 3 deletions.
20 changes: 17 additions & 3 deletions core/src/main/java/hudson/cli/CLIAction.java
Original file line number Diff line number Diff line change
Expand Up @@ -118,12 +118,26 @@ public boolean isWebSocketSupported() {
return WebSockets.isSupported();
}

/**
* Unlike {@link HttpResponses#errorWithoutStack} this sends the message in a header rather than the body.
* (Currently the WebSocket CLI is unable to process the body in an error message.)
*/
private static HttpResponse statusWithExplanation(int code, String errorMessage) {
return new HttpResponse() {
@Override
public void generateResponse(StaplerRequest2 req, StaplerResponse2 rsp, Object node) {
rsp.setStatus(code);
rsp.setHeader("X-CLI-Error", errorMessage);
}
};
}

/**
* WebSocket endpoint.
*/
public HttpResponse doWs(StaplerRequest2 req) {
if (!WebSockets.isSupported()) {
return HttpResponses.notFound();
return statusWithExplanation(HttpServletResponse.SC_NOT_FOUND, "WebSocket is not supported in this servlet container (try the built-in Jetty instead)");
}
if (ALLOW_WEBSOCKET == null) {
final String actualOrigin = req.getHeader("Origin");
Expand All @@ -141,10 +155,10 @@ public HttpResponse doWs(StaplerRequest2 req) {

if (actualOrigin == null || !actualOrigin.equals(expectedOrigin)) {
LOGGER.log(Level.FINE, () -> "Rejecting origin: " + actualOrigin + "; expected was from request: " + expectedOrigin);
return HttpResponses.forbidden();
return statusWithExplanation(HttpServletResponse.SC_FORBIDDEN, "Unexpected request origin (check your reverse proxy settings)");
}
} else if (!ALLOW_WEBSOCKET) {
return HttpResponses.forbidden();
return statusWithExplanation(HttpServletResponse.SC_FORBIDDEN, "WebSocket support for CLI disabled for this controller");
}
Authentication authentication = Jenkins.getAuthentication2();
return WebSockets.upgrade(new WebSocketSession() {
Expand Down

0 comments on commit f9e830e

Please sign in to comment.