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

software.amazon.awssdk.services.lexmodelbuilding.model.CreateIntentVersionRequest Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon Lex Model Building module holds the client classes that are used for communicating with Amazon Lex Model Building Service

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.lexmodelbuilding.model;

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.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
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;

/**
 */
@Generated("software.amazon.awssdk:codegen")
public final class CreateIntentVersionRequest extends LexModelBuildingRequest implements
        ToCopyableBuilder {
    private static final SdkField NAME_FIELD = SdkField. builder(MarshallingType.STRING).memberName("name")
            .getter(getter(CreateIntentVersionRequest::name)).setter(setter(Builder::name))
            .traits(LocationTrait.builder().location(MarshallLocation.PATH).locationName("name").build()).build();

    private static final SdkField CHECKSUM_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("checksum").getter(getter(CreateIntentVersionRequest::checksum)).setter(setter(Builder::checksum))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("checksum").build()).build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(NAME_FIELD, CHECKSUM_FIELD));

    private final String name;

    private final String checksum;

    private CreateIntentVersionRequest(BuilderImpl builder) {
        super(builder);
        this.name = builder.name;
        this.checksum = builder.checksum;
    }

    /**
     * 

* The name of the intent that you want to create a new version of. The name is case sensitive. *

* * @return The name of the intent that you want to create a new version of. The name is case sensitive. */ public final String name() { return name; } /** *

* Checksum of the $LATEST version of the intent that should be used to create the new version. If you * specify a checksum and the $LATEST version of the intent has a different checksum, Amazon Lex * returns a PreconditionFailedException exception and doesn't publish a new version. If you don't * specify a checksum, Amazon Lex publishes the $LATEST version. *

* * @return Checksum of the $LATEST version of the intent that should be used to create the new version. * If you specify a checksum and the $LATEST version of the intent has a different checksum, * Amazon Lex returns a PreconditionFailedException exception and doesn't publish a new * version. If you don't specify a checksum, Amazon Lex publishes the $LATEST version. */ public final String checksum() { return checksum; } @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 + super.hashCode(); hashCode = 31 * hashCode + Objects.hashCode(name()); hashCode = 31 * hashCode + Objects.hashCode(checksum()); return hashCode; } @Override public final boolean equals(Object obj) { return super.equals(obj) && equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof CreateIntentVersionRequest)) { return false; } CreateIntentVersionRequest other = (CreateIntentVersionRequest) obj; return Objects.equals(name(), other.name()) && Objects.equals(checksum(), other.checksum()); } /** * 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("CreateIntentVersionRequest").add("Name", name()).add("Checksum", checksum()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "name": return Optional.ofNullable(clazz.cast(name())); case "checksum": return Optional.ofNullable(clazz.cast(checksum())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((CreateIntentVersionRequest) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends LexModelBuildingRequest.Builder, SdkPojo, CopyableBuilder { /** *

* The name of the intent that you want to create a new version of. The name is case sensitive. *

* * @param name * The name of the intent that you want to create a new version of. The name is case sensitive. * @return Returns a reference to this object so that method calls can be chained together. */ Builder name(String name); /** *

* Checksum of the $LATEST version of the intent that should be used to create the new version. If * you specify a checksum and the $LATEST version of the intent has a different checksum, Amazon * Lex returns a PreconditionFailedException exception and doesn't publish a new version. If you * don't specify a checksum, Amazon Lex publishes the $LATEST version. *

* * @param checksum * Checksum of the $LATEST version of the intent that should be used to create the new * version. If you specify a checksum and the $LATEST version of the intent has a different * checksum, Amazon Lex returns a PreconditionFailedException exception and doesn't publish * a new version. If you don't specify a checksum, Amazon Lex publishes the $LATEST version. * @return Returns a reference to this object so that method calls can be chained together. */ Builder checksum(String checksum); @Override Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration); @Override Builder overrideConfiguration(Consumer builderConsumer); } static final class BuilderImpl extends LexModelBuildingRequest.BuilderImpl implements Builder { private String name; private String checksum; private BuilderImpl() { } private BuilderImpl(CreateIntentVersionRequest model) { super(model); name(model.name); checksum(model.checksum); } public final String getName() { return name; } public final void setName(String name) { this.name = name; } @Override public final Builder name(String name) { this.name = name; return this; } public final String getChecksum() { return checksum; } public final void setChecksum(String checksum) { this.checksum = checksum; } @Override public final Builder checksum(String checksum) { this.checksum = checksum; return this; } @Override public Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration) { super.overrideConfiguration(overrideConfiguration); return this; } @Override public Builder overrideConfiguration(Consumer builderConsumer) { super.overrideConfiguration(builderConsumer); return this; } @Override public CreateIntentVersionRequest build() { return new CreateIntentVersionRequest(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy