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

com.amazonaws.services.backup.model.Conditions Maven / Gradle / Ivy

/*
 * Copyright 2017-2022 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.backup.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* Contains information about which resources to include or exclude from a backup plan using their tags. Conditions are * case sensitive. *

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

* Filters the values of your tagged resources for only those resources that you tagged with the same value. Also * called "exact matching." *

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

* Filters the values of your tagged resources for only those resources that you tagged that do not have the same * value. Also called "negated matching." *

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

* Filters the values of your tagged resources for matching tag values with the use of a wildcard character (*) * anywhere in the string. For example, "prod*" or "*rod*" matches the tag value "production". *

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

* Filters the values of your tagged resources for non-matching tag values with the use of a wildcard character (*) * anywhere in the string. *

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

* Filters the values of your tagged resources for only those resources that you tagged with the same value. Also * called "exact matching." *

* * @return Filters the values of your tagged resources for only those resources that you tagged with the same value. * Also called "exact matching." */ public java.util.List getStringEquals() { return stringEquals; } /** *

* Filters the values of your tagged resources for only those resources that you tagged with the same value. Also * called "exact matching." *

* * @param stringEquals * Filters the values of your tagged resources for only those resources that you tagged with the same value. * Also called "exact matching." */ public void setStringEquals(java.util.Collection stringEquals) { if (stringEquals == null) { this.stringEquals = null; return; } this.stringEquals = new java.util.ArrayList(stringEquals); } /** *

* Filters the values of your tagged resources for only those resources that you tagged with the same value. Also * called "exact matching." *

*

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

* * @param stringEquals * Filters the values of your tagged resources for only those resources that you tagged with the same value. * Also called "exact matching." * @return Returns a reference to this object so that method calls can be chained together. */ public Conditions withStringEquals(ConditionParameter... stringEquals) { if (this.stringEquals == null) { setStringEquals(new java.util.ArrayList(stringEquals.length)); } for (ConditionParameter ele : stringEquals) { this.stringEquals.add(ele); } return this; } /** *

* Filters the values of your tagged resources for only those resources that you tagged with the same value. Also * called "exact matching." *

* * @param stringEquals * Filters the values of your tagged resources for only those resources that you tagged with the same value. * Also called "exact matching." * @return Returns a reference to this object so that method calls can be chained together. */ public Conditions withStringEquals(java.util.Collection stringEquals) { setStringEquals(stringEquals); return this; } /** *

* Filters the values of your tagged resources for only those resources that you tagged that do not have the same * value. Also called "negated matching." *

* * @return Filters the values of your tagged resources for only those resources that you tagged that do not have the * same value. Also called "negated matching." */ public java.util.List getStringNotEquals() { return stringNotEquals; } /** *

* Filters the values of your tagged resources for only those resources that you tagged that do not have the same * value. Also called "negated matching." *

* * @param stringNotEquals * Filters the values of your tagged resources for only those resources that you tagged that do not have the * same value. Also called "negated matching." */ public void setStringNotEquals(java.util.Collection stringNotEquals) { if (stringNotEquals == null) { this.stringNotEquals = null; return; } this.stringNotEquals = new java.util.ArrayList(stringNotEquals); } /** *

* Filters the values of your tagged resources for only those resources that you tagged that do not have the same * value. Also called "negated matching." *

*

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

* * @param stringNotEquals * Filters the values of your tagged resources for only those resources that you tagged that do not have the * same value. Also called "negated matching." * @return Returns a reference to this object so that method calls can be chained together. */ public Conditions withStringNotEquals(ConditionParameter... stringNotEquals) { if (this.stringNotEquals == null) { setStringNotEquals(new java.util.ArrayList(stringNotEquals.length)); } for (ConditionParameter ele : stringNotEquals) { this.stringNotEquals.add(ele); } return this; } /** *

* Filters the values of your tagged resources for only those resources that you tagged that do not have the same * value. Also called "negated matching." *

* * @param stringNotEquals * Filters the values of your tagged resources for only those resources that you tagged that do not have the * same value. Also called "negated matching." * @return Returns a reference to this object so that method calls can be chained together. */ public Conditions withStringNotEquals(java.util.Collection stringNotEquals) { setStringNotEquals(stringNotEquals); return this; } /** *

* Filters the values of your tagged resources for matching tag values with the use of a wildcard character (*) * anywhere in the string. For example, "prod*" or "*rod*" matches the tag value "production". *

* * @return Filters the values of your tagged resources for matching tag values with the use of a wildcard character * (*) anywhere in the string. For example, "prod*" or "*rod*" matches the tag value "production". */ public java.util.List getStringLike() { return stringLike; } /** *

* Filters the values of your tagged resources for matching tag values with the use of a wildcard character (*) * anywhere in the string. For example, "prod*" or "*rod*" matches the tag value "production". *

* * @param stringLike * Filters the values of your tagged resources for matching tag values with the use of a wildcard character * (*) anywhere in the string. For example, "prod*" or "*rod*" matches the tag value "production". */ public void setStringLike(java.util.Collection stringLike) { if (stringLike == null) { this.stringLike = null; return; } this.stringLike = new java.util.ArrayList(stringLike); } /** *

* Filters the values of your tagged resources for matching tag values with the use of a wildcard character (*) * anywhere in the string. For example, "prod*" or "*rod*" matches the tag value "production". *

*

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

* * @param stringLike * Filters the values of your tagged resources for matching tag values with the use of a wildcard character * (*) anywhere in the string. For example, "prod*" or "*rod*" matches the tag value "production". * @return Returns a reference to this object so that method calls can be chained together. */ public Conditions withStringLike(ConditionParameter... stringLike) { if (this.stringLike == null) { setStringLike(new java.util.ArrayList(stringLike.length)); } for (ConditionParameter ele : stringLike) { this.stringLike.add(ele); } return this; } /** *

* Filters the values of your tagged resources for matching tag values with the use of a wildcard character (*) * anywhere in the string. For example, "prod*" or "*rod*" matches the tag value "production". *

* * @param stringLike * Filters the values of your tagged resources for matching tag values with the use of a wildcard character * (*) anywhere in the string. For example, "prod*" or "*rod*" matches the tag value "production". * @return Returns a reference to this object so that method calls can be chained together. */ public Conditions withStringLike(java.util.Collection stringLike) { setStringLike(stringLike); return this; } /** *

* Filters the values of your tagged resources for non-matching tag values with the use of a wildcard character (*) * anywhere in the string. *

* * @return Filters the values of your tagged resources for non-matching tag values with the use of a wildcard * character (*) anywhere in the string. */ public java.util.List getStringNotLike() { return stringNotLike; } /** *

* Filters the values of your tagged resources for non-matching tag values with the use of a wildcard character (*) * anywhere in the string. *

* * @param stringNotLike * Filters the values of your tagged resources for non-matching tag values with the use of a wildcard * character (*) anywhere in the string. */ public void setStringNotLike(java.util.Collection stringNotLike) { if (stringNotLike == null) { this.stringNotLike = null; return; } this.stringNotLike = new java.util.ArrayList(stringNotLike); } /** *

* Filters the values of your tagged resources for non-matching tag values with the use of a wildcard character (*) * anywhere in the string. *

*

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

* * @param stringNotLike * Filters the values of your tagged resources for non-matching tag values with the use of a wildcard * character (*) anywhere in the string. * @return Returns a reference to this object so that method calls can be chained together. */ public Conditions withStringNotLike(ConditionParameter... stringNotLike) { if (this.stringNotLike == null) { setStringNotLike(new java.util.ArrayList(stringNotLike.length)); } for (ConditionParameter ele : stringNotLike) { this.stringNotLike.add(ele); } return this; } /** *

* Filters the values of your tagged resources for non-matching tag values with the use of a wildcard character (*) * anywhere in the string. *

* * @param stringNotLike * Filters the values of your tagged resources for non-matching tag values with the use of a wildcard * character (*) anywhere in the string. * @return Returns a reference to this object so that method calls can be chained together. */ public Conditions withStringNotLike(java.util.Collection stringNotLike) { setStringNotLike(stringNotLike); 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 (getStringEquals() != null) sb.append("StringEquals: ").append(getStringEquals()).append(","); if (getStringNotEquals() != null) sb.append("StringNotEquals: ").append(getStringNotEquals()).append(","); if (getStringLike() != null) sb.append("StringLike: ").append(getStringLike()).append(","); if (getStringNotLike() != null) sb.append("StringNotLike: ").append(getStringNotLike()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof Conditions == false) return false; Conditions other = (Conditions) obj; if (other.getStringEquals() == null ^ this.getStringEquals() == null) return false; if (other.getStringEquals() != null && other.getStringEquals().equals(this.getStringEquals()) == false) return false; if (other.getStringNotEquals() == null ^ this.getStringNotEquals() == null) return false; if (other.getStringNotEquals() != null && other.getStringNotEquals().equals(this.getStringNotEquals()) == false) return false; if (other.getStringLike() == null ^ this.getStringLike() == null) return false; if (other.getStringLike() != null && other.getStringLike().equals(this.getStringLike()) == false) return false; if (other.getStringNotLike() == null ^ this.getStringNotLike() == null) return false; if (other.getStringNotLike() != null && other.getStringNotLike().equals(this.getStringNotLike()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getStringEquals() == null) ? 0 : getStringEquals().hashCode()); hashCode = prime * hashCode + ((getStringNotEquals() == null) ? 0 : getStringNotEquals().hashCode()); hashCode = prime * hashCode + ((getStringLike() == null) ? 0 : getStringLike().hashCode()); hashCode = prime * hashCode + ((getStringNotLike() == null) ? 0 : getStringNotLike().hashCode()); return hashCode; } @Override public Conditions clone() { try { return (Conditions) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.backup.model.transform.ConditionsMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy