software.amazon.awssdk.services.kinesisanalytics.model.DeleteApplicationOutputRequest Maven / Gradle / Ivy
Show all versions of kinesis Show documentation
/*
* Copyright 2013-2018 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.kinesisanalytics.model;
import java.util.Objects;
import java.util.Optional;
import java.util.function.Consumer;
import javax.annotation.Generated;
import software.amazon.awssdk.core.AwsRequestOverrideConfig;
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 class DeleteApplicationOutputRequest extends KinesisAnalyticsRequest implements
ToCopyableBuilder {
private final String applicationName;
private final Long currentApplicationVersionId;
private final String outputId;
private DeleteApplicationOutputRequest(BuilderImpl builder) {
super(builder);
this.applicationName = builder.applicationName;
this.currentApplicationVersionId = builder.currentApplicationVersionId;
this.outputId = builder.outputId;
}
/**
*
* Amazon Kinesis Analytics application name.
*
*
* @return Amazon Kinesis Analytics application name.
*/
public String applicationName() {
return applicationName;
}
/**
*
* Amazon Kinesis Analytics application version. You can use the DescribeApplication operation to get the
* current application version. If the version specified is not the current version, the
* ConcurrentModificationException
is returned.
*
*
* @return Amazon Kinesis Analytics application version. You can use the DescribeApplication operation to get
* the current application version. If the version specified is not the current version, the
* ConcurrentModificationException
is returned.
*/
public Long currentApplicationVersionId() {
return currentApplicationVersionId;
}
/**
*
* The ID of the configuration to delete. Each output configuration that is added to the application, either when
* the application is created or later using the AddApplicationOutput operation, has a unique ID. You need to
* provide the ID to uniquely identify the output configuration that you want to delete from the application
* configuration. You can use the DescribeApplication operation to get the specific OutputId
.
*
*
* @return The ID of the configuration to delete. Each output configuration that is added to the application, either
* when the application is created or later using the AddApplicationOutput operation, has a unique
* ID. You need to provide the ID to uniquely identify the output configuration that you want to delete from
* the application configuration. You can use the DescribeApplication operation to get the specific
* OutputId
.
*/
public String outputId() {
return outputId;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class extends Builder> serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + Objects.hashCode(applicationName());
hashCode = 31 * hashCode + Objects.hashCode(currentApplicationVersionId());
hashCode = 31 * hashCode + Objects.hashCode(outputId());
return hashCode;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof DeleteApplicationOutputRequest)) {
return false;
}
DeleteApplicationOutputRequest other = (DeleteApplicationOutputRequest) obj;
return Objects.equals(applicationName(), other.applicationName())
&& Objects.equals(currentApplicationVersionId(), other.currentApplicationVersionId())
&& Objects.equals(outputId(), other.outputId());
}
@Override
public String toString() {
return ToString.builder("DeleteApplicationOutputRequest").add("ApplicationName", applicationName())
.add("CurrentApplicationVersionId", currentApplicationVersionId()).add("OutputId", outputId()).build();
}
public Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "ApplicationName":
return Optional.of(clazz.cast(applicationName()));
case "CurrentApplicationVersionId":
return Optional.of(clazz.cast(currentApplicationVersionId()));
case "OutputId":
return Optional.of(clazz.cast(outputId()));
default:
return Optional.empty();
}
}
public interface Builder extends KinesisAnalyticsRequest.Builder, CopyableBuilder {
/**
*
* Amazon Kinesis Analytics application name.
*
*
* @param applicationName
* Amazon Kinesis Analytics application name.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder applicationName(String applicationName);
/**
*
* Amazon Kinesis Analytics application version. You can use the DescribeApplication operation to get the
* current application version. If the version specified is not the current version, the
* ConcurrentModificationException
is returned.
*
*
* @param currentApplicationVersionId
* Amazon Kinesis Analytics application version. You can use the DescribeApplication operation to
* get the current application version. If the version specified is not the current version, the
* ConcurrentModificationException
is returned.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder currentApplicationVersionId(Long currentApplicationVersionId);
/**
*
* The ID of the configuration to delete. Each output configuration that is added to the application, either
* when the application is created or later using the AddApplicationOutput operation, has a unique ID.
* You need to provide the ID to uniquely identify the output configuration that you want to delete from the
* application configuration. You can use the DescribeApplication operation to get the specific
* OutputId
.
*
*
* @param outputId
* The ID of the configuration to delete. Each output configuration that is added to the application,
* either when the application is created or later using the AddApplicationOutput operation, has a
* unique ID. You need to provide the ID to uniquely identify the output configuration that you want to
* delete from the application configuration. You can use the DescribeApplication operation to get
* the specific OutputId
.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder outputId(String outputId);
@Override
Builder requestOverrideConfig(AwsRequestOverrideConfig awsRequestOverrideConfig);
}
static final class BuilderImpl extends KinesisAnalyticsRequest.BuilderImpl implements Builder {
private String applicationName;
private Long currentApplicationVersionId;
private String outputId;
private BuilderImpl() {
}
private BuilderImpl(DeleteApplicationOutputRequest model) {
applicationName(model.applicationName);
currentApplicationVersionId(model.currentApplicationVersionId);
outputId(model.outputId);
}
public final String getApplicationName() {
return applicationName;
}
@Override
public final Builder applicationName(String applicationName) {
this.applicationName = applicationName;
return this;
}
public final void setApplicationName(String applicationName) {
this.applicationName = applicationName;
}
public final Long getCurrentApplicationVersionId() {
return currentApplicationVersionId;
}
@Override
public final Builder currentApplicationVersionId(Long currentApplicationVersionId) {
this.currentApplicationVersionId = currentApplicationVersionId;
return this;
}
public final void setCurrentApplicationVersionId(Long currentApplicationVersionId) {
this.currentApplicationVersionId = currentApplicationVersionId;
}
public final String getOutputId() {
return outputId;
}
@Override
public final Builder outputId(String outputId) {
this.outputId = outputId;
return this;
}
public final void setOutputId(String outputId) {
this.outputId = outputId;
}
@Override
public Builder requestOverrideConfig(AwsRequestOverrideConfig awsRequestOverrideConfig) {
super.requestOverrideConfig(awsRequestOverrideConfig);
return this;
}
@Override
public Builder requestOverrideConfig(Consumer builderConsumer) {
super.requestOverrideConfig(builderConsumer);
return this;
}
@Override
public DeleteApplicationOutputRequest build() {
return new DeleteApplicationOutputRequest(this);
}
}
}