You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@jclouds.apache.org by an...@apache.org on 2014/08/09 01:10:30 UTC

[1/2] git commit: Revert "Parse Swift authentication headers case-insensitively"

Repository: jclouds
Updated Branches:
  refs/heads/master e532e6f26 -> aa174a5d7


Revert "Parse Swift authentication headers case-insensitively"

Missing JIRA issue number.

This reverts commit e532e6f260c6070673ed9bb87294c4596e9e8b88.


Project: http://git-wip-us.apache.org/repos/asf/jclouds/repo
Commit: http://git-wip-us.apache.org/repos/asf/jclouds/commit/5d3b293b
Tree: http://git-wip-us.apache.org/repos/asf/jclouds/tree/5d3b293b
Diff: http://git-wip-us.apache.org/repos/asf/jclouds/diff/5d3b293b

Branch: refs/heads/master
Commit: 5d3b293b69b8c656a2b6dd99824fb9ed7f88ca86
Parents: e532e6f
Author: Andrew Phillips <an...@apache.org>
Authored: Fri Aug 8 19:09:36 2014 -0400
Committer: Andrew Phillips <an...@apache.org>
Committed: Fri Aug 8 19:09:36 2014 -0400

----------------------------------------------------------------------
 .../ParseAuthenticationResponseFromHeaders.java | 12 +++-------
 ...seAuthenticationResponseFromHeadersTest.java | 24 ++++++--------------
 2 files changed, 10 insertions(+), 26 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/jclouds/blob/5d3b293b/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java
----------------------------------------------------------------------
diff --git a/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java b/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java
index 98780d5..26fb168 100644
--- a/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java
+++ b/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java
@@ -20,6 +20,7 @@ import static com.google.common.base.Preconditions.checkNotNull;
 import static org.jclouds.http.HttpUtils.releasePayload;
 import static org.jclouds.http.Uris.uriBuilder;
 import static org.jclouds.openstack.reference.AuthHeaders.AUTH_TOKEN;
+import static org.jclouds.openstack.reference.AuthHeaders.URL_SUFFIX;
 
 import java.net.URI;
 import java.util.Map.Entry;
@@ -30,7 +31,6 @@ import org.jclouds.http.HttpRequest;
 import org.jclouds.http.HttpResponse;
 import org.jclouds.logging.Logger;
 import org.jclouds.openstack.domain.AuthenticationResponse;
-import org.jclouds.openstack.reference.AuthHeaders;
 import org.jclouds.rest.InvocationContext;
 
 import com.google.common.annotations.VisibleForTesting;
@@ -58,14 +58,8 @@ public class ParseAuthenticationResponseFromHeaders implements Function<HttpResp
       // HTTP headers are case insensitive (RFC 2616) so we must allow for that when looking an header names for the URL keyword
       Builder<String, URI> builder = ImmutableMap.builder();
       for (Entry<String, String> entry : from.getHeaders().entries()) {
-         String header = entry.getKey();
-         if (header.equalsIgnoreCase(AuthHeaders.STORAGE_URL)) {
-            builder.put(AuthHeaders.STORAGE_URL, getURI(entry.getValue()));
-         } else if (header.equalsIgnoreCase(AuthHeaders.SERVER_MANAGEMENT_URL)) {
-            builder.put(AuthHeaders.SERVER_MANAGEMENT_URL, getURI(entry.getValue()));
-         } else if (header.equalsIgnoreCase(AuthHeaders.CDN_MANAGEMENT_URL)) {
-            builder.put(AuthHeaders.CDN_MANAGEMENT_URL, getURI(entry.getValue()));
-         }
+         if (entry.getKey().toLowerCase().endsWith(URL_SUFFIX.toLowerCase()))
+            builder.put(entry.getKey(), getURI(entry.getValue()));
       }
       AuthenticationResponse response = new AuthenticationResponse(checkNotNull(from.getFirstHeaderOrNull(AUTH_TOKEN),
                AUTH_TOKEN), builder.build());

http://git-wip-us.apache.org/repos/asf/jclouds/blob/5d3b293b/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java
----------------------------------------------------------------------
diff --git a/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java b/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java
index e566ca0..407abd6 100644
--- a/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java
+++ b/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java
@@ -23,9 +23,9 @@ import java.net.URI;
 import org.jclouds.Constants;
 import org.jclouds.http.HttpResponse;
 import org.jclouds.openstack.domain.AuthenticationResponse;
-import org.jclouds.openstack.reference.AuthHeaders;
 import org.testng.annotations.Test;
 
+import com.google.common.collect.ImmutableMap;
 import com.google.inject.AbstractModule;
 import com.google.inject.Guice;
 import com.google.inject.Injector;
