software.amazon.awssdk.services.eventbridge.model.KinesisParameters Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of eventbridge Show documentation
Show all versions of eventbridge Show documentation
The AWS Java SDK for EventBridge module holds the client classes that are used for
communicating with EventBridge.
/*
* Copyright 2015-2020 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.eventbridge.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;
/**
*
* This object enables you to specify a JSON path to extract from the event and use as the partition key for the Amazon
* Kinesis data stream so that you can control the shard that the event goes to. If you don't include this parameter,
* the default is to use the eventId
as the partition key.
*
*/
@Generated("software.amazon.awssdk:codegen")
public final class KinesisParameters implements SdkPojo, Serializable,
ToCopyableBuilder {
private static final SdkField PARTITION_KEY_PATH_FIELD = SdkField. builder(MarshallingType.STRING)
.getter(getter(KinesisParameters::partitionKeyPath)).setter(setter(Builder::partitionKeyPath))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("PartitionKeyPath").build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(PARTITION_KEY_PATH_FIELD));
private static final long serialVersionUID = 1L;
private final String partitionKeyPath;
private KinesisParameters(BuilderImpl builder) {
this.partitionKeyPath = builder.partitionKeyPath;
}
/**
*
* The JSON path to be extracted from the event and used as the partition key. For more information, see Amazon Kinesis Streams Key
* Concepts in the Amazon Kinesis Streams Developer Guide.
*
*
* @return The JSON path to be extracted from the event and used as the partition key. For more information, see Amazon Kinesis
* Streams Key Concepts in the Amazon Kinesis Streams Developer Guide.
*/
public String partitionKeyPath() {
return partitionKeyPath;
}
@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(partitionKeyPath());
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 KinesisParameters)) {
return false;
}
KinesisParameters other = (KinesisParameters) obj;
return Objects.equals(partitionKeyPath(), other.partitionKeyPath());
}
/**
* 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("KinesisParameters").add("PartitionKeyPath", partitionKeyPath()).build();
}
public Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "PartitionKeyPath":
return Optional.ofNullable(clazz.cast(partitionKeyPath()));
default:
return Optional.empty();
}
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
private static Function
© 2015 - 2025 Weber Informatics LLC | Privacy Policy