mirror of https://github.com/apache/jclouds.git
JCLOUDS-766: Do not resign already-signed requests
Previously jclouds would add both a V2 and V4 signature to some requests which Amazon rejects. Addresses AWSS3BlobSignerLiveTest test failures with time-limited requests.
This commit is contained in:
parent
6964ef6c8f
commit
fdec2fa99f
|
@ -17,11 +17,14 @@
|
||||||
package org.jclouds.aws.s3.filters;
|
package org.jclouds.aws.s3.filters;
|
||||||
|
|
||||||
import static org.jclouds.http.utils.Queries.queryParser;
|
import static org.jclouds.http.utils.Queries.queryParser;
|
||||||
|
import static org.jclouds.aws.s3.blobstore.AWSS3BlobRequestSigner.TEMPORARY_SIGNATURE_PARAM;
|
||||||
import static org.jclouds.s3.filters.AwsSignatureV4Constants.AMZ_SIGNATURE_PARAM;
|
import static org.jclouds.s3.filters.AwsSignatureV4Constants.AMZ_SIGNATURE_PARAM;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
import javax.inject.Singleton;
|
import javax.inject.Singleton;
|
||||||
|
|
||||||
|
import com.google.common.collect.Multimap;
|
||||||
|
|
||||||
import org.jclouds.http.HttpRequest;
|
import org.jclouds.http.HttpRequest;
|
||||||
import org.jclouds.s3.filters.Aws4SignerForAuthorizationHeader;
|
import org.jclouds.s3.filters.Aws4SignerForAuthorizationHeader;
|
||||||
import org.jclouds.s3.filters.Aws4SignerForChunkedUpload;
|
import org.jclouds.s3.filters.Aws4SignerForChunkedUpload;
|
||||||
|
@ -50,7 +53,8 @@ public class AWSRequestAuthorizeSignatureV4 extends RequestAuthorizeSignatureV4
|
||||||
* with expiration.
|
* with expiration.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (queryParser().apply(request.getEndpoint().getQuery()).containsKey(AMZ_SIGNATURE_PARAM)) {
|
Multimap<String, String> queryMap = queryParser().apply(request.getEndpoint().getQuery());
|
||||||
|
if (queryMap.containsKey(AMZ_SIGNATURE_PARAM) || queryMap.containsKey(TEMPORARY_SIGNATURE_PARAM)) {
|
||||||
return request;
|
return request;
|
||||||
}
|
}
|
||||||
return super.signForAuthorizationHeader(request);
|
return super.signForAuthorizationHeader(request);
|
||||||
|
|
Loading…
Reference in New Issue