@@ -53,16 +53,11 @@ public class ParseAuthenticationResponseFromHeadersTest {
       HttpResponse response = HttpResponse.builder().statusCode(204).message("No Content")
                                           .addHeader("X-Auth-Token", "token")
                                           .addHeader("X-Storage-Token", "token")
-                                          .addHeader("X-Storage-Url", "http://127.0.0.1:8080/v1/token")
-                                          .addHeader("X-CDN-Management-Url", "http://127.0.0.1:8080/cdn-mgmt")
-                                          .addHeader("X-Server-Management-Url", "http://127.0.0.1:8080/srv-mgmt")
-                                          .build();
+                                          .addHeader("X-Storage-Url", "http://127.0.0.1:8080/v1/token").build();
 
       AuthenticationResponse md = parser.apply(response);
-      assertEquals(md.getAuthToken(), "token");
-      assertEquals(md.getServices().get(AuthHeaders.STORAGE_URL), URI.create("http://fooman:8080/v1/token"));
-      assertEquals(md.getServices().get(AuthHeaders.CDN_MANAGEMENT_URL), URI.create("http://fooman:8080/cdn-mgmt"));
-      assertEquals(md.getServices().get(AuthHeaders.SERVER_MANAGEMENT_URL), URI.create("http://fooman:8080/srv-mgmt"));
+      assertEquals(md, new AuthenticationResponse("token", ImmutableMap.<String, URI> of("X-Storage-Url", 
+               URI.create("http://fooman:8080/v1/token"))));
    }
 
    public void testHandleHeadersCaseInsensitively() {
@@ -72,14 +67,9 @@ public class ParseAuthenticationResponseFromHeadersTest {
       HttpResponse response = HttpResponse.builder().statusCode(204).message("No Content")
               .addHeader("x-auth-token", "token")
               .addHeader("x-storage-token", "token")
-              .addHeader("x-storage-url", "http://127.0.0.1:8080/v1/token")
-              .addHeader("x-cdn-management-url", "http://127.0.0.1:8080/cdn-mgmt")
-              .addHeader("x-server-management-url", "http://127.0.0.1:8080/srv-mgmt")
-              .build();
+              .addHeader("x-storage-url", "http://127.0.0.1:8080/v1/token").build();
       AuthenticationResponse md = parser.apply(response);
-      assertEquals(md.getAuthToken(), "token");
-      assertEquals(md.getServices().get(AuthHeaders.STORAGE_URL), URI.create("http://fooman:8080/v1/token"));
-      assertEquals(md.getServices().get(AuthHeaders.CDN_MANAGEMENT_URL), URI.create("http://fooman:8080/cdn-mgmt"));
-      assertEquals(md.getServices().get(AuthHeaders.SERVER_MANAGEMENT_URL), URI.create("http://fooman:8080/srv-mgmt"));
+      assertEquals(md, new AuthenticationResponse("token", ImmutableMap.<String, URI> of("x-storage-url", 
+              URI.create("http://fooman:8080/v1/token"))));
    }
 }


[2/2] git commit: JCLOUDS-656: Parse Swift authentication headers case-insensitively

Posted by an...@apache.org.
JCLOUDS-656: Parse Swift authentication headers case-insensitively

Also ensure they are added to the result object with the normalized
capitalization expected by downstream code.

Follow-up to 375cb207.


Project: http://git-wip-us.apache.org/repos/asf/jclouds/repo
Commit: http://git-wip-us.apache.org/repos/asf/jclouds/commit/aa174a5d
Tree: http://git-wip-us.apache.org/repos/asf/jclouds/tree/aa174a5d
Diff: http://git-wip-us.apache.org/repos/asf/jclouds/diff/aa174a5d

Branch: refs/heads/master
Commit: aa174a5d73fb1195780c1dce45ab62404117217b
Parents: 5d3b293
Author: Fabian Lange <la...@gmail.com>
Authored: Wed Aug 6 18:16:32 2014 +0200
Committer: Andrew Phillips <an...@apache.org>
Committed: Fri Aug 8 19:10:00 2014 -0400

----------------------------------------------------------------------
 .../ParseAuthenticationResponseFromHeaders.java | 12 +++++++---
 ...seAuthenticationResponseFromHeadersTest.java | 24 ++++++++++++++------
 2 files changed, 26 insertions(+), 10 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/jclouds/blob/aa174a5d/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java
----------------------------------------------------------------------
diff --git a/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java b/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java
index 26fb168..98780d5 100644
--- a/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java
+++ b/common/openstack/src/main/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeaders.java
@@ -20,7 +20,6 @@ import static com.google.common.base.Preconditions.checkNotNull;
 import static org.jclouds.http.HttpUtils.releasePayload;
 import static org.jclouds.http.Uris.uriBuilder;
 import static org.jclouds.openstack.reference.AuthHeaders.AUTH_TOKEN;
-import static org.jclouds.openstack.reference.AuthHeaders.URL_SUFFIX;
 
 import java.net.URI;
 import java.util.Map.Entry;
@@ -31,6 +30,7 @@ import org.jclouds.http.HttpRequest;
 import org.jclouds.http.HttpResponse;
 import org.jclouds.logging.Logger;
 import org.jclouds.openstack.domain.AuthenticationResponse;
+import org.jclouds.openstack.reference.AuthHeaders;
 import org.jclouds.rest.InvocationContext;
 
 import com.google.common.annotations.VisibleForTesting;
