Package com.basho.riak.client.raw

Source Code of com.basho.riak.client.raw.RiakResponse

/*
* This file is provided to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.basho.riak.client.raw;

import java.util.Arrays;
import java.util.Iterator;

import com.basho.riak.client.IRiakObject;
import com.basho.riak.client.cap.BasicVClock;
import com.basho.riak.client.cap.VClock;
import com.basho.riak.client.operations.FetchObject;

/**
* A data response from Riak separated into a single vector clock and an array of sibling values.
*
* Immutable
*
* @author russell
*/
public class RiakResponse implements Iterable<IRiakObject> {

    private static final IRiakObject[] NO_OBJECTS = new IRiakObject[] {};
    private final VClock vclock;
    private final IRiakObject[] riakObjects;
    private final boolean unmodified;
    private final boolean deleted;

    /**
     * Create a response from the given vector clock and array. Array maybe
     * empty or null as may the vector clock (which implies no data, right.)
     *
     * @param vclock
     * @param riakObjects
     */
    public RiakResponse(byte[] vclock, IRiakObject[] riakObjects) {
        if (vclock == null) {
            this.vclock = null;
        } else {
            this.vclock = new BasicVClock(vclock);
        }
        if (riakObjects == null) {
            this.riakObjects = NO_OBJECTS;
        } else {
            this.riakObjects = riakObjects;
        }
        this.unmodified = false;
        this.deleted = false;
    }

    /**
     * Create a response from the given vector clock. Vclock may not be null.
     * This response is a fetch response where the vclock was returned but the
     * item is deleted.
     *
     * @param vclock
     *
     * @deprecated As of release 1.1.0
     * @see {@link IRiakObject#isDeleted() }
     *
     * If only a tombstone exists this RiakResponse will contain an IRiakObject
     * with no value and marked as deleted.
     */
    @Deprecated
    public RiakResponse(byte[] vclock) {
        if (vclock == null) {
            throw new IllegalArgumentException("vclock cannot be null");
        } else {
            this.vclock = new BasicVClock(vclock);
        }
        this.riakObjects = NO_OBJECTS;
        this.unmodified = false;
        this.deleted = true;
    }

    /**
     * Create THE empty response
     */
    private RiakResponse() {
        this.riakObjects = NO_OBJECTS;
        this.vclock = null;
        this.unmodified = false;
        this.deleted = false;
    }

    /**
     * Create an empty response, with an <code>unmodified</code> value
     */
    private RiakResponse(boolean unmodified) {
        this.riakObjects = NO_OBJECTS;
        this.vclock = null;
        this.unmodified = unmodified;
        this.deleted = false;
    }

    /**
     * Get the vector clock bytes
     * @return the vclock
     */
    public byte[] getVclockBytes() {
        return vclock.getBytes();
    }

    /**
     * Get the vector clock as a {@link VClock}
     * @return the vector clock
     */
    public VClock getVclock() {
        return vclock;
    }

    /**
     * Gets the actual array of {@link IRiakObject} (not a clone or copy, so treat it well)
     * @return the riakObjects
     */
    public IRiakObject[] getRiakObjects() {
        return riakObjects;
    }

    /**
     * Does the response have sibling values?
     * @return
     */
    public boolean hasSiblings() {
        return riakObjects.length > 1;
    }

    /**
     * Does the response hav *any* values?
     * @return
     */
    public boolean hasValue() {
        return riakObjects.length > 0;
    }

    /**
     * How many values?
     * @return
     */
    public int numberOfValues() {
        return riakObjects.length;
    }

    /**
     * @return true if this is an empty response because of a conditional fetch
     *         that returned unchanged/not-modified
     *
     * @see FetchObject#ifModified(VClock)
     * @see FetchObject#modifiedSince(java.util.Date)
     * @see FetchMeta#getIfModifiedSince()
     * @see FetchMeta#getIfModifiedVClock()
     */
    public boolean isUnmodified() {
        return unmodified;
    }

    /**
     * @return true if this object has been deleted but there is a vclock for
     *         it, only relevant/accurate if the fetch asked for the deleted
     *         vclock.
     *
     * @see FetchObject#returnDeletedVClock(boolean)
     * @see FetchMeta#getReturnDeletedVClock()
     *
     * @deprecated
     * @see {@link IRiakObject#isDeleted() }
     */
    @Deprecated
    public boolean isDeleted() {
        return deleted;
    }

    /**
     * Unmodifiable iterator view of the values returned from Riak.
     */
    public Iterator<IRiakObject> iterator() {
        return Arrays.asList(riakObjects).iterator();
    }

    /**
     * Generate the empty response
     * @return THE empty response
     */
    public static RiakResponse empty() {
        return new RiakResponse();
    }

    /**
     * Generate an empty response, with a value for the conditional get 'isUnmodified' response.
     * @return THE empty response
     */
    public static RiakResponse empty(boolean unmodified) {
        return new RiakResponse(unmodified);
    }

    /**
     * @param unmodified
     * @return an empty response for an unmodified object (from a conditional
     *         fetch).
     */
    public static RiakResponse unmodified() {
        return new RiakResponse(true);
    }

    /**
     * @return
     */
    public static RiakResponse matchFound() {
        return null;
    }
}
TOP

Related Classes of com.basho.riak.client.raw.RiakResponse

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.