JCLOUDS-1110: Inject timeStamp into Atmos provider

This addresses a unit test failure.
This commit is contained in:
Andrew Gaul 2017-11-14 10:46:54 -08:00
parent fda87d7dc7
commit a62494a117
2 changed files with 15 additions and 7 deletions

View File

@ -21,6 +21,7 @@ import static org.jclouds.blobstore.util.BlobStoreUtils.cleanRequest;
import static org.jclouds.reflect.Reflection2.method; import static org.jclouds.reflect.Reflection2.method;
import java.net.URI; import java.net.URI;
import java.util.Date;
import javax.inject.Inject; import javax.inject.Inject;
import javax.inject.Singleton; import javax.inject.Singleton;
@ -33,17 +34,19 @@ import org.jclouds.atmos.options.PutOptions;
import org.jclouds.blobstore.BlobRequestSigner; import org.jclouds.blobstore.BlobRequestSigner;
import org.jclouds.blobstore.domain.Blob; import org.jclouds.blobstore.domain.Blob;
import org.jclouds.blobstore.functions.BlobToHttpGetOptions; import org.jclouds.blobstore.functions.BlobToHttpGetOptions;
import org.jclouds.date.DateService;
import org.jclouds.date.TimeStamp;
import org.jclouds.domain.Credentials; import org.jclouds.domain.Credentials;
import org.jclouds.http.HttpRequest; import org.jclouds.http.HttpRequest;
import org.jclouds.http.Uris; import org.jclouds.http.Uris;
import org.jclouds.http.options.GetOptions; import org.jclouds.http.options.GetOptions;
import org.jclouds.location.Provider;
import org.jclouds.reflect.Invocation; import org.jclouds.reflect.Invocation;
import com.google.common.base.Function; import com.google.common.base.Function;
import com.google.common.base.Supplier; import com.google.common.base.Supplier;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.reflect.Invokable; import com.google.common.reflect.Invokable;
import com.google.inject.Provider;
@Singleton @Singleton
public class AtmosBlobRequestSigner implements BlobRequestSigner { public class AtmosBlobRequestSigner implements BlobRequestSigner {
@ -60,11 +63,15 @@ public class AtmosBlobRequestSigner implements BlobRequestSigner {
private final SignRequest signer; private final SignRequest signer;
private final URI endpoint; private final URI endpoint;
private final String identity; private final String identity;
private final DateService dateService;
private final Provider<String> timeStampProvider;
@Inject @Inject
public AtmosBlobRequestSigner(Function<Invocation, HttpRequest> processor, BlobToObject blobToObject, public AtmosBlobRequestSigner(Function<Invocation, HttpRequest> processor, BlobToObject blobToObject,
BlobToHttpGetOptions blob2ObjectGetOptions, SignRequest signer, BlobToHttpGetOptions blob2ObjectGetOptions, SignRequest signer,
@Provider Supplier<URI> endpointProvider, @Provider Supplier<Credentials> creds) @org.jclouds.location.Provider Supplier<URI> endpointProvider,
@org.jclouds.location.Provider Supplier<Credentials> creds,
DateService dateService, @TimeStamp Provider<String> timeStampProvider)
throws SecurityException, NoSuchMethodException { throws SecurityException, NoSuchMethodException {
this.processor = checkNotNull(processor, "processor"); this.processor = checkNotNull(processor, "processor");
this.blobToObject = checkNotNull(blobToObject, "blobToObject"); this.blobToObject = checkNotNull(blobToObject, "blobToObject");
@ -75,6 +82,8 @@ public class AtmosBlobRequestSigner implements BlobRequestSigner {
this.signer = signer; this.signer = signer;
this.endpoint = endpointProvider.get(); this.endpoint = endpointProvider.get();
this.identity = creds.get().identity; this.identity = creds.get().identity;
this.dateService = dateService;
this.timeStampProvider = timeStampProvider;
} }
@Override @Override
@ -124,7 +133,8 @@ public class AtmosBlobRequestSigner implements BlobRequestSigner {
} }
private HttpRequest sign(String method, String path, long timeInSeconds) { private HttpRequest sign(String method, String path, long timeInSeconds) {
String expires = String.valueOf(System.currentTimeMillis() / 1000 + timeInSeconds); Date now = dateService.rfc1123DateParse(timeStampProvider.get());
String expires = String.valueOf(now.getTime() / 1000 + timeInSeconds);
String stringToSign = method + "\n" + String stringToSign = method + "\n" +
path + "\n" + path + "\n" +
identity + "\n" + identity + "\n" +

View File

@ -59,10 +59,8 @@ public class AtmosBlobRequestSignerTest extends BaseRestAnnotationProcessingTest
NoSuchMethodException, IOException { NoSuchMethodException, IOException {
HttpRequest request = signer.signGetBlob("container", "name"); HttpRequest request = signer.signGetBlob("container", "name");
assertRequestLineEquals(request, "GET https://accesspoint.atmosonline.com/rest/namespace/container/name HTTP/1.1"); assertRequestLineEquals(request, "GET https://accesspoint.atmosonline.com/rest/namespace/container/name?uid=identity&expires=1212684799&signature=oijXdvPjHQ/LwWDcdx9Eozsu77o%3D HTTP/1.1");
assertNonPayloadHeadersEqual( assertNonPayloadHeadersEqual(request, "");
request,
"Accept: */*\nDate: Thu, 05 Jun 2008 16:38:19 GMT\nx-emc-signature: DHDKwV6IPsJJvtrI9ktTiKq9us4=\nx-emc-uid: identity\n");
assertPayloadEquals(request, null, null, false); assertPayloadEquals(request, null, null, false);
assertEquals(request.getFilters().size(), 0); assertEquals(request.getFilters().size(), 0);