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";