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

com.amazonaws.services.computeoptimizer.model.GetEC2InstanceRecommendationsRequest Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Compute Optimizer module holds the client classes that are used for communicating with AWS Compute Optimizer Service

The newest version!
/*
 * Copyright 2019-2024 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.computeoptimizer.model;

import java.io.Serializable;
import javax.annotation.Generated;

import com.amazonaws.AmazonWebServiceRequest;

/**
 * 
 * @see AWS API Documentation
 */
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class GetEC2InstanceRecommendationsRequest extends com.amazonaws.AmazonWebServiceRequest implements Serializable, Cloneable {

    /**
     * 

* The Amazon Resource Name (ARN) of the instances for which to return recommendations. *

*/ private java.util.List instanceArns; /** *

* The token to advance to the next page of instance recommendations. *

*/ private String nextToken; /** *

* The maximum number of instance recommendations to return with a single request. *

*

* To retrieve the remaining results, make another request with the returned nextToken value. *

*/ private Integer maxResults; /** *

* An array of objects to specify a filter that returns a more specific list of instance recommendations. *

*/ private java.util.List filters; /** *

* The ID of the Amazon Web Services account for which to return instance recommendations. *

*

* If your account is the management account of an organization, use this parameter to specify the member account * for which you want to return instance recommendations. *

*

* Only one account ID can be specified per request. *

*/ private java.util.List accountIds; /** *

* An object to specify the preferences for the Amazon EC2 instance recommendations to return in the response. *

*/ private RecommendationPreferences recommendationPreferences; /** *

* The Amazon Resource Name (ARN) of the instances for which to return recommendations. *

* * @return The Amazon Resource Name (ARN) of the instances for which to return recommendations. */ public java.util.List getInstanceArns() { return instanceArns; } /** *

* The Amazon Resource Name (ARN) of the instances for which to return recommendations. *

* * @param instanceArns * The Amazon Resource Name (ARN) of the instances for which to return recommendations. */ public void setInstanceArns(java.util.Collection instanceArns) { if (instanceArns == null) { this.instanceArns = null; return; } this.instanceArns = new java.util.ArrayList(instanceArns); } /** *

* The Amazon Resource Name (ARN) of the instances for which to return recommendations. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setInstanceArns(java.util.Collection)} or {@link #withInstanceArns(java.util.Collection)} if you want to * override the existing values. *

* * @param instanceArns * The Amazon Resource Name (ARN) of the instances for which to return recommendations. * @return Returns a reference to this object so that method calls can be chained together. */ public GetEC2InstanceRecommendationsRequest withInstanceArns(String... instanceArns) { if (this.instanceArns == null) { setInstanceArns(new java.util.ArrayList(instanceArns.length)); } for (String ele : instanceArns) { this.instanceArns.add(ele); } return this; } /** *

* The Amazon Resource Name (ARN) of the instances for which to return recommendations. *

* * @param instanceArns * The Amazon Resource Name (ARN) of the instances for which to return recommendations. * @return Returns a reference to this object so that method calls can be chained together. */ public GetEC2InstanceRecommendationsRequest withInstanceArns(java.util.Collection instanceArns) { setInstanceArns(instanceArns); return this; } /** *

* The token to advance to the next page of instance recommendations. *

* * @param nextToken * The token to advance to the next page of instance recommendations. */ public void setNextToken(String nextToken) { this.nextToken = nextToken; } /** *

* The token to advance to the next page of instance recommendations. *

* * @return The token to advance to the next page of instance recommendations. */ public String getNextToken() { return this.nextToken; } /** *

* The token to advance to the next page of instance recommendations. *

* * @param nextToken * The token to advance to the next page of instance recommendations. * @return Returns a reference to this object so that method calls can be chained together. */ public GetEC2InstanceRecommendationsRequest withNextToken(String nextToken) { setNextToken(nextToken); return this; } /** *

* The maximum number of instance recommendations to return with a single request. *

*

* To retrieve the remaining results, make another request with the returned nextToken value. *

* * @param maxResults * The maximum number of instance recommendations to return with a single request.

*

* To retrieve the remaining results, make another request with the returned nextToken value. */ public void setMaxResults(Integer maxResults) { this.maxResults = maxResults; } /** *

* The maximum number of instance recommendations to return with a single request. *

*

* To retrieve the remaining results, make another request with the returned nextToken value. *

* * @return The maximum number of instance recommendations to return with a single request.

*

* To retrieve the remaining results, make another request with the returned nextToken value. */ public Integer getMaxResults() { return this.maxResults; } /** *

* The maximum number of instance recommendations to return with a single request. *

*

* To retrieve the remaining results, make another request with the returned nextToken value. *

* * @param maxResults * The maximum number of instance recommendations to return with a single request.

*

* To retrieve the remaining results, make another request with the returned nextToken value. * @return Returns a reference to this object so that method calls can be chained together. */ public GetEC2InstanceRecommendationsRequest withMaxResults(Integer maxResults) { setMaxResults(maxResults); return this; } /** *

* An array of objects to specify a filter that returns a more specific list of instance recommendations. *

* * @return An array of objects to specify a filter that returns a more specific list of instance recommendations. */ public java.util.List getFilters() { return filters; } /** *

* An array of objects to specify a filter that returns a more specific list of instance recommendations. *

* * @param filters * An array of objects to specify a filter that returns a more specific list of instance recommendations. */ public void setFilters(java.util.Collection filters) { if (filters == null) { this.filters = null; return; } this.filters = new java.util.ArrayList(filters); } /** *

* An array of objects to specify a filter that returns a more specific list of instance recommendations. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setFilters(java.util.Collection)} or {@link #withFilters(java.util.Collection)} if you want to override * the existing values. *

* * @param filters * An array of objects to specify a filter that returns a more specific list of instance recommendations. * @return Returns a reference to this object so that method calls can be chained together. */ public GetEC2InstanceRecommendationsRequest withFilters(Filter... filters) { if (this.filters == null) { setFilters(new java.util.ArrayList(filters.length)); } for (Filter ele : filters) { this.filters.add(ele); } return this; } /** *

* An array of objects to specify a filter that returns a more specific list of instance recommendations. *

* * @param filters * An array of objects to specify a filter that returns a more specific list of instance recommendations. * @return Returns a reference to this object so that method calls can be chained together. */ public GetEC2InstanceRecommendationsRequest withFilters(java.util.Collection filters) { setFilters(filters); return this; } /** *

* The ID of the Amazon Web Services account for which to return instance recommendations. *

*

* If your account is the management account of an organization, use this parameter to specify the member account * for which you want to return instance recommendations. *

*

* Only one account ID can be specified per request. *

* * @return The ID of the Amazon Web Services account for which to return instance recommendations.

*

* If your account is the management account of an organization, use this parameter to specify the member * account for which you want to return instance recommendations. *

*

* Only one account ID can be specified per request. */ public java.util.List getAccountIds() { return accountIds; } /** *

* The ID of the Amazon Web Services account for which to return instance recommendations. *

*

* If your account is the management account of an organization, use this parameter to specify the member account * for which you want to return instance recommendations. *

*

* Only one account ID can be specified per request. *

* * @param accountIds * The ID of the Amazon Web Services account for which to return instance recommendations.

*

* If your account is the management account of an organization, use this parameter to specify the member * account for which you want to return instance recommendations. *

*

* Only one account ID can be specified per request. */ public void setAccountIds(java.util.Collection accountIds) { if (accountIds == null) { this.accountIds = null; return; } this.accountIds = new java.util.ArrayList(accountIds); } /** *

* The ID of the Amazon Web Services account for which to return instance recommendations. *

*

* If your account is the management account of an organization, use this parameter to specify the member account * for which you want to return instance recommendations. *

*

* Only one account ID can be specified per request. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setAccountIds(java.util.Collection)} or {@link #withAccountIds(java.util.Collection)} if you want to * override the existing values. *

* * @param accountIds * The ID of the Amazon Web Services account for which to return instance recommendations.

*

* If your account is the management account of an organization, use this parameter to specify the member * account for which you want to return instance recommendations. *

*

* Only one account ID can be specified per request. * @return Returns a reference to this object so that method calls can be chained together. */ public GetEC2InstanceRecommendationsRequest withAccountIds(String... accountIds) { if (this.accountIds == null) { setAccountIds(new java.util.ArrayList(accountIds.length)); } for (String ele : accountIds) { this.accountIds.add(ele); } return this; } /** *

* The ID of the Amazon Web Services account for which to return instance recommendations. *

*

* If your account is the management account of an organization, use this parameter to specify the member account * for which you want to return instance recommendations. *

*

* Only one account ID can be specified per request. *

* * @param accountIds * The ID of the Amazon Web Services account for which to return instance recommendations.

*

* If your account is the management account of an organization, use this parameter to specify the member * account for which you want to return instance recommendations. *

*

* Only one account ID can be specified per request. * @return Returns a reference to this object so that method calls can be chained together. */ public GetEC2InstanceRecommendationsRequest withAccountIds(java.util.Collection accountIds) { setAccountIds(accountIds); return this; } /** *

* An object to specify the preferences for the Amazon EC2 instance recommendations to return in the response. *

* * @param recommendationPreferences * An object to specify the preferences for the Amazon EC2 instance recommendations to return in the * response. */ public void setRecommendationPreferences(RecommendationPreferences recommendationPreferences) { this.recommendationPreferences = recommendationPreferences; } /** *

* An object to specify the preferences for the Amazon EC2 instance recommendations to return in the response. *

* * @return An object to specify the preferences for the Amazon EC2 instance recommendations to return in the * response. */ public RecommendationPreferences getRecommendationPreferences() { return this.recommendationPreferences; } /** *

* An object to specify the preferences for the Amazon EC2 instance recommendations to return in the response. *

* * @param recommendationPreferences * An object to specify the preferences for the Amazon EC2 instance recommendations to return in the * response. * @return Returns a reference to this object so that method calls can be chained together. */ public GetEC2InstanceRecommendationsRequest withRecommendationPreferences(RecommendationPreferences recommendationPreferences) { setRecommendationPreferences(recommendationPreferences); return this; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getInstanceArns() != null) sb.append("InstanceArns: ").append(getInstanceArns()).append(","); if (getNextToken() != null) sb.append("NextToken: ").append(getNextToken()).append(","); if (getMaxResults() != null) sb.append("MaxResults: ").append(getMaxResults()).append(","); if (getFilters() != null) sb.append("Filters: ").append(getFilters()).append(","); if (getAccountIds() != null) sb.append("AccountIds: ").append(getAccountIds()).append(","); if (getRecommendationPreferences() != null) sb.append("RecommendationPreferences: ").append(getRecommendationPreferences()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof GetEC2InstanceRecommendationsRequest == false) return false; GetEC2InstanceRecommendationsRequest other = (GetEC2InstanceRecommendationsRequest) obj; if (other.getInstanceArns() == null ^ this.getInstanceArns() == null) return false; if (other.getInstanceArns() != null && other.getInstanceArns().equals(this.getInstanceArns()) == false) return false; if (other.getNextToken() == null ^ this.getNextToken() == null) return false; if (other.getNextToken() != null && other.getNextToken().equals(this.getNextToken()) == false) return false; if (other.getMaxResults() == null ^ this.getMaxResults() == null) return false; if (other.getMaxResults() != null && other.getMaxResults().equals(this.getMaxResults()) == false) return false; if (other.getFilters() == null ^ this.getFilters() == null) return false; if (other.getFilters() != null && other.getFilters().equals(this.getFilters()) == false) return false; if (other.getAccountIds() == null ^ this.getAccountIds() == null) return false; if (other.getAccountIds() != null && other.getAccountIds().equals(this.getAccountIds()) == false) return false; if (other.getRecommendationPreferences() == null ^ this.getRecommendationPreferences() == null) return false; if (other.getRecommendationPreferences() != null && other.getRecommendationPreferences().equals(this.getRecommendationPreferences()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getInstanceArns() == null) ? 0 : getInstanceArns().hashCode()); hashCode = prime * hashCode + ((getNextToken() == null) ? 0 : getNextToken().hashCode()); hashCode = prime * hashCode + ((getMaxResults() == null) ? 0 : getMaxResults().hashCode()); hashCode = prime * hashCode + ((getFilters() == null) ? 0 : getFilters().hashCode()); hashCode = prime * hashCode + ((getAccountIds() == null) ? 0 : getAccountIds().hashCode()); hashCode = prime * hashCode + ((getRecommendationPreferences() == null) ? 0 : getRecommendationPreferences().hashCode()); return hashCode; } @Override public GetEC2InstanceRecommendationsRequest clone() { return (GetEC2InstanceRecommendationsRequest) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy