if (validator.getGrantType().equals(req.getGrantType())) {
validator.validateRequest(req);
return; // request validated
}
}
OAuth2NormalizedResponse response = new OAuth2NormalizedResponse();
response.setStatus(HttpServletResponse.SC_BAD_REQUEST);
response.setError(ErrorType.UNSUPPORTED_GRANT_TYPE.toString());
response.setErrorDescription("Unsupported grant type");
response.setBodyReturned(true);
throw new OAuth2Exception(response);
} else { // implicit flow does not include grant type
if (req.getResponseType() == null
|| !req.getResponseType().equals("token")) {
OAuth2NormalizedResponse resp = new OAuth2NormalizedResponse();
resp.setError(ErrorType.UNSUPPORTED_RESPONSE_TYPE.toString());
resp.setErrorDescription("Unsupported response type");
resp.setStatus(HttpServletResponse.SC_FORBIDDEN);
throw new OAuth2Exception(resp);
}
OAuth2Client client = store.getClient(req.getClientId());
if (client == null || client.getFlow() != Flow.IMPLICIT) {
OAuth2NormalizedResponse resp = new OAuth2NormalizedResponse();
resp.setError(ErrorType.INVALID_CLIENT.toString());
resp.setErrorDescription(req.getClientId()
+ " is not a registered implicit client");
resp.setBodyReturned(true);
resp.setStatus(HttpServletResponse.SC_FORBIDDEN);
throw new OAuth2Exception(resp);
}
if (req.getRedirectURI() == null && client.getRedirectURI() == null) {
OAuth2NormalizedResponse resp = new OAuth2NormalizedResponse();
resp.setError(ErrorType.INVALID_REQUEST.toString());
resp.setErrorDescription("No redirect_uri registered or received in request");
resp.setBodyReturned(true);
resp.setStatus(HttpServletResponse.SC_FORBIDDEN);
throw new OAuth2Exception(resp);
}
if (req.getRedirectURI() != null
&& !req.getRedirectURI().equals(client.getRedirectURI())) {
OAuth2NormalizedResponse resp = new OAuth2NormalizedResponse();
resp.setError(ErrorType.INVALID_REQUEST.toString());
resp.setErrorDescription("Redirect URI does not match the one registered for this client");
resp.setBodyReturned(true);
resp.setStatus(HttpServletResponse.SC_FORBIDDEN);
throw new OAuth2Exception(resp);
}
return; // request validated
}
}