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

com.amazonaws.services.datapipeline.model.PollForTaskRequest Maven / Gradle / Ivy

Go to download

The Amazon Web Services SDK for Java provides Java APIs for building software on AWS' cost-effective, scalable, and reliable infrastructure products. The AWS Java SDK allows developers to code against APIs for all of Amazon's infrastructure web services (Amazon S3, Amazon EC2, Amazon SQS, Amazon Relational Database Service, Amazon AutoScaling, etc).

The newest version!
/*
 * Copyright 2010-2014 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 * 
 *  http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file 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.amazonaws.services.datapipeline.model;

import java.io.Serializable;

import com.amazonaws.AmazonWebServiceRequest;

/**
 * Container for the parameters to the {@link com.amazonaws.services.datapipeline.DataPipeline#pollForTask(PollForTaskRequest) PollForTask operation}.
 * 

* Task runners call this action to receive a task to perform from AWS * Data Pipeline. The task runner specifies which tasks it can perform by * setting a value for the workerGroup parameter of the PollForTask call. * The task returned by PollForTask may come from any of the pipelines * that match the workerGroup value passed in by the task runner and that * was launched using the IAM user credentials specified by the task * runner. *

*

* If tasks are ready in the work queue, PollForTask returns a response * immediately. If no tasks are available in the queue, PollForTask uses * long-polling and holds on to a poll connection for up to a 90 seconds * during which time the first newly scheduled task is handed to the task * runner. To accomodate this, set the socket timeout in your task runner * to 90 seconds. The task runner should not call PollForTask again on * the same workerGroup until it receives a response, and * this may take up to 90 seconds. *

* * @see com.amazonaws.services.datapipeline.DataPipeline#pollForTask(PollForTaskRequest) */ public class PollForTaskRequest extends AmazonWebServiceRequest implements Serializable { /** * Indicates the type of task the task runner is configured to accept and * process. The worker group is set as a field on objects in the pipeline * when they are created. You can only specify a single value for * workerGroup in the call to PollForTask. There are * no wildcard values permitted in workerGroup, the string * must be an exact, case-sensitive, match. *

* Constraints:
* Length: 0 - 1024
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
*/ private String workerGroup; /** * The public DNS name of the calling task runner. *

* Constraints:
* Length: 1 - 1024
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
*/ private String hostname; /** * Identity information for the Amazon EC2 instance that is hosting the * task runner. You can get this value by calling the URI, * http://169.254.169.254/latest/meta-data/instance-id, from * the EC2 instance. For more information, go to Instance * Metadata in the Amazon Elastic Compute Cloud User Guide. * Passing in this value proves that your task runner is running on an * EC2 instance, and ensures the proper AWS Data Pipeline service charges * are applied to your pipeline. */ private InstanceIdentity instanceIdentity; /** * Indicates the type of task the task runner is configured to accept and * process. The worker group is set as a field on objects in the pipeline * when they are created. You can only specify a single value for * workerGroup in the call to PollForTask. There are * no wildcard values permitted in workerGroup, the string * must be an exact, case-sensitive, match. *

* Constraints:
* Length: 0 - 1024
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
* * @return Indicates the type of task the task runner is configured to accept and * process. The worker group is set as a field on objects in the pipeline * when they are created. You can only specify a single value for * workerGroup in the call to PollForTask. There are * no wildcard values permitted in workerGroup, the string * must be an exact, case-sensitive, match. */ public String getWorkerGroup() { return workerGroup; } /** * Indicates the type of task the task runner is configured to accept and * process. The worker group is set as a field on objects in the pipeline * when they are created. You can only specify a single value for * workerGroup in the call to PollForTask. There are * no wildcard values permitted in workerGroup, the string * must be an exact, case-sensitive, match. *

* Constraints:
* Length: 0 - 1024
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
* * @param workerGroup Indicates the type of task the task runner is configured to accept and * process. The worker group is set as a field on objects in the pipeline * when they are created. You can only specify a single value for * workerGroup in the call to PollForTask. There are * no wildcard values permitted in workerGroup, the string * must be an exact, case-sensitive, match. */ public void setWorkerGroup(String workerGroup) { this.workerGroup = workerGroup; } /** * Indicates the type of task the task runner is configured to accept and * process. The worker group is set as a field on objects in the pipeline * when they are created. You can only specify a single value for * workerGroup in the call to PollForTask. There are * no wildcard values permitted in workerGroup, the string * must be an exact, case-sensitive, match. *

* Returns a reference to this object so that method calls can be chained together. *

* Constraints:
* Length: 0 - 1024
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
* * @param workerGroup Indicates the type of task the task runner is configured to accept and * process. The worker group is set as a field on objects in the pipeline * when they are created. You can only specify a single value for * workerGroup in the call to PollForTask. There are * no wildcard values permitted in workerGroup, the string * must be an exact, case-sensitive, match. * * @return A reference to this updated object so that method calls can be chained * together. */ public PollForTaskRequest withWorkerGroup(String workerGroup) { this.workerGroup = workerGroup; return this; } /** * The public DNS name of the calling task runner. *

* Constraints:
* Length: 1 - 1024
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
* * @return The public DNS name of the calling task runner. */ public String getHostname() { return hostname; } /** * The public DNS name of the calling task runner. *

* Constraints:
* Length: 1 - 1024
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
* * @param hostname The public DNS name of the calling task runner. */ public void setHostname(String hostname) { this.hostname = hostname; } /** * The public DNS name of the calling task runner. *

* Returns a reference to this object so that method calls can be chained together. *

* Constraints:
* Length: 1 - 1024
* Pattern: [\u0020-\uD7FF\uE000-\uFFFD\uD800\uDC00-\uDBFF\uDFFF\r\n\t]*
* * @param hostname The public DNS name of the calling task runner. * * @return A reference to this updated object so that method calls can be chained * together. */ public PollForTaskRequest withHostname(String hostname) { this.hostname = hostname; return this; } /** * Identity information for the Amazon EC2 instance that is hosting the * task runner. You can get this value by calling the URI, * http://169.254.169.254/latest/meta-data/instance-id, from * the EC2 instance. For more information, go to Instance * Metadata in the Amazon Elastic Compute Cloud User Guide. * Passing in this value proves that your task runner is running on an * EC2 instance, and ensures the proper AWS Data Pipeline service charges * are applied to your pipeline. * * @return Identity information for the Amazon EC2 instance that is hosting the * task runner. You can get this value by calling the URI, * http://169.254.169.254/latest/meta-data/instance-id, from * the EC2 instance. For more information, go to Instance * Metadata in the Amazon Elastic Compute Cloud User Guide. * Passing in this value proves that your task runner is running on an * EC2 instance, and ensures the proper AWS Data Pipeline service charges * are applied to your pipeline. */ public InstanceIdentity getInstanceIdentity() { return instanceIdentity; } /** * Identity information for the Amazon EC2 instance that is hosting the * task runner. You can get this value by calling the URI, * http://169.254.169.254/latest/meta-data/instance-id, from * the EC2 instance. For more information, go to Instance * Metadata in the Amazon Elastic Compute Cloud User Guide. * Passing in this value proves that your task runner is running on an * EC2 instance, and ensures the proper AWS Data Pipeline service charges * are applied to your pipeline. * * @param instanceIdentity Identity information for the Amazon EC2 instance that is hosting the * task runner. You can get this value by calling the URI, * http://169.254.169.254/latest/meta-data/instance-id, from * the EC2 instance. For more information, go to Instance * Metadata in the Amazon Elastic Compute Cloud User Guide. * Passing in this value proves that your task runner is running on an * EC2 instance, and ensures the proper AWS Data Pipeline service charges * are applied to your pipeline. */ public void setInstanceIdentity(InstanceIdentity instanceIdentity) { this.instanceIdentity = instanceIdentity; } /** * Identity information for the Amazon EC2 instance that is hosting the * task runner. You can get this value by calling the URI, * http://169.254.169.254/latest/meta-data/instance-id, from * the EC2 instance. For more information, go to Instance * Metadata in the Amazon Elastic Compute Cloud User Guide. * Passing in this value proves that your task runner is running on an * EC2 instance, and ensures the proper AWS Data Pipeline service charges * are applied to your pipeline. *

* Returns a reference to this object so that method calls can be chained together. * * @param instanceIdentity Identity information for the Amazon EC2 instance that is hosting the * task runner. You can get this value by calling the URI, * http://169.254.169.254/latest/meta-data/instance-id, from * the EC2 instance. For more information, go to Instance * Metadata in the Amazon Elastic Compute Cloud User Guide. * Passing in this value proves that your task runner is running on an * EC2 instance, and ensures the proper AWS Data Pipeline service charges * are applied to your pipeline. * * @return A reference to this updated object so that method calls can be chained * together. */ public PollForTaskRequest withInstanceIdentity(InstanceIdentity instanceIdentity) { this.instanceIdentity = instanceIdentity; return this; } /** * Returns a string representation of this object; useful for testing and * debugging. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getWorkerGroup() != null) sb.append("WorkerGroup: " + getWorkerGroup() + ","); if (getHostname() != null) sb.append("Hostname: " + getHostname() + ","); if (getInstanceIdentity() != null) sb.append("InstanceIdentity: " + getInstanceIdentity() ); sb.append("}"); return sb.toString(); } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getWorkerGroup() == null) ? 0 : getWorkerGroup().hashCode()); hashCode = prime * hashCode + ((getHostname() == null) ? 0 : getHostname().hashCode()); hashCode = prime * hashCode + ((getInstanceIdentity() == null) ? 0 : getInstanceIdentity().hashCode()); return hashCode; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof PollForTaskRequest == false) return false; PollForTaskRequest other = (PollForTaskRequest)obj; if (other.getWorkerGroup() == null ^ this.getWorkerGroup() == null) return false; if (other.getWorkerGroup() != null && other.getWorkerGroup().equals(this.getWorkerGroup()) == false) return false; if (other.getHostname() == null ^ this.getHostname() == null) return false; if (other.getHostname() != null && other.getHostname().equals(this.getHostname()) == false) return false; if (other.getInstanceIdentity() == null ^ this.getInstanceIdentity() == null) return false; if (other.getInstanceIdentity() != null && other.getInstanceIdentity().equals(this.getInstanceIdentity()) == false) return false; return true; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy