org.jclouds.openstack.marconi.v1.options.StreamMessagesOptions.java Source code

Java tutorial

Introduction

Here is the source code for org.jclouds.openstack.marconi.v1.options.StreamMessagesOptions.java

Source

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file 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 org.jclouds.openstack.marconi.v1.options;

import com.google.common.collect.Iterables;
import com.google.common.collect.Multimap;
import org.jclouds.openstack.v2_0.options.PaginationOptions;

import static com.google.common.base.Preconditions.checkNotNull;

/**
 * Options used to control the messages returned in the response.
 */
public class StreamMessagesOptions extends PaginationOptions {

    public static final StreamMessagesOptions NONE = new StreamMessagesOptions();

    /**
     * {@inheritDoc}
     */
    @Override
    public StreamMessagesOptions queryParameters(Multimap<String, String> queryParams) {
        checkNotNull(queryParams, "queryParams");
        queryParameters.putAll(queryParams);
        return this;
    }

    /**
     * @see Builder#marker(String)
     */
    @Override
    public StreamMessagesOptions marker(String marker) {
        super.marker(marker);
        return this;
    }

    /**
     * @see Builder#limit(int)
     */
    @Override
    public StreamMessagesOptions limit(int limit) {
        super.limit(limit);
        return this;

    }

    /**
     * @see Builder#echo(boolean)
     */
    public StreamMessagesOptions echo(boolean echo) {
        queryParameters.put("echo", Boolean.toString(echo));
        return this;
    }

    /**
     * @see Builder#includeClaimed(boolean)
     */
    public StreamMessagesOptions includeClaimed(boolean includeClaimed) {
        queryParameters.put("include_claimed", Boolean.toString(includeClaimed));
        return this;
    }

    /**
     * @return The String representation of the marker for these StreamMessagesOptions.
     */
    public String getMarker() {
        return Iterables.getOnlyElement(queryParameters.get("marker"));
    }

    public static class Builder {
        /**
         * @see PaginationOptions#queryParameters(Multimap)
         */
        public static StreamMessagesOptions queryParameters(Multimap<String, String> queryParams) {
            StreamMessagesOptions options = new StreamMessagesOptions();
            return options.queryParameters(queryParams);
        }

        /**
         * Specifies an opaque string that the client can use to request the next batch of messages. The marker parameter
         * communicates to the server which messages the client has already received. If you do not specify a value, the
         * API returns all messages at the head of the queue (up to the limit).
         * </p>
         * Clients should make no assumptions about the format or length of the marker. Furthermore, clients should assume
         * that there is no relationship between markers and message IDs.
         */
        public static StreamMessagesOptions marker(String marker) {
            StreamMessagesOptions options = new StreamMessagesOptions();
            return options.marker(marker);
        }

        /**
         * When more messages are available than can be returned in a single request, the client can pick up the next
         * batch of messages by simply using the {@see StremOptions} returned from the previous call in {@code
         * MessageStream#nextStreamOptions()}. Specifies up to 10 messages (the default value) to return. If you do not
         * specify a value for the limit parameter, the default value of 10 is used.
         */
        public static StreamMessagesOptions limit(int limit) {
            StreamMessagesOptions options = new StreamMessagesOptions();
            return options.limit(limit);
        }

        /**
         * The echo parameter determines whether the API returns a client's own messages, as determined by the clientId
         * (UUID) portion of the client. If you do not specify a value, echo uses the default value of false. If you are
         * experimenting with the API, you might want to set echo=true in order to see the messages that you posted.
         */
        public static StreamMessagesOptions echo(boolean echo) {
            StreamMessagesOptions options = new StreamMessagesOptions();
            return options.echo(echo);
        }

        /**
         * The includeClaimed parameter determines whether the API returns claimed messages.
         */
        public static StreamMessagesOptions includeClaimed(boolean includeClaimed) {
            StreamMessagesOptions options = new StreamMessagesOptions();
            return options.echo(includeClaimed);
        }
    }
}