/* * Copyright 2018-2023 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.savingsplans.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.protocol.StructuredPojo; import com.amazonaws.protocol.ProtocolMarshaller; /** *
* Information about a Savings Plan offering. *
* * @see AWS * API Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class SavingsPlanOffering implements Serializable, Cloneable, StructuredPojo { /** ** The ID of the offering. *
*/ private String offeringId; /** ** The product type. *
*/ private java.util.List* The plan type. *
*/ private String planType; /** ** The description. *
*/ private String description; /** ** The payment option. *
*/ private String paymentOption; /** ** The duration, in seconds. *
*/ private Long durationSeconds; /** ** The currency. *
*/ private String currency; /** ** The service. *
*/ private String serviceCode; /** ** The usage details of the line item in the billing report. *
*/ private String usageType; /** ** The specific AWS operation for the line item in the billing report. *
*/ private String operation; /** ** The properties. *
*/ private java.util.List* The ID of the offering. *
* * @param offeringId * The ID of the offering. */ public void setOfferingId(String offeringId) { this.offeringId = offeringId; } /** ** The ID of the offering. *
* * @return The ID of the offering. */ public String getOfferingId() { return this.offeringId; } /** ** The ID of the offering. *
* * @param offeringId * The ID of the offering. * @return Returns a reference to this object so that method calls can be chained together. */ public SavingsPlanOffering withOfferingId(String offeringId) { setOfferingId(offeringId); return this; } /** ** The product type. *
* * @return The product type. * @see SavingsPlanProductType */ public java.util.List* The product type. *
* * @param productTypes * The product type. * @see SavingsPlanProductType */ public void setProductTypes(java.util.Collection* The product type. *
** NOTE: This method appends the values to the existing list (if any). Use * {@link #setProductTypes(java.util.Collection)} or {@link #withProductTypes(java.util.Collection)} if you want to * override the existing values. *
* * @param productTypes * The product type. * @return Returns a reference to this object so that method calls can be chained together. * @see SavingsPlanProductType */ public SavingsPlanOffering withProductTypes(String... productTypes) { if (this.productTypes == null) { setProductTypes(new java.util.ArrayList* The product type. *
* * @param productTypes * The product type. * @return Returns a reference to this object so that method calls can be chained together. * @see SavingsPlanProductType */ public SavingsPlanOffering withProductTypes(java.util.Collection* The product type. *
* * @param productTypes * The product type. * @return Returns a reference to this object so that method calls can be chained together. * @see SavingsPlanProductType */ public SavingsPlanOffering withProductTypes(SavingsPlanProductType... productTypes) { java.util.ArrayList* The plan type. *
* * @param planType * The plan type. * @see SavingsPlanType */ public void setPlanType(String planType) { this.planType = planType; } /** ** The plan type. *
* * @return The plan type. * @see SavingsPlanType */ public String getPlanType() { return this.planType; } /** ** The plan type. *
* * @param planType * The plan type. * @return Returns a reference to this object so that method calls can be chained together. * @see SavingsPlanType */ public SavingsPlanOffering withPlanType(String planType) { setPlanType(planType); return this; } /** ** The plan type. *
* * @param planType * The plan type. * @return Returns a reference to this object so that method calls can be chained together. * @see SavingsPlanType */ public SavingsPlanOffering withPlanType(SavingsPlanType planType) { this.planType = planType.toString(); return this; } /** ** The description. *
* * @param description * The description. */ public void setDescription(String description) { this.description = description; } /** ** The description. *
* * @return The description. */ public String getDescription() { return this.description; } /** ** The description. *
* * @param description * The description. * @return Returns a reference to this object so that method calls can be chained together. */ public SavingsPlanOffering withDescription(String description) { setDescription(description); return this; } /** ** The payment option. *
* * @param paymentOption * The payment option. * @see SavingsPlanPaymentOption */ public void setPaymentOption(String paymentOption) { this.paymentOption = paymentOption; } /** ** The payment option. *
* * @return The payment option. * @see SavingsPlanPaymentOption */ public String getPaymentOption() { return this.paymentOption; } /** ** The payment option. *
* * @param paymentOption * The payment option. * @return Returns a reference to this object so that method calls can be chained together. * @see SavingsPlanPaymentOption */ public SavingsPlanOffering withPaymentOption(String paymentOption) { setPaymentOption(paymentOption); return this; } /** ** The payment option. *
* * @param paymentOption * The payment option. * @return Returns a reference to this object so that method calls can be chained together. * @see SavingsPlanPaymentOption */ public SavingsPlanOffering withPaymentOption(SavingsPlanPaymentOption paymentOption) { this.paymentOption = paymentOption.toString(); return this; } /** ** The duration, in seconds. *
* * @param durationSeconds * The duration, in seconds. */ public void setDurationSeconds(Long durationSeconds) { this.durationSeconds = durationSeconds; } /** ** The duration, in seconds. *
* * @return The duration, in seconds. */ public Long getDurationSeconds() { return this.durationSeconds; } /** ** The duration, in seconds. *
* * @param durationSeconds * The duration, in seconds. * @return Returns a reference to this object so that method calls can be chained together. */ public SavingsPlanOffering withDurationSeconds(Long durationSeconds) { setDurationSeconds(durationSeconds); return this; } /** ** The currency. *
* * @param currency * The currency. * @see CurrencyCode */ public void setCurrency(String currency) { this.currency = currency; } /** ** The currency. *
* * @return The currency. * @see CurrencyCode */ public String getCurrency() { return this.currency; } /** ** The currency. *
* * @param currency * The currency. * @return Returns a reference to this object so that method calls can be chained together. * @see CurrencyCode */ public SavingsPlanOffering withCurrency(String currency) { setCurrency(currency); return this; } /** ** The currency. *
* * @param currency * The currency. * @return Returns a reference to this object so that method calls can be chained together. * @see CurrencyCode */ public SavingsPlanOffering withCurrency(CurrencyCode currency) { this.currency = currency.toString(); return this; } /** ** The service. *
* * @param serviceCode * The service. */ public void setServiceCode(String serviceCode) { this.serviceCode = serviceCode; } /** ** The service. *
* * @return The service. */ public String getServiceCode() { return this.serviceCode; } /** ** The service. *
* * @param serviceCode * The service. * @return Returns a reference to this object so that method calls can be chained together. */ public SavingsPlanOffering withServiceCode(String serviceCode) { setServiceCode(serviceCode); return this; } /** ** The usage details of the line item in the billing report. *
* * @param usageType * The usage details of the line item in the billing report. */ public void setUsageType(String usageType) { this.usageType = usageType; } /** ** The usage details of the line item in the billing report. *
* * @return The usage details of the line item in the billing report. */ public String getUsageType() { return this.usageType; } /** ** The usage details of the line item in the billing report. *
* * @param usageType * The usage details of the line item in the billing report. * @return Returns a reference to this object so that method calls can be chained together. */ public SavingsPlanOffering withUsageType(String usageType) { setUsageType(usageType); return this; } /** ** The specific AWS operation for the line item in the billing report. *
* * @param operation * The specific AWS operation for the line item in the billing report. */ public void setOperation(String operation) { this.operation = operation; } /** ** The specific AWS operation for the line item in the billing report. *
* * @return The specific AWS operation for the line item in the billing report. */ public String getOperation() { return this.operation; } /** ** The specific AWS operation for the line item in the billing report. *
* * @param operation * The specific AWS operation for the line item in the billing report. * @return Returns a reference to this object so that method calls can be chained together. */ public SavingsPlanOffering withOperation(String operation) { setOperation(operation); return this; } /** ** The properties. *
* * @return The properties. */ public java.util.List* The properties. *
* * @param properties * The properties. */ public void setProperties(java.util.Collection* The properties. *
** NOTE: This method appends the values to the existing list (if any). Use * {@link #setProperties(java.util.Collection)} or {@link #withProperties(java.util.Collection)} if you want to * override the existing values. *
* * @param properties * The properties. * @return Returns a reference to this object so that method calls can be chained together. */ public SavingsPlanOffering withProperties(SavingsPlanOfferingProperty... properties) { if (this.properties == null) { setProperties(new java.util.ArrayList* The properties. *
* * @param properties * The properties. * @return Returns a reference to this object so that method calls can be chained together. */ public SavingsPlanOffering withProperties(java.util.Collection