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

software.amazon.awssdk.services.backup.model.Condition Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Backup module holds the client classes that are used for communicating with Backup.

There is a newer version: 2.29.39
Show newest version
/*
 * Copyright 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 software.amazon.awssdk.services.backup.model;

import java.io.Serializable;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * 

* Contains an array of triplets made up of a condition type (such as StringEquals), a key, and a value. * Conditions are used to filter resources in a selection that is assigned to a backup plan. *

*/ @Generated("software.amazon.awssdk:codegen") public final class Condition implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField CONDITION_TYPE_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(Condition::conditionTypeAsString)).setter(setter(Builder::conditionType)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ConditionType").build()).build(); private static final SdkField CONDITION_KEY_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(Condition::conditionKey)).setter(setter(Builder::conditionKey)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ConditionKey").build()).build(); private static final SdkField CONDITION_VALUE_FIELD = SdkField. builder(MarshallingType.STRING) .getter(getter(Condition::conditionValue)).setter(setter(Builder::conditionValue)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ConditionValue").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(CONDITION_TYPE_FIELD, CONDITION_KEY_FIELD, CONDITION_VALUE_FIELD)); private static final long serialVersionUID = 1L; private final String conditionType; private final String conditionKey; private final String conditionValue; private Condition(BuilderImpl builder) { this.conditionType = builder.conditionType; this.conditionKey = builder.conditionKey; this.conditionValue = builder.conditionValue; } /** *

* An operation, such as StringEquals, that is applied to a key-value pair used to filter resources in * a selection. *

*

* If the service returns an enum value that is not available in the current SDK version, {@link #conditionType} * will return {@link ConditionType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #conditionTypeAsString}. *

* * @return An operation, such as StringEquals, that is applied to a key-value pair used to filter * resources in a selection. * @see ConditionType */ public ConditionType conditionType() { return ConditionType.fromValue(conditionType); } /** *

* An operation, such as StringEquals, that is applied to a key-value pair used to filter resources in * a selection. *

*

* If the service returns an enum value that is not available in the current SDK version, {@link #conditionType} * will return {@link ConditionType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #conditionTypeAsString}. *

* * @return An operation, such as StringEquals, that is applied to a key-value pair used to filter * resources in a selection. * @see ConditionType */ public String conditionTypeAsString() { return conditionType; } /** *

* The key in a key-value pair. For example, in "ec2:ResourceTag/Department": "accounting", * "ec2:ResourceTag/Department" is the key. *

* * @return The key in a key-value pair. For example, in "ec2:ResourceTag/Department": "accounting", * "ec2:ResourceTag/Department" is the key. */ public String conditionKey() { return conditionKey; } /** *

* The value in a key-value pair. For example, in "ec2:ResourceTag/Department": "accounting", * "accounting" is the value. *

* * @return The value in a key-value pair. For example, in "ec2:ResourceTag/Department": "accounting", * "accounting" is the value. */ public String conditionValue() { return conditionValue; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(conditionTypeAsString()); hashCode = 31 * hashCode + Objects.hashCode(conditionKey()); hashCode = 31 * hashCode + Objects.hashCode(conditionValue()); return hashCode; } @Override public boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof Condition)) { return false; } Condition other = (Condition) obj; return Objects.equals(conditionTypeAsString(), other.conditionTypeAsString()) && Objects.equals(conditionKey(), other.conditionKey()) && Objects.equals(conditionValue(), other.conditionValue()); } /** * 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. */ @Override public String toString() { return ToString.builder("Condition").add("ConditionType", conditionTypeAsString()).add("ConditionKey", conditionKey()) .add("ConditionValue", conditionValue()).build(); } public Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "ConditionType": return Optional.ofNullable(clazz.cast(conditionTypeAsString())); case "ConditionKey": return Optional.ofNullable(clazz.cast(conditionKey())); case "ConditionValue": return Optional.ofNullable(clazz.cast(conditionValue())); default: return Optional.empty(); } } @Override public List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((Condition) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* An operation, such as StringEquals, that is applied to a key-value pair used to filter resources * in a selection. *

* * @param conditionType * An operation, such as StringEquals, that is applied to a key-value pair used to filter * resources in a selection. * @see ConditionType * @return Returns a reference to this object so that method calls can be chained together. * @see ConditionType */ Builder conditionType(String conditionType); /** *

* An operation, such as StringEquals, that is applied to a key-value pair used to filter resources * in a selection. *

* * @param conditionType * An operation, such as StringEquals, that is applied to a key-value pair used to filter * resources in a selection. * @see ConditionType * @return Returns a reference to this object so that method calls can be chained together. * @see ConditionType */ Builder conditionType(ConditionType conditionType); /** *

* The key in a key-value pair. For example, in "ec2:ResourceTag/Department": "accounting", * "ec2:ResourceTag/Department" is the key. *

* * @param conditionKey * The key in a key-value pair. For example, in "ec2:ResourceTag/Department": "accounting", * "ec2:ResourceTag/Department" is the key. * @return Returns a reference to this object so that method calls can be chained together. */ Builder conditionKey(String conditionKey); /** *

* The value in a key-value pair. For example, in "ec2:ResourceTag/Department": "accounting", * "accounting" is the value. *

* * @param conditionValue * The value in a key-value pair. For example, in "ec2:ResourceTag/Department": "accounting" * , "accounting" is the value. * @return Returns a reference to this object so that method calls can be chained together. */ Builder conditionValue(String conditionValue); } static final class BuilderImpl implements Builder { private String conditionType; private String conditionKey; private String conditionValue; private BuilderImpl() { } private BuilderImpl(Condition model) { conditionType(model.conditionType); conditionKey(model.conditionKey); conditionValue(model.conditionValue); } public final String getConditionType() { return conditionType; } @Override public final Builder conditionType(String conditionType) { this.conditionType = conditionType; return this; } @Override public final Builder conditionType(ConditionType conditionType) { this.conditionType(conditionType == null ? null : conditionType.toString()); return this; } public final void setConditionType(String conditionType) { this.conditionType = conditionType; } public final String getConditionKey() { return conditionKey; } @Override public final Builder conditionKey(String conditionKey) { this.conditionKey = conditionKey; return this; } public final void setConditionKey(String conditionKey) { this.conditionKey = conditionKey; } public final String getConditionValue() { return conditionValue; } @Override public final Builder conditionValue(String conditionValue) { this.conditionValue = conditionValue; return this; } public final void setConditionValue(String conditionValue) { this.conditionValue = conditionValue; } @Override public Condition build() { return new Condition(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy