You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cxf.apache.org by se...@apache.org on 2015/11/17 13:31:02 UTC
[1/2] cxf git commit: Updating ClientCodeRequestFilter to call
setCodeVerifier
Repository: cxf
Updated Branches:
refs/heads/3.1.x-fixes 08752e19d -> 5c541cd9c
Updating ClientCodeRequestFilter to call setCodeVerifier
Project: http://git-wip-us.apache.org/repos/asf/cxf/repo
Commit: http://git-wip-us.apache.org/repos/asf/cxf/commit/5c541cd9
Tree: http://git-wip-us.apache.org/repos/asf/cxf/tree/5c541cd9
Diff: http://git-wip-us.apache.org/repos/asf/cxf/diff/5c541cd9
Branch: refs/heads/3.1.x-fixes
Commit: 5c541cd9c16ed2d982085410cb801f2f21dbc82d
Parents: 68bdc0c
Author: Sergey Beryozkin <sb...@gmail.com>
Authored: Tue Nov 17 12:29:20 2015 +0000
Committer: Sergey Beryozkin <sb...@gmail.com>
Committed: Tue Nov 17 12:30:36 2015 +0000
----------------------------------------------------------------------
.../cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java | 1 +
1 file changed, 1 insertion(+)
----------------------------------------------------------------------
http://git-wip-us.apache.org/repos/asf/cxf/blob/5c541cd9/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java
----------------------------------------------------------------------
diff --git a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java
index 6dfaafe..98ca208 100644
--- a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java
+++ b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java
@@ -141,6 +141,7 @@ public class ClientCodeRequestFilter implements ContainerRequestFilter {
theState,
theScope);
setFormPostResponseMode(ub, redirectState);
+ setCodeVerifier(ub, redirectState);
setAdditionalCodeRequestParams(ub, redirectState);
URI uri = ub.build();
return Response.seeOther(uri).build();
[2/2] cxf git commit: Updating CodeVerifierTransformer
Posted by se...@apache.org.
Updating CodeVerifierTransformer
Project: http://git-wip-us.apache.org/repos/asf/cxf/repo
Commit: http://git-wip-us.apache.org/repos/asf/cxf/commit/68bdc0ce
Tree: http://git-wip-us.apache.org/repos/asf/cxf/tree/68bdc0ce
Diff: http://git-wip-us.apache.org/repos/asf/cxf/diff/68bdc0ce
Branch: refs/heads/3.1.x-fixes
Commit: 68bdc0ce14b116b961d752493621d8880106d979
Parents: 08752e1
Author: Sergey Beryozkin <sb...@gmail.com>
Authored: Tue Nov 17 12:26:39 2015 +0000
Committer: Sergey Beryozkin <sb...@gmail.com>
Committed: Tue Nov 17 12:30:36 2015 +0000
----------------------------------------------------------------------
.../oauth2/client/ClientCodeRequestFilter.java | 25 ++++++++++++--
.../grants/code/CodeVerifierTransformer.java | 1 +
.../oauth2/grants/code/DigestCodeVerifier.java | 5 +++
.../oauth2/grants/code/PlainCodeVerifier.java | 34 ++++++++++++++++++++
.../security/oauth2/utils/OAuthConstants.java | 3 +-
5 files changed, 65 insertions(+), 3 deletions(-)
----------------------------------------------------------------------
http://git-wip-us.apache.org/repos/asf/cxf/blob/68bdc0ce/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java
----------------------------------------------------------------------
diff --git a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java
index 18285a6..6dfaafe 100644
--- a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java
+++ b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/client/ClientCodeRequestFilter.java
@@ -36,6 +36,7 @@ import javax.ws.rs.core.SecurityContext;
import javax.ws.rs.core.UriBuilder;
import javax.ws.rs.core.UriInfo;
+import org.apache.cxf.common.util.Base64UrlUtility;
import org.apache.cxf.jaxrs.client.WebClient;
import org.apache.cxf.jaxrs.ext.MessageContext;
import org.apache.cxf.jaxrs.impl.MetadataMap;
@@ -45,8 +46,10 @@ import org.apache.cxf.jaxrs.utils.JAXRSUtils;
import org.apache.cxf.rs.security.oauth2.common.AccessTokenGrant;
import org.apache.cxf.rs.security.oauth2.common.ClientAccessToken;
import org.apache.cxf.rs.security.oauth2.grants.code.AuthorizationCodeGrant;
+import org.apache.cxf.rs.security.oauth2.grants.code.CodeVerifierTransformer;
import org.apache.cxf.rs.security.oauth2.utils.OAuthConstants;
import org.apache.cxf.rs.security.oauth2.utils.OAuthUtils;
+import org.apache.cxf.rt.security.crypto.CryptoUtils;
@PreMatching
@Priority(Priorities.AUTHENTICATION + 1)
@@ -68,6 +71,7 @@ public class ClientCodeRequestFilter implements ContainerRequestFilter {
private boolean setFormPostResponseMode;
private boolean faultAccessDeniedResponses;
private boolean applicationCanHandleAccessDenied;
+ private CodeVerifierTransformer codeVerifierTransformer;
@Override
public void filter(ContainerRequestContext rc) throws IOException {
@@ -136,19 +140,32 @@ public class ClientCodeRequestFilter implements ContainerRequestFilter {
getAbsoluteRedirectUri(ui).toString(),
theState,
theScope);
+ setFormPostResponseMode(ub, redirectState);
setAdditionalCodeRequestParams(ub, redirectState);
URI uri = ub.build();
return Response.seeOther(uri).build();
}
- protected void setAdditionalCodeRequestParams(UriBuilder ub, MultivaluedMap<String, String> redirectState) {
+ protected void setFormPostResponseMode(UriBuilder ub, MultivaluedMap<String, String> redirectState) {
if (setFormPostResponseMode) {
// This property is described in OIDC OAuth 2.0 Form Post Response Mode which is technically
// can be used without OIDC hence this is set in this filter as opposed to the OIDC specific one.
ub.queryParam("response_mode", "form_post");
}
}
-
+ protected void setCodeVerifier(UriBuilder ub, MultivaluedMap<String, String> redirectState) {
+ if (codeVerifierTransformer != null) {
+ String codeVerifier = Base64UrlUtility.encode(CryptoUtils.generateSecureRandomBytes(32));
+ ub.queryParam(OAuthConstants.AUTHORIZATION_CODE_CHALLENGE,
+ codeVerifierTransformer.transformCodeVerifier(codeVerifier));
+ ub.queryParam(OAuthConstants.AUTHORIZATION_CODE_CHALLENGE_METHOD,
+ codeVerifierTransformer.getChallengeMethod());
+ }
+ }
+ protected void setAdditionalCodeRequestParams(UriBuilder ub, MultivaluedMap<String, String> redirectState) {
+ }
+
+
private URI getAbsoluteRedirectUri(UriInfo ui) {
if (redirectUri != null) {
return URI.create(redirectUri);
@@ -315,4 +332,8 @@ public class ClientCodeRequestFilter implements ContainerRequestFilter {
public void setApplicationCanHandleAccessDenied(boolean applicationCanHandleAccessDenied) {
this.applicationCanHandleAccessDenied = applicationCanHandleAccessDenied;
}
+
+ public void setCodeVerifierTransformer(CodeVerifierTransformer codeVerifierTransformer) {
+ this.codeVerifierTransformer = codeVerifierTransformer;
+ }
}
http://git-wip-us.apache.org/repos/asf/cxf/blob/68bdc0ce/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/CodeVerifierTransformer.java
----------------------------------------------------------------------
diff --git a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/CodeVerifierTransformer.java b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/CodeVerifierTransformer.java
index 02a5e51..c856b7d 100644
--- a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/CodeVerifierTransformer.java
+++ b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/CodeVerifierTransformer.java
@@ -20,4 +20,5 @@ package org.apache.cxf.rs.security.oauth2.grants.code;
public interface CodeVerifierTransformer {
String transformCodeVerifier(String codeVerifier);
+ String getChallengeMethod();
}
http://git-wip-us.apache.org/repos/asf/cxf/blob/68bdc0ce/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/DigestCodeVerifier.java
----------------------------------------------------------------------
diff --git a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/DigestCodeVerifier.java b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/DigestCodeVerifier.java
index 9dc64e8..7f4325f 100644
--- a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/DigestCodeVerifier.java
+++ b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/DigestCodeVerifier.java
@@ -29,6 +29,11 @@ public class DigestCodeVerifier implements CodeVerifierTransformer {
return Base64UrlUtility.encode(digest);
}
+ @Override
+ public String getChallengeMethod() {
+ return "S256";
+ }
+
}
http://git-wip-us.apache.org/repos/asf/cxf/blob/68bdc0ce/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/PlainCodeVerifier.java
----------------------------------------------------------------------
diff --git a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/PlainCodeVerifier.java b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/PlainCodeVerifier.java
new file mode 100644
index 0000000..95d3baf
--- /dev/null
+++ b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/grants/code/PlainCodeVerifier.java
@@ -0,0 +1,34 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+package org.apache.cxf.rs.security.oauth2.grants.code;
+
+public class PlainCodeVerifier implements CodeVerifierTransformer {
+
+ public String transformCodeVerifier(String codeVerifier) {
+ return codeVerifier;
+ }
+
+ @Override
+ public String getChallengeMethod() {
+ return "plain";
+ }
+
+
+
+}
http://git-wip-us.apache.org/repos/asf/cxf/blob/68bdc0ce/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/utils/OAuthConstants.java
----------------------------------------------------------------------
diff --git a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/utils/OAuthConstants.java b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/utils/OAuthConstants.java
index b8f3687..b835e02 100644
--- a/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/utils/OAuthConstants.java
+++ b/rt/rs/security/oauth-parent/oauth2/src/main/java/org/apache/cxf/rs/security/oauth2/utils/OAuthConstants.java
@@ -57,9 +57,10 @@ public final class OAuthConstants {
public static final String BEARER_TOKEN_TYPE = "bearer";
public static final String HAWK_TOKEN_TYPE = "hawk";
- // http://datatracker.ietf.org/doc/draft-sakimura-oauth-tcse
+ // https://tools.ietf.org/html/rfc7636
public static final String AUTHORIZATION_CODE_VERIFIER = "code_verifier";
public static final String AUTHORIZATION_CODE_CHALLENGE = "code_challenge";
+ public static final String AUTHORIZATION_CODE_CHALLENGE_METHOD = "code_challenge_method";
// CXF-specific
public static final String REFRESH_TOKEN_TYPE = "refresh";