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

software.amazon.awssdk.services.ecs.model.PlacementConstraint Maven / Gradle / Ivy

Go to download

The AWS Java SDK for the Amazon EC2 Container Service holds the client classes that are used for communicating with the Amazon EC2 Container Service

There is a newer version: 2.30.1
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.ecs.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;

/**
 * 

* An object representing a constraint on task placement. For more information, see Task Placement * Constraints in the Amazon Elastic Container Service Developer Guide. *

* *

* If you are using the Fargate launch type, task placement constraints are not supported. *

*
*/ @Generated("software.amazon.awssdk:codegen") public final class PlacementConstraint implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField TYPE_FIELD = SdkField. builder(MarshallingType.STRING).memberName("type") .getter(getter(PlacementConstraint::typeAsString)).setter(setter(Builder::type)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("type").build()).build(); private static final SdkField EXPRESSION_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("expression").getter(getter(PlacementConstraint::expression)).setter(setter(Builder::expression)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("expression").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(TYPE_FIELD, EXPRESSION_FIELD)); private static final long serialVersionUID = 1L; private final String type; private final String expression; private PlacementConstraint(BuilderImpl builder) { this.type = builder.type; this.expression = builder.expression; } /** *

* The type of constraint. Use distinctInstance to ensure that each task in a particular group is * running on a different container instance. Use memberOf to restrict the selection to a group of * valid candidates. *

*

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

* * @return The type of constraint. Use distinctInstance to ensure that each task in a particular group * is running on a different container instance. Use memberOf to restrict the selection to a * group of valid candidates. * @see PlacementConstraintType */ public final PlacementConstraintType type() { return PlacementConstraintType.fromValue(type); } /** *

* The type of constraint. Use distinctInstance to ensure that each task in a particular group is * running on a different container instance. Use memberOf to restrict the selection to a group of * valid candidates. *

*

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

* * @return The type of constraint. Use distinctInstance to ensure that each task in a particular group * is running on a different container instance. Use memberOf to restrict the selection to a * group of valid candidates. * @see PlacementConstraintType */ public final String typeAsString() { return type; } /** *

* A cluster query language expression to apply to the constraint. You cannot specify an expression if the * constraint type is distinctInstance. For more information, see Cluster Query * Language in the Amazon Elastic Container Service Developer Guide. *

* * @return A cluster query language expression to apply to the constraint. You cannot specify an expression if the * constraint type is distinctInstance. For more information, see Cluster * Query Language in the Amazon Elastic Container Service Developer Guide. */ public final String expression() { return expression; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(typeAsString()); hashCode = 31 * hashCode + Objects.hashCode(expression()); return hashCode; } @Override public final boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof PlacementConstraint)) { return false; } PlacementConstraint other = (PlacementConstraint) obj; return Objects.equals(typeAsString(), other.typeAsString()) && Objects.equals(expression(), other.expression()); } /** * 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 final String toString() { return ToString.builder("PlacementConstraint").add("Type", typeAsString()).add("Expression", expression()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "type": return Optional.ofNullable(clazz.cast(typeAsString())); case "expression": return Optional.ofNullable(clazz.cast(expression())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((PlacementConstraint) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* The type of constraint. Use distinctInstance to ensure that each task in a particular group is * running on a different container instance. Use memberOf to restrict the selection to a group of * valid candidates. *

* * @param type * The type of constraint. Use distinctInstance to ensure that each task in a particular * group is running on a different container instance. Use memberOf to restrict the * selection to a group of valid candidates. * @see PlacementConstraintType * @return Returns a reference to this object so that method calls can be chained together. * @see PlacementConstraintType */ Builder type(String type); /** *

* The type of constraint. Use distinctInstance to ensure that each task in a particular group is * running on a different container instance. Use memberOf to restrict the selection to a group of * valid candidates. *

* * @param type * The type of constraint. Use distinctInstance to ensure that each task in a particular * group is running on a different container instance. Use memberOf to restrict the * selection to a group of valid candidates. * @see PlacementConstraintType * @return Returns a reference to this object so that method calls can be chained together. * @see PlacementConstraintType */ Builder type(PlacementConstraintType type); /** *

* A cluster query language expression to apply to the constraint. You cannot specify an expression if the * constraint type is distinctInstance. For more information, see Cluster Query * Language in the Amazon Elastic Container Service Developer Guide. *

* * @param expression * A cluster query language expression to apply to the constraint. You cannot specify an expression if * the constraint type is distinctInstance. For more information, see Cluster * Query Language in the Amazon Elastic Container Service Developer Guide. * @return Returns a reference to this object so that method calls can be chained together. */ Builder expression(String expression); } static final class BuilderImpl implements Builder { private String type; private String expression; private BuilderImpl() { } private BuilderImpl(PlacementConstraint model) { type(model.type); expression(model.expression); } public final String getType() { return type; } @Override public final Builder type(String type) { this.type = type; return this; } @Override public final Builder type(PlacementConstraintType type) { this.type(type == null ? null : type.toString()); return this; } public final void setType(String type) { this.type = type; } public final String getExpression() { return expression; } @Override public final Builder expression(String expression) { this.expression = expression; return this; } public final void setExpression(String expression) { this.expression = expression; } @Override public PlacementConstraint build() { return new PlacementConstraint(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy