software.amazon.awssdk.services.kinesisanalytics.model.AddApplicationOutputRequest 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 AddApplicationOutputRequest extends KinesisAnalyticsRequest implements
ToCopyableBuilder {
private final String applicationName;
private final Long currentApplicationVersionId;
private final Output output;
private AddApplicationOutputRequest(BuilderImpl builder) {
super(builder);
this.applicationName = builder.applicationName;
this.currentApplicationVersionId = builder.currentApplicationVersionId;
this.output = builder.output;
}
/**
*
* Name of the application to which you want to add the output configuration.
*
*
* @return Name of the application to which you want to add the output configuration.
*/
public String applicationName() {
return applicationName;
}
/**
*
* Version of the application to which you want add the output configuration. 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 Version of the application to which you want add the output configuration. 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;
}
/**
*
* An array of objects, each describing one output configuration. In the output configuration, you specify the name
* of an in-application stream, a destination (that is, an Amazon Kinesis stream or an Amazon Kinesis Firehose
* delivery stream), and record the formation to use when writing to the destination.
*
*
* @return An array of objects, each describing one output configuration. In the output configuration, you specify
* the name of an in-application stream, a destination (that is, an Amazon Kinesis stream or an Amazon
* Kinesis Firehose delivery stream), and record the formation to use when writing to the destination.
*/
public Output output() {
return output;
}
@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(output());
return hashCode;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof AddApplicationOutputRequest)) {
return false;
}
AddApplicationOutputRequest other = (AddApplicationOutputRequest) obj;
return Objects.equals(applicationName(), other.applicationName())
&& Objects.equals(currentApplicationVersionId(), other.currentApplicationVersionId())
&& Objects.equals(output(), other.output());
}
@Override
public String toString() {
return ToString.builder("AddApplicationOutputRequest").add("ApplicationName", applicationName())
.add("CurrentApplicationVersionId", currentApplicationVersionId()).add("Output", output()).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 "Output":
return Optional.of(clazz.cast(output()));
default:
return Optional.empty();
}
}
public interface Builder extends KinesisAnalyticsRequest.Builder, CopyableBuilder {
/**
*
* Name of the application to which you want to add the output configuration.
*
*
* @param applicationName
* Name of the application to which you want to add the output configuration.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder applicationName(String applicationName);
/**
*
* Version of the application to which you want add the output configuration. 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
* Version of the application to which you want add the output configuration. 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);
/**
*
* An array of objects, each describing one output configuration. In the output configuration, you specify the
* name of an in-application stream, a destination (that is, an Amazon Kinesis stream or an Amazon Kinesis
* Firehose delivery stream), and record the formation to use when writing to the destination.
*
*
* @param output
* An array of objects, each describing one output configuration. In the output configuration, you
* specify the name of an in-application stream, a destination (that is, an Amazon Kinesis stream or an
* Amazon Kinesis Firehose delivery stream), and record the formation to use when writing to the
* destination.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder output(Output output);
/**
*
* An array of objects, each describing one output configuration. In the output configuration, you specify the
* name of an in-application stream, a destination (that is, an Amazon Kinesis stream or an Amazon Kinesis
* Firehose delivery stream), and record the formation to use when writing to the destination.
*
* This is a convenience that creates an instance of the {@link Output.Builder} avoiding the need to create one
* manually via {@link Output#builder()}.
*
* When the {@link Consumer} completes, {@link Output.Builder#build()} is called immediately and its result is
* passed to {@link #output(Output)}.
*
* @param output
* a consumer that will call methods on {@link Output.Builder}
* @return Returns a reference to this object so that method calls can be chained together.
* @see #output(Output)
*/
default Builder output(Consumer output) {
return output(Output.builder().apply(output).build());
}
@Override
Builder requestOverrideConfig(AwsRequestOverrideConfig awsRequestOverrideConfig);
}
static final class BuilderImpl extends KinesisAnalyticsRequest.BuilderImpl implements Builder {
private String applicationName;
private Long currentApplicationVersionId;
private Output output;
private BuilderImpl() {
}
private BuilderImpl(AddApplicationOutputRequest model) {
applicationName(model.applicationName);
currentApplicationVersionId(model.currentApplicationVersionId);
output(model.output);
}
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 Output.Builder getOutput() {
return output != null ? output.toBuilder() : null;
}
@Override
public final Builder output(Output output) {
this.output = output;
return this;
}
public final void setOutput(Output.BuilderImpl output) {
this.output = output != null ? output.build() : null;
}
@Override
public Builder requestOverrideConfig(AwsRequestOverrideConfig awsRequestOverrideConfig) {
super.requestOverrideConfig(awsRequestOverrideConfig);
return this;
}
@Override
public Builder requestOverrideConfig(Consumer builderConsumer) {
super.requestOverrideConfig(builderConsumer);
return this;
}
@Override
public AddApplicationOutputRequest build() {
return new AddApplicationOutputRequest(this);
}
}
}