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

software.amazon.awssdk.services.ses.model.SendBounceRequest Maven / Gradle / Ivy

/*
 * 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.ses.model;

import java.util.Arrays;
import java.util.Collection;
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 java.util.stream.Collectors;
import java.util.stream.Stream;
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.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * 

* Represents a request to send a bounce message to the sender of an email you received through Amazon SES. *

*/ @Generated("software.amazon.awssdk:codegen") public final class SendBounceRequest extends SesRequest implements ToCopyableBuilder { private static final SdkField ORIGINAL_MESSAGE_ID_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("OriginalMessageId").getter(getter(SendBounceRequest::originalMessageId)) .setter(setter(Builder::originalMessageId)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("OriginalMessageId").build()).build(); private static final SdkField BOUNCE_SENDER_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("BounceSender").getter(getter(SendBounceRequest::bounceSender)).setter(setter(Builder::bounceSender)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("BounceSender").build()).build(); private static final SdkField EXPLANATION_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("Explanation").getter(getter(SendBounceRequest::explanation)).setter(setter(Builder::explanation)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Explanation").build()).build(); private static final SdkField MESSAGE_DSN_FIELD = SdkField. builder(MarshallingType.SDK_POJO) .memberName("MessageDsn").getter(getter(SendBounceRequest::messageDsn)).setter(setter(Builder::messageDsn)) .constructor(MessageDsn::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("MessageDsn").build()).build(); private static final SdkField> BOUNCED_RECIPIENT_INFO_LIST_FIELD = SdkField .> builder(MarshallingType.LIST) .memberName("BouncedRecipientInfoList") .getter(getter(SendBounceRequest::bouncedRecipientInfoList)) .setter(setter(Builder::bouncedRecipientInfoList)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("BouncedRecipientInfoList").build(), ListTrait .builder() .memberLocationName(null) .memberFieldInfo( SdkField. builder(MarshallingType.SDK_POJO) .constructor(BouncedRecipientInfo::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD) .locationName("member").build()).build()).build()).build(); private static final SdkField BOUNCE_SENDER_ARN_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("BounceSenderArn").getter(getter(SendBounceRequest::bounceSenderArn)) .setter(setter(Builder::bounceSenderArn)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("BounceSenderArn").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays .asList(ORIGINAL_MESSAGE_ID_FIELD, BOUNCE_SENDER_FIELD, EXPLANATION_FIELD, MESSAGE_DSN_FIELD, BOUNCED_RECIPIENT_INFO_LIST_FIELD, BOUNCE_SENDER_ARN_FIELD)); private final String originalMessageId; private final String bounceSender; private final String explanation; private final MessageDsn messageDsn; private final List bouncedRecipientInfoList; private final String bounceSenderArn; private SendBounceRequest(BuilderImpl builder) { super(builder); this.originalMessageId = builder.originalMessageId; this.bounceSender = builder.bounceSender; this.explanation = builder.explanation; this.messageDsn = builder.messageDsn; this.bouncedRecipientInfoList = builder.bouncedRecipientInfoList; this.bounceSenderArn = builder.bounceSenderArn; } /** *

* The message ID of the message to be bounced. *

* * @return The message ID of the message to be bounced. */ public final String originalMessageId() { return originalMessageId; } /** *

* The address to use in the "From" header of the bounce message. This must be an identity that you have verified * with Amazon SES. *

* * @return The address to use in the "From" header of the bounce message. This must be an identity that you have * verified with Amazon SES. */ public final String bounceSender() { return bounceSender; } /** *

* Human-readable text for the bounce message to explain the failure. If not specified, the text will be * auto-generated based on the bounced recipient information. *

* * @return Human-readable text for the bounce message to explain the failure. If not specified, the text will be * auto-generated based on the bounced recipient information. */ public final String explanation() { return explanation; } /** *

* Message-related DSN fields. If not specified, Amazon SES will choose the values. *

* * @return Message-related DSN fields. If not specified, Amazon SES will choose the values. */ public final MessageDsn messageDsn() { return messageDsn; } /** * Returns true if the BouncedRecipientInfoList property was specified by the sender (it may be empty), or false if * the sender did not specify the value (it will be empty). For responses returned by the SDK, the sender is the AWS * service. */ public final boolean hasBouncedRecipientInfoList() { return bouncedRecipientInfoList != null && !(bouncedRecipientInfoList instanceof SdkAutoConstructList); } /** *

* A list of recipients of the bounced message, including the information required to create the Delivery Status * Notifications (DSNs) for the recipients. You must specify at least one BouncedRecipientInfo in the * list. *

*

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

*

* You can use {@link #hasBouncedRecipientInfoList()} to see if a value was sent in this field. *

* * @return A list of recipients of the bounced message, including the information required to create the Delivery * Status Notifications (DSNs) for the recipients. You must specify at least one * BouncedRecipientInfo in the list. */ public final List bouncedRecipientInfoList() { return bouncedRecipientInfoList; } /** *

* This parameter is used only for sending authorization. It is the ARN of the identity that is associated with the * sending authorization policy that permits you to use the address in the "From" header of the bounce. For more * information about sending authorization, see the Amazon SES Developer * Guide. *

* * @return This parameter is used only for sending authorization. It is the ARN of the identity that is associated * with the sending authorization policy that permits you to use the address in the "From" header of the * bounce. For more information about sending authorization, see the Amazon SES * Developer Guide. */ public final String bounceSenderArn() { return bounceSenderArn; } @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(originalMessageId()); hashCode = 31 * hashCode + Objects.hashCode(bounceSender()); hashCode = 31 * hashCode + Objects.hashCode(explanation()); hashCode = 31 * hashCode + Objects.hashCode(messageDsn()); hashCode = 31 * hashCode + Objects.hashCode(hasBouncedRecipientInfoList() ? bouncedRecipientInfoList() : null); hashCode = 31 * hashCode + Objects.hashCode(bounceSenderArn()); 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 SendBounceRequest)) { return false; } SendBounceRequest other = (SendBounceRequest) obj; return Objects.equals(originalMessageId(), other.originalMessageId()) && Objects.equals(bounceSender(), other.bounceSender()) && Objects.equals(explanation(), other.explanation()) && Objects.equals(messageDsn(), other.messageDsn()) && hasBouncedRecipientInfoList() == other.hasBouncedRecipientInfoList() && Objects.equals(bouncedRecipientInfoList(), other.bouncedRecipientInfoList()) && Objects.equals(bounceSenderArn(), other.bounceSenderArn()); } /** * 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("SendBounceRequest").add("OriginalMessageId", originalMessageId()) .add("BounceSender", bounceSender()).add("Explanation", explanation()).add("MessageDsn", messageDsn()) .add("BouncedRecipientInfoList", hasBouncedRecipientInfoList() ? bouncedRecipientInfoList() : null) .add("BounceSenderArn", bounceSenderArn()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "OriginalMessageId": return Optional.ofNullable(clazz.cast(originalMessageId())); case "BounceSender": return Optional.ofNullable(clazz.cast(bounceSender())); case "Explanation": return Optional.ofNullable(clazz.cast(explanation())); case "MessageDsn": return Optional.ofNullable(clazz.cast(messageDsn())); case "BouncedRecipientInfoList": return Optional.ofNullable(clazz.cast(bouncedRecipientInfoList())); case "BounceSenderArn": return Optional.ofNullable(clazz.cast(bounceSenderArn())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((SendBounceRequest) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SesRequest.Builder, SdkPojo, CopyableBuilder { /** *

* The message ID of the message to be bounced. *

* * @param originalMessageId * The message ID of the message to be bounced. * @return Returns a reference to this object so that method calls can be chained together. */ Builder originalMessageId(String originalMessageId); /** *

* The address to use in the "From" header of the bounce message. This must be an identity that you have * verified with Amazon SES. *

* * @param bounceSender * The address to use in the "From" header of the bounce message. This must be an identity that you have * verified with Amazon SES. * @return Returns a reference to this object so that method calls can be chained together. */ Builder bounceSender(String bounceSender); /** *

* Human-readable text for the bounce message to explain the failure. If not specified, the text will be * auto-generated based on the bounced recipient information. *

* * @param explanation * Human-readable text for the bounce message to explain the failure. If not specified, the text will be * auto-generated based on the bounced recipient information. * @return Returns a reference to this object so that method calls can be chained together. */ Builder explanation(String explanation); /** *

* Message-related DSN fields. If not specified, Amazon SES will choose the values. *

* * @param messageDsn * Message-related DSN fields. If not specified, Amazon SES will choose the values. * @return Returns a reference to this object so that method calls can be chained together. */ Builder messageDsn(MessageDsn messageDsn); /** *

* Message-related DSN fields. If not specified, Amazon SES will choose the values. *

* This is a convenience that creates an instance of the {@link MessageDsn.Builder} avoiding the need to create * one manually via {@link MessageDsn#builder()}. * * When the {@link Consumer} completes, {@link MessageDsn.Builder#build()} is called immediately and its result * is passed to {@link #messageDsn(MessageDsn)}. * * @param messageDsn * a consumer that will call methods on {@link MessageDsn.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #messageDsn(MessageDsn) */ default Builder messageDsn(Consumer messageDsn) { return messageDsn(MessageDsn.builder().applyMutation(messageDsn).build()); } /** *

* A list of recipients of the bounced message, including the information required to create the Delivery Status * Notifications (DSNs) for the recipients. You must specify at least one BouncedRecipientInfo in * the list. *

* * @param bouncedRecipientInfoList * A list of recipients of the bounced message, including the information required to create the Delivery * Status Notifications (DSNs) for the recipients. You must specify at least one * BouncedRecipientInfo in the list. * @return Returns a reference to this object so that method calls can be chained together. */ Builder bouncedRecipientInfoList(Collection bouncedRecipientInfoList); /** *

* A list of recipients of the bounced message, including the information required to create the Delivery Status * Notifications (DSNs) for the recipients. You must specify at least one BouncedRecipientInfo in * the list. *

* * @param bouncedRecipientInfoList * A list of recipients of the bounced message, including the information required to create the Delivery * Status Notifications (DSNs) for the recipients. You must specify at least one * BouncedRecipientInfo in the list. * @return Returns a reference to this object so that method calls can be chained together. */ Builder bouncedRecipientInfoList(BouncedRecipientInfo... bouncedRecipientInfoList); /** *

* A list of recipients of the bounced message, including the information required to create the Delivery Status * Notifications (DSNs) for the recipients. You must specify at least one BouncedRecipientInfo in * the list. *

* This is a convenience that creates an instance of the {@link List.Builder} avoiding the * need to create one manually via {@link List#builder()}. * * When the {@link Consumer} completes, {@link List.Builder#build()} is called immediately * and its result is passed to {@link #bouncedRecipientInfoList(List)}. * * @param bouncedRecipientInfoList * a consumer that will call methods on {@link List.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #bouncedRecipientInfoList(List) */ Builder bouncedRecipientInfoList(Consumer... bouncedRecipientInfoList); /** *

* This parameter is used only for sending authorization. It is the ARN of the identity that is associated with * the sending authorization policy that permits you to use the address in the "From" header of the bounce. For * more information about sending authorization, see the Amazon SES Developer * Guide. *

* * @param bounceSenderArn * This parameter is used only for sending authorization. It is the ARN of the identity that is * associated with the sending authorization policy that permits you to use the address in the "From" * header of the bounce. For more information about sending authorization, see the Amazon SES * Developer Guide. * @return Returns a reference to this object so that method calls can be chained together. */ Builder bounceSenderArn(String bounceSenderArn); @Override Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration); @Override Builder overrideConfiguration(Consumer builderConsumer); } static final class BuilderImpl extends SesRequest.BuilderImpl implements Builder { private String originalMessageId; private String bounceSender; private String explanation; private MessageDsn messageDsn; private List bouncedRecipientInfoList = DefaultSdkAutoConstructList.getInstance(); private String bounceSenderArn; private BuilderImpl() { } private BuilderImpl(SendBounceRequest model) { super(model); originalMessageId(model.originalMessageId); bounceSender(model.bounceSender); explanation(model.explanation); messageDsn(model.messageDsn); bouncedRecipientInfoList(model.bouncedRecipientInfoList); bounceSenderArn(model.bounceSenderArn); } public final String getOriginalMessageId() { return originalMessageId; } @Override public final Builder originalMessageId(String originalMessageId) { this.originalMessageId = originalMessageId; return this; } public final void setOriginalMessageId(String originalMessageId) { this.originalMessageId = originalMessageId; } public final String getBounceSender() { return bounceSender; } @Override public final Builder bounceSender(String bounceSender) { this.bounceSender = bounceSender; return this; } public final void setBounceSender(String bounceSender) { this.bounceSender = bounceSender; } public final String getExplanation() { return explanation; } @Override public final Builder explanation(String explanation) { this.explanation = explanation; return this; } public final void setExplanation(String explanation) { this.explanation = explanation; } public final MessageDsn.Builder getMessageDsn() { return messageDsn != null ? messageDsn.toBuilder() : null; } @Override public final Builder messageDsn(MessageDsn messageDsn) { this.messageDsn = messageDsn; return this; } public final void setMessageDsn(MessageDsn.BuilderImpl messageDsn) { this.messageDsn = messageDsn != null ? messageDsn.build() : null; } public final Collection getBouncedRecipientInfoList() { if (bouncedRecipientInfoList instanceof SdkAutoConstructList) { return null; } return bouncedRecipientInfoList != null ? bouncedRecipientInfoList.stream().map(BouncedRecipientInfo::toBuilder) .collect(Collectors.toList()) : null; } @Override public final Builder bouncedRecipientInfoList(Collection bouncedRecipientInfoList) { this.bouncedRecipientInfoList = BouncedRecipientInfoListCopier.copy(bouncedRecipientInfoList); return this; } @Override @SafeVarargs public final Builder bouncedRecipientInfoList(BouncedRecipientInfo... bouncedRecipientInfoList) { bouncedRecipientInfoList(Arrays.asList(bouncedRecipientInfoList)); return this; } @Override @SafeVarargs public final Builder bouncedRecipientInfoList(Consumer... bouncedRecipientInfoList) { bouncedRecipientInfoList(Stream.of(bouncedRecipientInfoList) .map(c -> BouncedRecipientInfo.builder().applyMutation(c).build()).collect(Collectors.toList())); return this; } public final void setBouncedRecipientInfoList(Collection bouncedRecipientInfoList) { this.bouncedRecipientInfoList = BouncedRecipientInfoListCopier.copyFromBuilder(bouncedRecipientInfoList); } public final String getBounceSenderArn() { return bounceSenderArn; } @Override public final Builder bounceSenderArn(String bounceSenderArn) { this.bounceSenderArn = bounceSenderArn; return this; } public final void setBounceSenderArn(String bounceSenderArn) { this.bounceSenderArn = bounceSenderArn; } @Override public Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration) { super.overrideConfiguration(overrideConfiguration); return this; } @Override public Builder overrideConfiguration(Consumer builderConsumer) { super.overrideConfiguration(builderConsumer); return this; } @Override public SendBounceRequest build() { return new SendBounceRequest(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy