All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.microsoft.windowsazure.services.queue.models.CreateQueueOptions Maven / Gradle / Ivy

/**
 * Copyright Microsoft Corporation
 * 
 * Licensed 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.microsoft.windowsazure.services.queue.models;

import java.util.HashMap;

import com.microsoft.windowsazure.services.queue.QueueContract;

/**
 * Represents the options that may be set on a queue when created in the storage service with a
 * {@link QueueContract#createQueue(String, CreateQueueOptions) createQueue} request. These options include a server
 * response timeout for the request and the metadata to associate with the created queue.
 */
public class CreateQueueOptions extends QueueServiceOptions {
    private HashMap metadata = new HashMap();

    /**
     * Sets the server request timeout value associated with this {@link CreateQueueOptions} instance.
     * 

* The timeout value only affects calls made on methods where this {@link CreateQueueOptions} instance is * passed as a parameter. * * @param timeout * The server request timeout value to set in milliseconds. * @return * A reference to this {@link CreateQueueOptions} instance. */ @Override public CreateQueueOptions setTimeout(Integer timeout) { super.setTimeout(timeout); return this; } /** * Gets the metadata collection of key-value {@link String} pairs to set on a queue when the queue is created. * * @return * A {@link java.util.HashMap} of key-value {@link String} pairs containing the metadata to set on the * queue. */ public HashMap getMetadata() { return metadata; } /** * Sets the metadata collection of key-value {@link String} pairs to set on a queue when the queue is created. Queue * metadata is a user-defined collection of key-value pairs that is opaque to the server. *

* The metadata value is only added to a newly created queue where this {@link CreateQueueOptions} instance * is passed as a parameter. * * @param metadata * The {@link java.util.HashMap} of key-value {@link String} pairs containing the metadata to set on the * queue. * @return * A reference to this {@link CreateQueueOptions} instance. */ public CreateQueueOptions setMetadata(HashMap metadata) { this.metadata = metadata; return this; } /** * Adds a key-value pair of {@link String} to the metadata collection to set on a queue when the queue is created. * Queue metadata is a user-defined collection of key-value pairs that is opaque to the server. If the key already * exists in the metadata collection, the value parameter will overwrite the existing value paired with that key * without notification. *

* The updated metadata is only added to a newly created queue where this {@link CreateQueueOptions} instance is * passed as a parameter. * * @param key * A {@link String} containing the key part of the key-value pair to add to the metadata. * @param value * A {@link String} containing the value part of the key-value pair to add to the metadata. * @return * A reference to this {@link CreateQueueOptions} instance. */ public CreateQueueOptions addMetadata(String key, String value) { this.metadata.put(key, value); return this; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy