mirror of https://github.com/apache/jclouds.git
Replace uses of ByteArrayPayload
Prefer ByteSourcePayload which offers a superset of its functionality. Note that ByteArrayPayload implicitly set the contentLength while users of ByteSourcePayload must do so explicitly.
This commit is contained in:
parent
a4bc36dafa
commit
bd5b6853ee
|
@ -82,7 +82,7 @@ See http://code.google.com/p/jclouds for details."
|
|||
;; hence separating it from the above
|
||||
(extend-protocol PayloadSource
|
||||
(class (make-array Byte/TYPE 0))
|
||||
(payload [ba] (Payloads/newByteArrayPayload ba)))
|
||||
(payload [ba] (Payloads/newPayload ba)))
|
||||
|
||||
(defn blobstore
|
||||
"Create a logged in context.
|
||||
|
|
|
@ -16,8 +16,6 @@
|
|||
*/
|
||||
package org.jclouds.blobstore.strategy.internal;
|
||||
|
||||
import static org.jclouds.io.Payloads.newByteArrayPayload;
|
||||
|
||||
import javax.inject.Named;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
|
@ -26,6 +24,7 @@ import org.jclouds.blobstore.domain.StorageType;
|
|||
import org.jclouds.blobstore.reference.BlobStoreConstants;
|
||||
import org.jclouds.blobstore.strategy.MkdirStrategy;
|
||||
|
||||
import com.google.common.io.ByteSource;
|
||||
import com.google.inject.Inject;
|
||||
|
||||
/**
|
||||
|
@ -50,6 +49,8 @@ public class MarkerFileMkdirStrategy implements MkdirStrategy {
|
|||
blobStore.putBlob(
|
||||
containerName,
|
||||
blobStore.blobBuilder(directory + directorySuffix).type(StorageType.RELATIVE_PATH)
|
||||
.payload(newByteArrayPayload(new byte[] {})).contentType("application/directory").build());
|
||||
.payload(ByteSource.empty())
|
||||
.contentLength(0L)
|
||||
.contentType("application/directory").build());
|
||||
}
|
||||
}
|
||||
|
|
|
@ -69,7 +69,7 @@ public class HttpMessage extends PayloadEnclosingImpl {
|
|||
*/
|
||||
@Deprecated
|
||||
public T payload(byte [] payload) {
|
||||
this.payload = Payloads.newByteArrayPayload(checkNotNull(payload, "payload"));
|
||||
this.payload = Payloads.newPayload(checkNotNull(payload, "payload"));
|
||||
return self();
|
||||
}
|
||||
|
||||
|
|
|
@ -46,7 +46,10 @@ public class Payloads {
|
|||
} else if (data instanceof InputStream) {
|
||||
return newInputStreamPayload((InputStream) data);
|
||||
} else if (data instanceof byte[]) {
|
||||
return newByteArrayPayload((byte[]) data);
|
||||
byte[] array = (byte[]) data;
|
||||
Payload payload = newByteSourcePayload(ByteSource.wrap(array));
|
||||
payload.getContentMetadata().setContentLength((long) array.length);
|
||||
return payload;
|
||||
} else if (data instanceof ByteSource) {
|
||||
return newByteSourcePayload((ByteSource) data);
|
||||
} else if (data instanceof String) {
|
||||
|
|
|
@ -33,9 +33,9 @@ import javax.inject.Singleton;
|
|||
|
||||
import org.jclouds.io.ContentMetadata;
|
||||
import org.jclouds.io.Payload;
|
||||
import org.jclouds.io.Payloads;
|
||||
import org.jclouds.io.PayloadSlicer;
|
||||
import org.jclouds.io.payloads.BaseMutableContentMetadata;
|
||||
import org.jclouds.io.payloads.ByteArrayPayload;
|
||||
import org.jclouds.io.payloads.ByteSourcePayload;
|
||||
import org.jclouds.io.payloads.InputStreamPayload;
|
||||
|
||||
|
@ -119,7 +119,7 @@ public class BasePayloadSlicer implements PayloadSlicer {
|
|||
Payload payload = null;
|
||||
|
||||
if (content.length > 0) {
|
||||
payload = new ByteArrayPayload(content);
|
||||
payload = Payloads.newPayload(content);
|
||||
ContentMetadata cm = metaData.toBuilder().contentLength((long)content.length).contentMD5((HashCode) null).build();
|
||||
payload.setContentMetadata(BaseMutableContentMetadata.fromContentMetadata(cm));
|
||||
}
|
||||
|
|
|
@ -23,7 +23,7 @@ import com.google.common.base.Charsets;
|
|||
|
||||
/**
|
||||
* This implementation converts the String to a byte array using UTF-8 encoding. If you wish to use
|
||||
* a different encoding, please use {@link ByteArrayPayload}.
|
||||
* a different encoding, please use {@link ByteSourcePayload}.
|
||||
*
|
||||
* @deprecated see ByteSourcePayload
|
||||
*/
|
||||
|
|
|
@ -300,7 +300,7 @@ public class RestAnnotationProcessor implements Function<Invocation, HttpRequest
|
|||
payload = Payloads.newUrlEncodedFormPayload(transformValues(formParams, NullableToStringFunction.INSTANCE));
|
||||
} else if (headers.containsKey(CONTENT_TYPE) && !HttpRequest.NON_PAYLOAD_METHODS.contains(requestMethod)) {
|
||||
if (payload == null)
|
||||
payload = Payloads.newByteArrayPayload(new byte[] {});
|
||||
payload = Payloads.newPayload(new byte[] {});
|
||||
payload.getContentMetadata().setContentType(get(headers.get(CONTENT_TYPE), 0));
|
||||
}
|
||||
if (payload != null) {
|
||||
|
|
|
@ -36,7 +36,6 @@ import org.apache.http.client.methods.HttpPost;
|
|||
import org.apache.http.client.methods.HttpPut;
|
||||
import org.apache.http.client.methods.HttpRequestBase;
|
||||
import org.apache.http.client.methods.HttpUriRequest;
|
||||
import org.apache.http.entity.ByteArrayEntity;
|
||||
import org.apache.http.entity.FileEntity;
|
||||
import org.apache.http.entity.InputStreamEntity;
|
||||
import org.apache.http.entity.StringEntity;
|
||||
|
@ -48,7 +47,6 @@ import org.jclouds.io.ContentMetadataCodec;
|
|||
import org.jclouds.io.MutableContentMetadata;
|
||||
import org.jclouds.io.Payload;
|
||||
import org.jclouds.io.payloads.BasePayload;
|
||||
import org.jclouds.io.payloads.ByteArrayPayload;
|
||||
import org.jclouds.io.payloads.DelegatingPayload;
|
||||
import org.jclouds.io.payloads.FilePayload;
|
||||
import org.jclouds.io.payloads.StringPayload;
|
||||
|
@ -139,10 +137,6 @@ public class ApacheHCUtils {
|
|||
} else if (payload instanceof FilePayload) {
|
||||
apacheRequest.setEntity(new FileEntity((File) payload.getRawContent(), payload.getContentMetadata()
|
||||
.getContentType()));
|
||||
} else if (payload instanceof ByteArrayPayload) {
|
||||
ByteArrayEntity Entity = new ByteArrayEntity((byte[]) payload.getRawContent());
|
||||
Entity.setContentType(payload.getContentMetadata().getContentType());
|
||||
apacheRequest.setEntity(Entity);
|
||||
} else {
|
||||
InputStream inputStream = payload.getInput();
|
||||
if (payload.getContentMetadata().getContentLength() == null)
|
||||
|
|
|
@ -43,7 +43,7 @@ public class ConvertToJcloudsResponse implements Function<HTTPResponse, HttpResp
|
|||
|
||||
@Override
|
||||
public HttpResponse apply(HTTPResponse gaeResponse) {
|
||||
Payload payload = gaeResponse.getContent() != null ? Payloads.newByteArrayPayload(gaeResponse.getContent())
|
||||
Payload payload = gaeResponse.getContent() != null ? Payloads.newPayload(gaeResponse.getContent())
|
||||
: null;
|
||||
Multimap<String, String> headers = LinkedHashMultimap.create();
|
||||
String message = null;
|
||||
|
|
|
@ -18,7 +18,6 @@ package org.jclouds.aws.s3;
|
|||
|
||||
import static com.google.common.hash.Hashing.md5;
|
||||
import static org.jclouds.aws.s3.blobstore.options.AWSS3PutOptions.Builder.storageClass;
|
||||
import static org.jclouds.io.Payloads.newByteArrayPayload;
|
||||
import static org.jclouds.s3.options.ListBucketOptions.Builder.withPrefix;
|
||||
import static org.testng.Assert.assertEquals;
|
||||
import static org.testng.Assert.assertNotNull;
|
||||
|
@ -42,6 +41,7 @@ import org.jclouds.blobstore.options.PutOptions;
|
|||
import org.jclouds.domain.Location;
|
||||
import org.jclouds.io.ByteStreams2;
|
||||
import org.jclouds.io.Payload;
|
||||
import org.jclouds.io.Payloads;
|
||||
import org.jclouds.s3.S3Client;
|
||||
import org.jclouds.s3.S3ClientLiveTest;
|
||||
import org.jclouds.s3.domain.ListBucketResponse;
|
||||
|
@ -93,7 +93,7 @@ public class AWSS3ClientLiveTest extends S3ClientLiveTest {
|
|||
byte[] buffer = oneHundredOneConstitutions.read();
|
||||
assertEquals(oneHundredOneConstitutions.size(), (long) buffer.length);
|
||||
|
||||
Payload part1 = newByteArrayPayload(buffer);
|
||||
Payload part1 = Payloads.newPayload(buffer);
|
||||
part1.getContentMetadata().setContentLength((long) buffer.length);
|
||||
part1.getContentMetadata().setContentMD5(oneHundredOneConstitutionsMD5);
|
||||
|
||||
|
|
|
@ -45,7 +45,7 @@ import org.jclouds.blobstore.ContainerNotFoundException;
|
|||
import org.jclouds.blobstore.integration.internal.BaseBlobStoreIntegrationTest;
|
||||
import org.jclouds.http.HttpResponseException;
|
||||
import org.jclouds.http.options.GetOptions;
|
||||
import org.jclouds.io.payloads.ByteArrayPayload;
|
||||
import org.jclouds.io.Payloads;
|
||||
import org.jclouds.util.Strings2;
|
||||
import org.jclouds.util.Throwables2;
|
||||
import org.testng.annotations.Test;
|
||||
|
@ -361,9 +361,9 @@ public class AzureBlobClientLiveTest extends BaseBlobStoreIntegrationTest {
|
|||
String blockIdB = BaseEncoding.base64().encode((blockBlob + "-" + B).getBytes());
|
||||
String blockIdC = BaseEncoding.base64().encode((blockBlob + "-" + C).getBytes());
|
||||
getApi().createContainer(blockContainer);
|
||||
getApi().putBlock(blockContainer, blockBlob, blockIdA, new ByteArrayPayload(A.getBytes()));
|
||||
getApi().putBlock(blockContainer, blockBlob, blockIdB, new ByteArrayPayload(B.getBytes()));
|
||||
getApi().putBlock(blockContainer, blockBlob, blockIdC, new ByteArrayPayload(C.getBytes()));
|
||||
getApi().putBlock(blockContainer, blockBlob, blockIdA, Payloads.newPayload(A.getBytes()));
|
||||
getApi().putBlock(blockContainer, blockBlob, blockIdB, Payloads.newPayload(B.getBytes()));
|
||||
getApi().putBlock(blockContainer, blockBlob, blockIdC, Payloads.newPayload(C.getBytes()));
|
||||
getApi().putBlockList(blockContainer, blockBlob, Arrays.asList(blockIdA, blockIdB, blockIdC));
|
||||
ListBlobBlocksResponse blocks = getApi().getBlockList(blockContainer, blockBlob);
|
||||
assertEquals(3, blocks.getBlocks().size());
|
||||
|
|
Loading…
Reference in New Issue