KEYCLOAK-5146 TokenEndpoint returns wrong methods for preflight requests (#4455)

This commit is contained in:
Martin Kanis 2017-09-13 06:23:11 +02:00 committed by Stian Thorgersen
parent 90db6654d3
commit 550e5f752a
3 changed files with 64 additions and 1 deletions

View file

@ -163,7 +163,7 @@ public class TokenEndpoint {
if (logger.isDebugEnabled()) { if (logger.isDebugEnabled()) {
logger.debugv("CORS preflight from: {0}", headers.getRequestHeaders().getFirst("Origin")); logger.debugv("CORS preflight from: {0}", headers.getRequestHeaders().getFirst("Origin"));
} }
return Cors.add(request, Response.ok()).auth().preflight().build(); return Cors.add(request, Response.ok()).auth().preflight().allowedMethods("POST", "OPTIONS").build();
} }
private void checkSsl() { private void checkSsl() {

View file

@ -23,6 +23,7 @@ import org.apache.http.NameValuePair;
import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet; import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpOptions;
import org.apache.http.client.methods.HttpPost; import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.utils.URLEncodedUtils; import org.apache.http.client.utils.URLEncodedUtils;
import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.CloseableHttpClient;
@ -248,6 +249,17 @@ public class OAuthClient {
return new DefaultHttpClient(); return new DefaultHttpClient();
} }
public CloseableHttpResponse doPreflightRequest() {
try (CloseableHttpClient client = newCloseableHttpClient()) {
HttpOptions options = new HttpOptions(getAccessTokenUrl());
options.setHeader("Origin", "http://example.com");
return client.execute(options);
} catch (IOException ioe) {
throw new RuntimeException(ioe);
}
}
public AccessTokenResponse doAccessTokenRequest(String code, String password) { public AccessTokenResponse doAccessTokenRequest(String code, String password) {
try (CloseableHttpClient client = newCloseableHttpClient()) { try (CloseableHttpClient client = newCloseableHttpClient()) {
HttpPost post = new HttpPost(getAccessTokenUrl()); HttpPost post = new HttpPost(getAccessTokenUrl());

View file

@ -0,0 +1,51 @@
package org.keycloak.testsuite.oauth;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.junit.Rule;
import org.junit.Test;
import org.keycloak.representations.idm.RealmRepresentation;
import org.keycloak.testsuite.AbstractKeycloakTest;
import org.keycloak.testsuite.AssertEvents;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import static org.keycloak.testsuite.auth.page.AuthRealm.TEST;
/**
* @author <a href="mailto:mkanis@redhat.com">Martin Kanis</a>
*/
public class PreflightRequestTest extends AbstractKeycloakTest {
@Rule
public AssertEvents events = new AssertEvents(this);
@Override
public void beforeAbstractKeycloakTest() throws Exception {
super.beforeAbstractKeycloakTest();
}
@Override
public void addTestRealms(List<RealmRepresentation> testRealms) {
RealmRepresentation testRealmRep = new RealmRepresentation();
testRealmRep.setId(TEST);
testRealmRep.setRealm(TEST);
testRealmRep.setEnabled(true);
testRealms.add(testRealmRep);
}
@Test
public void preflightRequest() throws Exception {
CloseableHttpResponse response = oauth.doPreflightRequest();
String[] methods = response.getHeaders("Access-Control-Allow-Methods")[0].getValue().split(", ");
Set allowedMethods = new HashSet(Arrays.asList(methods));
assertEquals(2, allowedMethods.size());
assertTrue(allowedMethods.containsAll(Arrays.asList("POST", "OPTIONS")));
}
}