@@ -58,8 +58,14 @@ public class ParseAuthenticationResponseFromHeaders implements Function<HttpResp
       // HTTP headers are case insensitive (RFC 2616) so we must allow for that when looking an header names for the URL keyword
       Builder<String, URI> builder = ImmutableMap.builder();
       for (Entry<String, String> entry : from.getHeaders().entries()) {
-         if (entry.getKey().toLowerCase().endsWith(URL_SUFFIX.toLowerCase()))
-            builder.put(entry.getKey(), getURI(entry.getValue()));
+         String header = entry.getKey();
+         if (header.equalsIgnoreCase(AuthHeaders.STORAGE_URL)) {
+            builder.put(AuthHeaders.STORAGE_URL, getURI(entry.getValue()));
+         } else if (header.equalsIgnoreCase(AuthHeaders.SERVER_MANAGEMENT_URL)) {
+            builder.put(AuthHeaders.SERVER_MANAGEMENT_URL, getURI(entry.getValue()));
+         } else if (header.equalsIgnoreCase(AuthHeaders.CDN_MANAGEMENT_URL)) {
+            builder.put(AuthHeaders.CDN_MANAGEMENT_URL, getURI(entry.getValue()));
+         }
       }
       AuthenticationResponse response = new AuthenticationResponse(checkNotNull(from.getFirstHeaderOrNull(AUTH_TOKEN),
                AUTH_TOKEN), builder.build());

http://git-wip-us.apache.org/repos/asf/jclouds/blob/aa174a5d/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java
----------------------------------------------------------------------
diff --git a/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java b/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java
index 407abd6..e566ca0 100644
--- a/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java
+++ b/common/openstack/src/test/java/org/jclouds/openstack/functions/ParseAuthenticationResponseFromHeadersTest.java
@@ -23,9 +23,9 @@ import java.net.URI;
 import org.jclouds.Constants;
 import org.jclouds.http.HttpResponse;
 import org.jclouds.openstack.domain.AuthenticationResponse;
+import org.jclouds.openstack.reference.AuthHeaders;
 import org.testng.annotations.Test;
 
-import com.google.common.collect.ImmutableMap;
 import com.google.inject.AbstractModule;
 import com.google.inject.Guice;
 import com.google.inject.Injector;
@@ -53,11 +53,16 @@ public class ParseAuthenticationResponseFromHeadersTest {
       HttpResponse response = HttpResponse.builder().statusCode(204).message("No Content")
                                           .addHeader("X-Auth-Token", "token")
                                           .addHeader("X-Storage-Token", "token")
-                                          .addHeader("X-Storage-Url", "http://127.0.0.1:8080/v1/token").build();
+                                          .addHeader("X-Storage-Url", "http://127.0.0.1:8080/v1/token")
+                                          .addHeader("X-CDN-Management-Url", "http://127.0.0.1:8080/cdn-mgmt")
+                                          .addHeader("X-Server-Management-Url", "http://127.0.0.1:8080/srv-mgmt")
+                                          .build();
 
       AuthenticationResponse md = parser.apply(response);
-      assertEquals(md, new AuthenticationResponse("token", ImmutableMap.<String, URI> of("X-Storage-Url", 
-               URI.create("http://fooman:8080/v1/token"))));
+      assertEquals(md.getAuthToken(), "token");
+      assertEquals(md.getServices().get(AuthHeaders.STORAGE_URL), URI.create("http://fooman:8080/v1/token"));
+      assertEquals(md.getServices().get(AuthHeaders.CDN_MANAGEMENT_URL), URI.create("http://fooman:8080/cdn-mgmt"));
+      assertEquals(md.getServices().get(AuthHeaders.SERVER_MANAGEMENT_URL), URI.create("http://fooman:8080/srv-mgmt"));
    }
 
    public void testHandleHeadersCaseInsensitively() {
@@ -67,9 +72,14 @@ public class ParseAuthenticationResponseFromHeadersTest {
       HttpResponse response = HttpResponse.builder().statusCode(204).message("No Content")
               .addHeader("x-auth-token", "token")
               .addHeader("x-storage-token", "token")
-              .addHeader("x-storage-url", "http://127.0.0.1:8080/v1/token").build();
+              .addHeader("x-storage-url", "http://127.0.0.1:8080/v1/token")
+              .addHeader("x-cdn-management-url", "http://127.0.0.1:8080/cdn-mgmt")
+              .addHeader("x-server-management-url", "http://127.0.0.1:8080/srv-mgmt")
+              .build();
       AuthenticationResponse md = parser.apply(response);
-      assertEquals(md, new AuthenticationResponse("token", ImmutableMap.<String, URI> of("x-storage-url", 
-              URI.create("http://fooman:8080/v1/token"))));
+      assertEquals(md.getAuthToken(), "token");
+      assertEquals(md.getServices().get(AuthHeaders.STORAGE_URL), URI.create("http://fooman:8080/v1/token"));
+      assertEquals(md.getServices().get(AuthHeaders.CDN_MANAGEMENT_URL), URI.create("http://fooman:8080/cdn-mgmt"));
+      assertEquals(md.getServices().get(AuthHeaders.SERVER_MANAGEMENT_URL), URI.create("http://fooman:8080/srv-mgmt"));
    }
 }