com.basho.riak.client.http.response.StreamedSiblingsCollection Maven / Gradle / Ivy
package com.basho.riak.client.http.response;
import java.io.IOException;
import java.util.List;
import java.util.Map;
import com.basho.riak.client.http.RiakClient;
import com.basho.riak.client.http.RiakIndex;
import com.basho.riak.client.http.RiakLink;
import com.basho.riak.client.http.RiakObject;
import com.basho.riak.client.http.util.ClientUtils;
import com.basho.riak.client.http.util.CollectionWrapper;
import com.basho.riak.client.http.util.Constants;
import com.basho.riak.client.http.util.Multipart;
import com.basho.riak.client.http.util.StreamedMultipart;
public class StreamedSiblingsCollection extends CollectionWrapper {
String bucket;
String key;
RiakClient riak;
StreamedMultipart multipart;
public StreamedSiblingsCollection(RiakClient riak, String bucket, String key, StreamedMultipart multipart) {
this.bucket = bucket;
this.key = key;
this.riak = riak;
this.multipart = multipart;
}
/**
* Tries to read and cache another part of the multipart/mixed stream.
*
* @throws RiakIORuntimeException
* If an error occurs during communication with the Riak server.
*/
@Override protected boolean cacheNext() {
if (multipart == null)
return false;
String vclock = null;
if (multipart.getHeaders() != null) {
vclock = multipart.getHeaders().get(Constants.HDR_VCLOCK);
}
Multipart.Part part;
try {
part = multipart.next();
} catch (RuntimeException e) {
if (e.getCause() instanceof IOException) {
throw new RiakIORuntimeException(e);
}
throw e;
}
if (part != null) {
Map headers = part.getHeaders();
List links = ClientUtils.parseLinkHeader(headers.get(Constants.HDR_LINK));
@SuppressWarnings("rawtypes") List indexes = ClientUtils.parseIndexHeaders(headers);
Map usermeta = ClientUtils.parseUsermeta(headers);
String location = headers.get(Constants.HDR_LOCATION);
String partBucket = bucket;
String partKey = key;
if (location != null) {
String[] locationParts = location.split("/");
if (locationParts.length >= 2) {
partBucket = locationParts[locationParts.length - 2];
partKey = locationParts[locationParts.length - 1];
}
}
RiakObject o = new RiakObject(riak, partBucket, partKey, null, headers.get(Constants.HDR_CONTENT_TYPE),
links, usermeta, vclock, headers.get(Constants.HDR_LAST_MODIFIED),
headers.get(Constants.HDR_ETAG), indexes,
headers.get(Constants.HDR_DELETED) != null ? true : false);
o.setValueStream(part.getStream());
cache(o);
return true;
}
return false;
}
@Override protected void closeBackend() {
riak = null;
multipart = null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy