public final class TaskOptions implements Serializable
   
  Contains various options for a task following the builder pattern. Calls to TaskOptions
 methods may be chained to specify multiple options in the one TaskOptions object.
 
taskOptions can have either TaskOptions.Method PULL or a PUSH-related method, e.g.
 POST, GET, ... Tasks with PULL method can only be added into a PULL queue and PUSH tasks can only
 be added into a PUSH queue.
 
Notes on usage:
 The recommended way to instantiate a TaskOptions object is to statically import Builder.* and invoke a static creation method followed by an instance mutator (if needed):
 
 import static com.google.appengine.api.taskqueue.TaskOptions.Builder.*;
 ...
 QueueFactory#getDefaultQueue().add(withUrl(url).etaMillis(eta));
 
    Inheritance
    Object  > 
    TaskOptions
   
  
  
  Constructors
  
  
  TaskOptions(TaskOptions options)
  
    public TaskOptions(TaskOptions options)
   
  
  
  Methods
  
  
  clearParams()
  
    public TaskOptions clearParams()
   
  
  
  
  countdownMillis(long countdownMillis)
  
    public TaskOptions countdownMillis(long countdownMillis)
   
  Set the number of milliseconds delay before execution of the task.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | countdownMillis | long
 | 
    
  
  
  
  dispatchDeadline(Duration dispatchDeadline)
  
    public TaskOptions dispatchDeadline(Duration dispatchDeadline)
   
  Sets the dispatch deadline for a task. The dispatch deadline should be no smaller than
 TaskOptions#MIN_DISPATCH_DEADLINE and no larger than TaskOptions#MAX_DISPATCH_DEADLINE.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | dispatchDeadline | Duration
 | 
    
  
  
  
  equals(Object obj)
  
    public boolean equals(Object obj)
   
  
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | obj | Object
 | 
    
  
  
  Overrides
  
  
  etaMillis(long etaMillis)
  
    public TaskOptions etaMillis(long etaMillis)
   
  Sets the approximate absolute time to execute. (i.e. etaMillis is comparable with System#currentTimeMillis()).
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | etaMillis | long
 | 
    
  
  
  
  getByteArrayParams()
  
    public Map<String,List<byte[]>> getByteArrayParams()
   
  Returns a copy of the task's byte-array-valued parameters as a map from each parameter name to
 a list of values for that name.
getCountdownMillis()
  
    public Long getCountdownMillis()
   
  Returns the delay to apply to the submitted time. May be null.
    
      
        | Returns | 
      
        | Type | Description | 
      
        | Long |  | 
    
  
  
  getDispatchDeadline()
  
    public @Nullable Duration getDispatchDeadline()
   
  Returns the dispatch deadline for a task. The dispatch deadline determines how long the of a
 task should take. If a task exceeds its deadline, it will be canceled and retried based on
 retry configurations of the task and/or queue.
getEtaMillis()
  
    public Long getEtaMillis()
   
  Returns the specified ETA for a task. May be null if not specified.
    
      
        | Returns | 
      
        | Type | Description | 
      
        | Long |  | 
    
  
  
  
  
    public Map<String,List<String>> getHeaders()
   
  Returns a copy of the task's headers as a map from each header name to a list of values for
 that header name.
getMethod()
  
    public TaskOptions.Method getMethod()
   
  Returns the method used for this task.
getPayload()
  
    public byte[] getPayload()
   
  Returns the live payload for the task, not a copy. May be null.
    
      
        | Returns | 
      
        | Type | Description | 
      
        | byte[] |  | 
    
  
  
  getRetryOptions()
  
    public RetryOptions getRetryOptions()
   
  Returns a copy of the retry options for a task. May be null if not specified.
getStringParams()
  
    public Map<String,List<String>> getStringParams()
   
  Returns a copy of the task's string-valued parameters as a map from each parameter name to a
 list of values for that name.
getTag()
  
  Returns the tag for a task. May be null if tag is not specified.
    
      
        | Returns | 
      
        | Type | Description | 
      
        | String |  | 
    
  
  
  
  getTagAsBytes()
  
    public byte[] getTagAsBytes()
   
  Returns the live tag bytes for a task, not a copy. May be null if tag is not specified.
    
      
        | Returns | 
      
        | Type | Description | 
      
        | byte[] |  | 
    
  
  
  getTaskName()
  
    public String getTaskName()
   
  
  
    
      
        | Returns | 
      
        | Type | Description | 
      
        | String |  | 
    
  
  
  getUrl()
  
  
    
      
        | Returns | 
      
        | Type | Description | 
      
        | String |  | 
    
  
  
  hashCode()
  
  
    
      
        | Returns | 
      
        | Type | Description | 
      
        | int |  | 
    
  
  Overrides
  
  
  
  
    public TaskOptions header(String headerName, String value)
   
  Adds a header name/value pair.
    public TaskOptions headers(Map<String,String> headers)
   
  Replaces the existing headers with the provided header name/value mapping.
    
      
        | Returns | 
      
        | Type | Description | 
      
        | TaskOptions | TaskOptions object for chaining. | 
    
  
  
  method(TaskOptions.Method method)
  
    public TaskOptions method(TaskOptions.Method method)
   
  Set the method used for this task. Defaults to Method#POST.
param(String name, byte[] value)
  
    public TaskOptions param(String name, byte[] value)
   
  Add a named byte array parameter.
    
      
        | Parameters | 
      
        | Name | Description | 
      
        | name | String
 Name of the parameter. Must not be null or empty. | 
      
        | value | byte[]
 A byte array and encoded as-is (i.e. without character encoding transformations).
     valuemust not benull. | 
    
  
  
  
  param(String name, String value)
  
    public TaskOptions param(String name, String value)
   
  
  
    
      
        | Parameters | 
      
        | Name | Description | 
      
        | name | String
 Name of the parameter. Must not be null or empty. | 
      
        | value | String
 The value of the parameter will undergo a "UTF-8" character encoding
     transformation upon being added to the queue. valuemust not benull. | 
    
  
  
  
  payload(byte[] payload)
  
    public TaskOptions payload(byte[] payload)
   
  Sets the payload directly without specifying the content-type. If this task is added to a push
 queue, the content-type will be set to 'application/octet-stream' by default.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | payload | byte[]
 The bytes representing the paylaod. | 
    
  
  
    
      
        | Returns | 
      
        | Type | Description | 
      
        | TaskOptions | TaskOptions object for chaining. | 
    
  
  
  payload(byte[] payload, String contentType)
  
    public TaskOptions payload(byte[] payload, String contentType)
   
  Set the payload with the given content type.
    
      
        | Parameters | 
      
        | Name | Description | 
      
        | payload | byte[]
 The bytes representing the paylaod. | 
      
        | contentType | String
 The content-type of the bytes. | 
    
  
  
    
      
        | Returns | 
      
        | Type | Description | 
      
        | TaskOptions | TaskOptions object for chaining. | 
    
  
  
  payload(DeferredTask deferredTask)
  
    public TaskOptions payload(DeferredTask deferredTask)
   
  Sets the payload to the serialized form of the deferredTask object. The payload will be
 generated by serializing the deferredTask object using ObjectOutputStream#writeObject(Object). If the deferredTask's Method is not PULL, the
 content type will be set to DeferredTaskContext#RUNNABLE_TASK_CONTENT_TYPE, the method
 will be forced to Method#POST and if otherwise not specified, the url will be set to
 DeferredTaskContext#DEFAULT_DEFERRED_URL; the DeferredTask servlet is, by
 default, mapped to this url.
 
Note: While this may be a convenient API, it requires careful control of the serialization
 compatibility of objects passed into #payload(DeferredTask) method as objects placed in
 the task queue will survive revision updates of the application and hence may fail
 deserialization when the task is decoded with new revisions of the application. In particular,
 Java anonymous classes are convenient but may be particularly difficult to control or test for
 serialization compatibility.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | deferredTask | DeferredTask
 The object to serialize into the payload. | 
    
  
  
  
  payload(String payload)
  
    public TaskOptions payload(String payload)
   
  Set the payload by String. The charset to convert the String to will be UTF-8 unless
 the method is PULL, in which case the String's bytes will be used directly.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | payload | String
 The String to be used. | 
    
  
  
    
      
        | Returns | 
      
        | Type | Description | 
      
        | TaskOptions | TaskOptions object for chaining. | 
    
  
  
  payload(String payload, String charset)
  
    public TaskOptions payload(String payload, String charset)
   
  Sets the payload from a String given a specific character set.
    public TaskOptions removeHeader(String headerName)
   
  Remove all headers with the given name.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | headerName | String
 | 
    
  
  
  
  removeParam(String paramName)
  
    public TaskOptions removeParam(String paramName)
   
  Remove all parameters with the given name.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | paramName | String
 Name of the parameter. Must not be null or empty. | 
    
  
  
  
  retryOptions(RetryOptions retryOptions)
  
    public TaskOptions retryOptions(RetryOptions retryOptions)
   
  Sets retry options for this task. Retry Options must be built with 
 RetryOptions.Builder.
tag(byte[] tag)
  
    public TaskOptions tag(byte[] tag)
   
  Sets the tag for a task. Ignores null or zero-length tags.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | tag | byte[]
 | 
    
  
  
  
  tag(String tag)
  
    public TaskOptions tag(String tag)
   
  Sets the tag for a task. Ignores null or empty tags.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | tag | String
 | 
    
  
  
  
  taskName(String taskName)
  
    public TaskOptions taskName(String taskName)
   
  
  
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | taskName | String
 | 
    
  
  
  
  toString()
  
  
    
      
        | Returns | 
      
        | Type | Description | 
      
        | String |  | 
    
  
  Overrides
  
  
  url(String url)
  
    public TaskOptions url(String url)
   
  Set the URL.
 
Default value is null.
    
      
        | Parameter | 
      
        | Name | Description | 
      
        | url | String
 String containing URL. |