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

software.amazon.awssdk.services.ses.DefaultSesAsyncClient Maven / Gradle / Ivy

Go to download

The AWS Java SDK for Amazon SES module holds the client classes that are used for communicating with Amazon Simple Email Service

There is a newer version: 2.30.1
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.ses;

import java.util.Collections;
import java.util.List;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ScheduledExecutorService;
import java.util.function.Consumer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.annotations.SdkInternalApi;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
import software.amazon.awssdk.awscore.client.handler.AwsAsyncClientHandler;
import software.amazon.awssdk.awscore.exception.AwsServiceException;
import software.amazon.awssdk.core.ApiName;
import software.amazon.awssdk.core.RequestOverrideConfiguration;
import software.amazon.awssdk.core.client.config.SdkClientConfiguration;
import software.amazon.awssdk.core.client.config.SdkClientOption;
import software.amazon.awssdk.core.client.handler.AsyncClientHandler;
import software.amazon.awssdk.core.client.handler.ClientExecutionParams;
import software.amazon.awssdk.core.http.HttpResponseHandler;
import software.amazon.awssdk.core.metrics.CoreMetric;
import software.amazon.awssdk.core.util.VersionInfo;
import software.amazon.awssdk.metrics.MetricCollector;
import software.amazon.awssdk.metrics.MetricPublisher;
import software.amazon.awssdk.metrics.NoOpMetricCollector;
import software.amazon.awssdk.protocols.core.ExceptionMetadata;
import software.amazon.awssdk.protocols.query.AwsQueryProtocolFactory;
import software.amazon.awssdk.services.ses.model.AccountSendingPausedException;
import software.amazon.awssdk.services.ses.model.AlreadyExistsException;
import software.amazon.awssdk.services.ses.model.CannotDeleteException;
import software.amazon.awssdk.services.ses.model.CloneReceiptRuleSetRequest;
import software.amazon.awssdk.services.ses.model.CloneReceiptRuleSetResponse;
import software.amazon.awssdk.services.ses.model.ConfigurationSetAlreadyExistsException;
import software.amazon.awssdk.services.ses.model.ConfigurationSetDoesNotExistException;
import software.amazon.awssdk.services.ses.model.ConfigurationSetSendingPausedException;
import software.amazon.awssdk.services.ses.model.CreateConfigurationSetEventDestinationRequest;
import software.amazon.awssdk.services.ses.model.CreateConfigurationSetEventDestinationResponse;
import software.amazon.awssdk.services.ses.model.CreateConfigurationSetRequest;
import software.amazon.awssdk.services.ses.model.CreateConfigurationSetResponse;
import software.amazon.awssdk.services.ses.model.CreateConfigurationSetTrackingOptionsRequest;
import software.amazon.awssdk.services.ses.model.CreateConfigurationSetTrackingOptionsResponse;
import software.amazon.awssdk.services.ses.model.CreateCustomVerificationEmailTemplateRequest;
import software.amazon.awssdk.services.ses.model.CreateCustomVerificationEmailTemplateResponse;
import software.amazon.awssdk.services.ses.model.CreateReceiptFilterRequest;
import software.amazon.awssdk.services.ses.model.CreateReceiptFilterResponse;
import software.amazon.awssdk.services.ses.model.CreateReceiptRuleRequest;
import software.amazon.awssdk.services.ses.model.CreateReceiptRuleResponse;
import software.amazon.awssdk.services.ses.model.CreateReceiptRuleSetRequest;
import software.amazon.awssdk.services.ses.model.CreateReceiptRuleSetResponse;
import software.amazon.awssdk.services.ses.model.CreateTemplateRequest;
import software.amazon.awssdk.services.ses.model.CreateTemplateResponse;
import software.amazon.awssdk.services.ses.model.CustomVerificationEmailInvalidContentException;
import software.amazon.awssdk.services.ses.model.CustomVerificationEmailTemplateAlreadyExistsException;
import software.amazon.awssdk.services.ses.model.CustomVerificationEmailTemplateDoesNotExistException;
import software.amazon.awssdk.services.ses.model.DeleteConfigurationSetEventDestinationRequest;
import software.amazon.awssdk.services.ses.model.DeleteConfigurationSetEventDestinationResponse;
import software.amazon.awssdk.services.ses.model.DeleteConfigurationSetRequest;
import software.amazon.awssdk.services.ses.model.DeleteConfigurationSetResponse;
import software.amazon.awssdk.services.ses.model.DeleteConfigurationSetTrackingOptionsRequest;
import software.amazon.awssdk.services.ses.model.DeleteConfigurationSetTrackingOptionsResponse;
import software.amazon.awssdk.services.ses.model.DeleteCustomVerificationEmailTemplateRequest;
import software.amazon.awssdk.services.ses.model.DeleteCustomVerificationEmailTemplateResponse;
import software.amazon.awssdk.services.ses.model.DeleteIdentityPolicyRequest;
import software.amazon.awssdk.services.ses.model.DeleteIdentityPolicyResponse;
import software.amazon.awssdk.services.ses.model.DeleteIdentityRequest;
import software.amazon.awssdk.services.ses.model.DeleteIdentityResponse;
import software.amazon.awssdk.services.ses.model.DeleteReceiptFilterRequest;
import software.amazon.awssdk.services.ses.model.DeleteReceiptFilterResponse;
import software.amazon.awssdk.services.ses.model.DeleteReceiptRuleRequest;
import software.amazon.awssdk.services.ses.model.DeleteReceiptRuleResponse;
import software.amazon.awssdk.services.ses.model.DeleteReceiptRuleSetRequest;
import software.amazon.awssdk.services.ses.model.DeleteReceiptRuleSetResponse;
import software.amazon.awssdk.services.ses.model.DeleteTemplateRequest;
import software.amazon.awssdk.services.ses.model.DeleteTemplateResponse;
import software.amazon.awssdk.services.ses.model.DeleteVerifiedEmailAddressRequest;
import software.amazon.awssdk.services.ses.model.DeleteVerifiedEmailAddressResponse;
import software.amazon.awssdk.services.ses.model.DescribeActiveReceiptRuleSetRequest;
import software.amazon.awssdk.services.ses.model.DescribeActiveReceiptRuleSetResponse;
import software.amazon.awssdk.services.ses.model.DescribeConfigurationSetRequest;
import software.amazon.awssdk.services.ses.model.DescribeConfigurationSetResponse;
import software.amazon.awssdk.services.ses.model.DescribeReceiptRuleRequest;
import software.amazon.awssdk.services.ses.model.DescribeReceiptRuleResponse;
import software.amazon.awssdk.services.ses.model.DescribeReceiptRuleSetRequest;
import software.amazon.awssdk.services.ses.model.DescribeReceiptRuleSetResponse;
import software.amazon.awssdk.services.ses.model.EventDestinationAlreadyExistsException;
import software.amazon.awssdk.services.ses.model.EventDestinationDoesNotExistException;
import software.amazon.awssdk.services.ses.model.FromEmailAddressNotVerifiedException;
import software.amazon.awssdk.services.ses.model.GetAccountSendingEnabledRequest;
import software.amazon.awssdk.services.ses.model.GetAccountSendingEnabledResponse;
import software.amazon.awssdk.services.ses.model.GetCustomVerificationEmailTemplateRequest;
import software.amazon.awssdk.services.ses.model.GetCustomVerificationEmailTemplateResponse;
import software.amazon.awssdk.services.ses.model.GetIdentityDkimAttributesRequest;
import software.amazon.awssdk.services.ses.model.GetIdentityDkimAttributesResponse;
import software.amazon.awssdk.services.ses.model.GetIdentityMailFromDomainAttributesRequest;
import software.amazon.awssdk.services.ses.model.GetIdentityMailFromDomainAttributesResponse;
import software.amazon.awssdk.services.ses.model.GetIdentityNotificationAttributesRequest;
import software.amazon.awssdk.services.ses.model.GetIdentityNotificationAttributesResponse;
import software.amazon.awssdk.services.ses.model.GetIdentityPoliciesRequest;
import software.amazon.awssdk.services.ses.model.GetIdentityPoliciesResponse;
import software.amazon.awssdk.services.ses.model.GetIdentityVerificationAttributesRequest;
import software.amazon.awssdk.services.ses.model.GetIdentityVerificationAttributesResponse;
import software.amazon.awssdk.services.ses.model.GetSendQuotaRequest;
import software.amazon.awssdk.services.ses.model.GetSendQuotaResponse;
import software.amazon.awssdk.services.ses.model.GetSendStatisticsRequest;
import software.amazon.awssdk.services.ses.model.GetSendStatisticsResponse;
import software.amazon.awssdk.services.ses.model.GetTemplateRequest;
import software.amazon.awssdk.services.ses.model.GetTemplateResponse;
import software.amazon.awssdk.services.ses.model.InvalidCloudWatchDestinationException;
import software.amazon.awssdk.services.ses.model.InvalidConfigurationSetException;
import software.amazon.awssdk.services.ses.model.InvalidDeliveryOptionsException;
import software.amazon.awssdk.services.ses.model.InvalidFirehoseDestinationException;
import software.amazon.awssdk.services.ses.model.InvalidLambdaFunctionException;
import software.amazon.awssdk.services.ses.model.InvalidPolicyException;
import software.amazon.awssdk.services.ses.model.InvalidRenderingParameterException;
import software.amazon.awssdk.services.ses.model.InvalidS3ConfigurationException;
import software.amazon.awssdk.services.ses.model.InvalidSnsDestinationException;
import software.amazon.awssdk.services.ses.model.InvalidSnsTopicException;
import software.amazon.awssdk.services.ses.model.InvalidTemplateException;
import software.amazon.awssdk.services.ses.model.InvalidTrackingOptionsException;
import software.amazon.awssdk.services.ses.model.LimitExceededException;
import software.amazon.awssdk.services.ses.model.ListConfigurationSetsRequest;
import software.amazon.awssdk.services.ses.model.ListConfigurationSetsResponse;
import software.amazon.awssdk.services.ses.model.ListCustomVerificationEmailTemplatesRequest;
import software.amazon.awssdk.services.ses.model.ListCustomVerificationEmailTemplatesResponse;
import software.amazon.awssdk.services.ses.model.ListIdentitiesRequest;
import software.amazon.awssdk.services.ses.model.ListIdentitiesResponse;
import software.amazon.awssdk.services.ses.model.ListIdentityPoliciesRequest;
import software.amazon.awssdk.services.ses.model.ListIdentityPoliciesResponse;
import software.amazon.awssdk.services.ses.model.ListReceiptFiltersRequest;
import software.amazon.awssdk.services.ses.model.ListReceiptFiltersResponse;
import software.amazon.awssdk.services.ses.model.ListReceiptRuleSetsRequest;
import software.amazon.awssdk.services.ses.model.ListReceiptRuleSetsResponse;
import software.amazon.awssdk.services.ses.model.ListTemplatesRequest;
import software.amazon.awssdk.services.ses.model.ListTemplatesResponse;
import software.amazon.awssdk.services.ses.model.ListVerifiedEmailAddressesRequest;
import software.amazon.awssdk.services.ses.model.ListVerifiedEmailAddressesResponse;
import software.amazon.awssdk.services.ses.model.MailFromDomainNotVerifiedException;
import software.amazon.awssdk.services.ses.model.MessageRejectedException;
import software.amazon.awssdk.services.ses.model.MissingRenderingAttributeException;
import software.amazon.awssdk.services.ses.model.ProductionAccessNotGrantedException;
import software.amazon.awssdk.services.ses.model.PutConfigurationSetDeliveryOptionsRequest;
import software.amazon.awssdk.services.ses.model.PutConfigurationSetDeliveryOptionsResponse;
import software.amazon.awssdk.services.ses.model.PutIdentityPolicyRequest;
import software.amazon.awssdk.services.ses.model.PutIdentityPolicyResponse;
import software.amazon.awssdk.services.ses.model.ReorderReceiptRuleSetRequest;
import software.amazon.awssdk.services.ses.model.ReorderReceiptRuleSetResponse;
import software.amazon.awssdk.services.ses.model.RuleDoesNotExistException;
import software.amazon.awssdk.services.ses.model.RuleSetDoesNotExistException;
import software.amazon.awssdk.services.ses.model.SendBounceRequest;
import software.amazon.awssdk.services.ses.model.SendBounceResponse;
import software.amazon.awssdk.services.ses.model.SendBulkTemplatedEmailRequest;
import software.amazon.awssdk.services.ses.model.SendBulkTemplatedEmailResponse;
import software.amazon.awssdk.services.ses.model.SendCustomVerificationEmailRequest;
import software.amazon.awssdk.services.ses.model.SendCustomVerificationEmailResponse;
import software.amazon.awssdk.services.ses.model.SendEmailRequest;
import software.amazon.awssdk.services.ses.model.SendEmailResponse;
import software.amazon.awssdk.services.ses.model.SendRawEmailRequest;
import software.amazon.awssdk.services.ses.model.SendRawEmailResponse;
import software.amazon.awssdk.services.ses.model.SendTemplatedEmailRequest;
import software.amazon.awssdk.services.ses.model.SendTemplatedEmailResponse;
import software.amazon.awssdk.services.ses.model.SesException;
import software.amazon.awssdk.services.ses.model.SesRequest;
import software.amazon.awssdk.services.ses.model.SetActiveReceiptRuleSetRequest;
import software.amazon.awssdk.services.ses.model.SetActiveReceiptRuleSetResponse;
import software.amazon.awssdk.services.ses.model.SetIdentityDkimEnabledRequest;
import software.amazon.awssdk.services.ses.model.SetIdentityDkimEnabledResponse;
import software.amazon.awssdk.services.ses.model.SetIdentityFeedbackForwardingEnabledRequest;
import software.amazon.awssdk.services.ses.model.SetIdentityFeedbackForwardingEnabledResponse;
import software.amazon.awssdk.services.ses.model.SetIdentityHeadersInNotificationsEnabledRequest;
import software.amazon.awssdk.services.ses.model.SetIdentityHeadersInNotificationsEnabledResponse;
import software.amazon.awssdk.services.ses.model.SetIdentityMailFromDomainRequest;
import software.amazon.awssdk.services.ses.model.SetIdentityMailFromDomainResponse;
import software.amazon.awssdk.services.ses.model.SetIdentityNotificationTopicRequest;
import software.amazon.awssdk.services.ses.model.SetIdentityNotificationTopicResponse;
import software.amazon.awssdk.services.ses.model.SetReceiptRulePositionRequest;
import software.amazon.awssdk.services.ses.model.SetReceiptRulePositionResponse;
import software.amazon.awssdk.services.ses.model.TemplateDoesNotExistException;
import software.amazon.awssdk.services.ses.model.TestRenderTemplateRequest;
import software.amazon.awssdk.services.ses.model.TestRenderTemplateResponse;
import software.amazon.awssdk.services.ses.model.TrackingOptionsAlreadyExistsException;
import software.amazon.awssdk.services.ses.model.TrackingOptionsDoesNotExistException;
import software.amazon.awssdk.services.ses.model.UpdateAccountSendingEnabledRequest;
import software.amazon.awssdk.services.ses.model.UpdateAccountSendingEnabledResponse;
import software.amazon.awssdk.services.ses.model.UpdateConfigurationSetEventDestinationRequest;
import software.amazon.awssdk.services.ses.model.UpdateConfigurationSetEventDestinationResponse;
import software.amazon.awssdk.services.ses.model.UpdateConfigurationSetReputationMetricsEnabledRequest;
import software.amazon.awssdk.services.ses.model.UpdateConfigurationSetReputationMetricsEnabledResponse;
import software.amazon.awssdk.services.ses.model.UpdateConfigurationSetSendingEnabledRequest;
import software.amazon.awssdk.services.ses.model.UpdateConfigurationSetSendingEnabledResponse;
import software.amazon.awssdk.services.ses.model.UpdateConfigurationSetTrackingOptionsRequest;
import software.amazon.awssdk.services.ses.model.UpdateConfigurationSetTrackingOptionsResponse;
import software.amazon.awssdk.services.ses.model.UpdateCustomVerificationEmailTemplateRequest;
import software.amazon.awssdk.services.ses.model.UpdateCustomVerificationEmailTemplateResponse;
import software.amazon.awssdk.services.ses.model.UpdateReceiptRuleRequest;
import software.amazon.awssdk.services.ses.model.UpdateReceiptRuleResponse;
import software.amazon.awssdk.services.ses.model.UpdateTemplateRequest;
import software.amazon.awssdk.services.ses.model.UpdateTemplateResponse;
import software.amazon.awssdk.services.ses.model.VerifyDomainDkimRequest;
import software.amazon.awssdk.services.ses.model.VerifyDomainDkimResponse;
import software.amazon.awssdk.services.ses.model.VerifyDomainIdentityRequest;
import software.amazon.awssdk.services.ses.model.VerifyDomainIdentityResponse;
import software.amazon.awssdk.services.ses.model.VerifyEmailAddressRequest;
import software.amazon.awssdk.services.ses.model.VerifyEmailAddressResponse;
import software.amazon.awssdk.services.ses.model.VerifyEmailIdentityRequest;
import software.amazon.awssdk.services.ses.model.VerifyEmailIdentityResponse;
import software.amazon.awssdk.services.ses.paginators.ListCustomVerificationEmailTemplatesPublisher;
import software.amazon.awssdk.services.ses.paginators.ListIdentitiesPublisher;
import software.amazon.awssdk.services.ses.transform.CloneReceiptRuleSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.CreateConfigurationSetEventDestinationRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.CreateConfigurationSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.CreateConfigurationSetTrackingOptionsRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.CreateCustomVerificationEmailTemplateRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.CreateReceiptFilterRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.CreateReceiptRuleRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.CreateReceiptRuleSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.CreateTemplateRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteConfigurationSetEventDestinationRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteConfigurationSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteConfigurationSetTrackingOptionsRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteCustomVerificationEmailTemplateRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteIdentityPolicyRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteIdentityRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteReceiptFilterRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteReceiptRuleRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteReceiptRuleSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteTemplateRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DeleteVerifiedEmailAddressRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DescribeActiveReceiptRuleSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DescribeConfigurationSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DescribeReceiptRuleRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.DescribeReceiptRuleSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetAccountSendingEnabledRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetCustomVerificationEmailTemplateRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetIdentityDkimAttributesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetIdentityMailFromDomainAttributesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetIdentityNotificationAttributesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetIdentityPoliciesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetIdentityVerificationAttributesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetSendQuotaRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetSendStatisticsRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.GetTemplateRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.ListConfigurationSetsRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.ListCustomVerificationEmailTemplatesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.ListIdentitiesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.ListIdentityPoliciesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.ListReceiptFiltersRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.ListReceiptRuleSetsRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.ListTemplatesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.ListVerifiedEmailAddressesRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.PutConfigurationSetDeliveryOptionsRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.PutIdentityPolicyRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.ReorderReceiptRuleSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SendBounceRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SendBulkTemplatedEmailRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SendCustomVerificationEmailRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SendEmailRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SendRawEmailRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SendTemplatedEmailRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SetActiveReceiptRuleSetRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SetIdentityDkimEnabledRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SetIdentityFeedbackForwardingEnabledRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SetIdentityHeadersInNotificationsEnabledRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SetIdentityMailFromDomainRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SetIdentityNotificationTopicRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.SetReceiptRulePositionRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.TestRenderTemplateRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.UpdateAccountSendingEnabledRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.UpdateConfigurationSetEventDestinationRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.UpdateConfigurationSetReputationMetricsEnabledRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.UpdateConfigurationSetSendingEnabledRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.UpdateConfigurationSetTrackingOptionsRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.UpdateCustomVerificationEmailTemplateRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.UpdateReceiptRuleRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.UpdateTemplateRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.VerifyDomainDkimRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.VerifyDomainIdentityRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.VerifyEmailAddressRequestMarshaller;
import software.amazon.awssdk.services.ses.transform.VerifyEmailIdentityRequestMarshaller;
import software.amazon.awssdk.services.ses.waiters.SesAsyncWaiter;
import software.amazon.awssdk.utils.CompletableFutureUtils;

/**
 * Internal implementation of {@link SesAsyncClient}.
 *
 * @see SesAsyncClient#builder()
 */
@Generated("software.amazon.awssdk:codegen")
@SdkInternalApi
final class DefaultSesAsyncClient implements SesAsyncClient {
    private static final Logger log = LoggerFactory.getLogger(DefaultSesAsyncClient.class);

    private final AsyncClientHandler clientHandler;

    private final AwsQueryProtocolFactory protocolFactory;

    private final SdkClientConfiguration clientConfiguration;

    private final ScheduledExecutorService executorService;

    protected DefaultSesAsyncClient(SdkClientConfiguration clientConfiguration) {
        this.clientHandler = new AwsAsyncClientHandler(clientConfiguration);
        this.clientConfiguration = clientConfiguration;
        this.protocolFactory = init();
        this.executorService = clientConfiguration.option(SdkClientOption.SCHEDULED_EXECUTOR_SERVICE);
    }

    @Override
    public final String serviceName() {
        return SERVICE_NAME;
    }

    /**
     * 

* Creates a receipt rule set by cloning an existing one. All receipt rules and configurations are copied to the new * receipt rule set and are completely independent of the source rule set. *

*

* For information about setting up rule sets, see the Amazon SES * Developer Guide. *

*

* You can execute this operation no more than once per second. *

* * @param cloneReceiptRuleSetRequest * Represents a request to create a receipt rule set by cloning an existing one. You use receipt rule sets to * receive email with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the CloneReceiptRuleSet operation returned by the service.
* The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
    *
  • RuleSetDoesNotExistException Indicates that the provided receipt rule set does not exist.
  • *
  • AlreadyExistsException Indicates that a resource could not be created because of a naming conflict.
  • *
  • LimitExceededException Indicates that a resource could not be created because of service limits. For * a list of Amazon SES limits, see the Amazon SES Developer Guide.
  • *
  • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
  • *
  • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
  • *
  • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
  • *
* @sample SesAsyncClient.CloneReceiptRuleSet * @see AWS API * Documentation */ @Override public CompletableFuture cloneReceiptRuleSet( CloneReceiptRuleSetRequest cloneReceiptRuleSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, cloneReceiptRuleSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "CloneReceiptRuleSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(CloneReceiptRuleSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("CloneReceiptRuleSet") .withMarshaller(new CloneReceiptRuleSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(cloneReceiptRuleSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = cloneReceiptRuleSetRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

* Creates a configuration set. *

*

* Configuration sets enable you to publish email sending events. For information about using configuration sets, * see the Amazon SES * Developer Guide. *

*

* You can execute this operation no more than once per second. *

* * @param createConfigurationSetRequest * Represents a request to create a configuration set. Configuration sets enable you to publish email sending * events. For information about using configuration sets, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the CreateConfigurationSet operation returned by the service.
* The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
    *
  • ConfigurationSetAlreadyExistsException Indicates that the configuration set could not be created * because of a naming conflict.
  • *
  • InvalidConfigurationSetException Indicates that the configuration set is invalid. See the error * message for details.
  • *
  • LimitExceededException Indicates that a resource could not be created because of service limits. For * a list of Amazon SES limits, see the Amazon SES Developer Guide.
  • *
  • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
  • *
  • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
  • *
  • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
  • *
* @sample SesAsyncClient.CreateConfigurationSet * @see AWS * API Documentation */ @Override public CompletableFuture createConfigurationSet( CreateConfigurationSetRequest createConfigurationSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, createConfigurationSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "CreateConfigurationSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(CreateConfigurationSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("CreateConfigurationSet") .withMarshaller(new CreateConfigurationSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(createConfigurationSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = createConfigurationSetRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

* Creates a configuration set event destination. *

* *

* When you create or update an event destination, you must provide one, and only one, destination. The destination * can be CloudWatch, Amazon Kinesis Firehose, or Amazon Simple Notification Service (Amazon SNS). *

*
*

* An event destination is the AWS service to which Amazon SES publishes the email sending events associated with a * configuration set. For information about using configuration sets, see the Amazon SES Developer * Guide. *

*

* You can execute this operation no more than once per second. *

* * @param createConfigurationSetEventDestinationRequest * Represents a request to create a configuration set event destination. A configuration set event * destination, which can be either Amazon CloudWatch or Amazon Kinesis Firehose, describes an AWS service in * which Amazon SES publishes the email sending events associated with a configuration set. For information * about using configuration sets, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the CreateConfigurationSetEventDestination operation returned by * the service.
* The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
    *
  • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
  • *
  • EventDestinationAlreadyExistsException Indicates that the event destination could not be created * because of a naming conflict.
  • *
  • InvalidCloudWatchDestinationException Indicates that the Amazon CloudWatch destination is invalid. * See the error message for details.
  • *
  • InvalidFirehoseDestinationException Indicates that the Amazon Kinesis Firehose destination is * invalid. See the error message for details.
  • *
  • InvalidSnsDestinationException Indicates that the Amazon Simple Notification Service (Amazon SNS) * destination is invalid. See the error message for details.
  • *
  • LimitExceededException Indicates that a resource could not be created because of service limits. For * a list of Amazon SES limits, see the Amazon SES Developer Guide.
  • *
  • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
  • *
  • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
  • *
  • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
  • *
* @sample SesAsyncClient.CreateConfigurationSetEventDestination * @see AWS API Documentation */ @Override public CompletableFuture createConfigurationSetEventDestination( CreateConfigurationSetEventDestinationRequest createConfigurationSetEventDestinationRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, createConfigurationSetEventDestinationRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "CreateConfigurationSetEventDestination"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(CreateConfigurationSetEventDestinationResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("CreateConfigurationSetEventDestination") .withMarshaller(new CreateConfigurationSetEventDestinationRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(createConfigurationSetEventDestinationRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = createConfigurationSetEventDestinationRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

* Creates an association between a configuration set and a custom domain for open and click event tracking. *

*

* By default, images and links used for tracking open and click events are hosted on domains operated by Amazon * SES. You can configure a subdomain of your own to handle these events. For information about using custom * domains, see the Amazon SES * Developer Guide. *

* * @param createConfigurationSetTrackingOptionsRequest * Represents a request to create an open and click tracking option object in a configuration set. * @return A Java Future containing the result of the CreateConfigurationSetTrackingOptions operation returned by * the service.
* The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
    *
  • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
  • *
  • TrackingOptionsAlreadyExistsException Indicates that the configuration set you specified already * contains a TrackingOptions object.
  • *
  • InvalidTrackingOptionsException Indicates that the custom domain to be used for open and click * tracking redirects is invalid. This error appears most often in the following situations:

    *
      *
    • *

      * When the tracking domain you specified is not verified in Amazon SES. *

      *
    • *
    • *

      * When the tracking domain you specified is not a valid domain or subdomain. *

      *
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.CreateConfigurationSetTrackingOptions * @see AWS API Documentation */ @Override public CompletableFuture createConfigurationSetTrackingOptions( CreateConfigurationSetTrackingOptionsRequest createConfigurationSetTrackingOptionsRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, createConfigurationSetTrackingOptionsRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "CreateConfigurationSetTrackingOptions"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(CreateConfigurationSetTrackingOptionsResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("CreateConfigurationSetTrackingOptions") .withMarshaller(new CreateConfigurationSetTrackingOptionsRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(createConfigurationSetTrackingOptionsRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = createConfigurationSetTrackingOptionsRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Creates a new custom verification email template. *

    *

    * For more information about custom verification email templates, see Using Custom * Verification Email Templates in the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param createCustomVerificationEmailTemplateRequest * Represents a request to create a custom verification email template. * @return A Java Future containing the result of the CreateCustomVerificationEmailTemplate operation returned by * the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • CustomVerificationEmailTemplateAlreadyExistsException Indicates that a custom verification email * template with the name you specified already exists.
    • *
    • FromEmailAddressNotVerifiedException Indicates that the sender address specified for a custom * verification email is not verified, and is therefore not eligible to send the custom verification email.
    • *
    • CustomVerificationEmailInvalidContentException Indicates that custom verification email template * provided content is invalid.
    • *
    • LimitExceededException Indicates that a resource could not be created because of service limits. For * a list of Amazon SES limits, see the Amazon SES Developer Guide.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.CreateCustomVerificationEmailTemplate * @see AWS API Documentation */ @Override public CompletableFuture createCustomVerificationEmailTemplate( CreateCustomVerificationEmailTemplateRequest createCustomVerificationEmailTemplateRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, createCustomVerificationEmailTemplateRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "CreateCustomVerificationEmailTemplate"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(CreateCustomVerificationEmailTemplateResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("CreateCustomVerificationEmailTemplate") .withMarshaller(new CreateCustomVerificationEmailTemplateRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(createCustomVerificationEmailTemplateRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = createCustomVerificationEmailTemplateRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Creates a new IP address filter. *

    *

    * For information about setting up IP address filters, see the Amazon SES Developer * Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param createReceiptFilterRequest * Represents a request to create a new IP address filter. You use IP address filters when you receive email * with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the CreateReceiptFilter operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • LimitExceededException Indicates that a resource could not be created because of service limits. For * a list of Amazon SES limits, see the Amazon SES Developer Guide.
    • *
    • AlreadyExistsException Indicates that a resource could not be created because of a naming conflict.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.CreateReceiptFilter * @see AWS API * Documentation */ @Override public CompletableFuture createReceiptFilter( CreateReceiptFilterRequest createReceiptFilterRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, createReceiptFilterRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "CreateReceiptFilter"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(CreateReceiptFilterResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("CreateReceiptFilter") .withMarshaller(new CreateReceiptFilterRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(createReceiptFilterRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = createReceiptFilterRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Creates a receipt rule. *

    *

    * For information about setting up receipt rules, see the Amazon SES * Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param createReceiptRuleRequest * Represents a request to create a receipt rule. You use receipt rules to receive email with Amazon SES. For * more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the CreateReceiptRule operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • InvalidSnsTopicException Indicates that the provided Amazon SNS topic is invalid, or that Amazon SES * could not publish to the topic, possibly due to permissions issues. For information about giving * permissions, see the Amazon SES * Developer Guide.
    • *
    • InvalidS3ConfigurationException Indicates that the provided Amazon S3 bucket or AWS KMS encryption * key is invalid, or that Amazon SES could not publish to the bucket, possibly due to permissions issues. * For information about giving permissions, see the Amazon SES * Developer Guide.
    • *
    • InvalidLambdaFunctionException Indicates that the provided AWS Lambda function is invalid, or that * Amazon SES could not execute the provided function, possibly due to permissions issues. For information * about giving permissions, see the Amazon SES * Developer Guide.
    • *
    • AlreadyExistsException Indicates that a resource could not be created because of a naming conflict.
    • *
    • RuleDoesNotExistException Indicates that the provided receipt rule does not exist.
    • *
    • RuleSetDoesNotExistException Indicates that the provided receipt rule set does not exist.
    • *
    • LimitExceededException Indicates that a resource could not be created because of service limits. For * a list of Amazon SES limits, see the Amazon SES Developer Guide.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.CreateReceiptRule * @see AWS API * Documentation */ @Override public CompletableFuture createReceiptRule(CreateReceiptRuleRequest createReceiptRuleRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, createReceiptRuleRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "CreateReceiptRule"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(CreateReceiptRuleResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("CreateReceiptRule") .withMarshaller(new CreateReceiptRuleRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(createReceiptRuleRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = createReceiptRuleRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Creates an empty receipt rule set. *

    *

    * For information about setting up receipt rule sets, see the Amazon SES * Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param createReceiptRuleSetRequest * Represents a request to create an empty receipt rule set. You use receipt rule sets to receive email with * Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the CreateReceiptRuleSet operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • AlreadyExistsException Indicates that a resource could not be created because of a naming conflict.
    • *
    • LimitExceededException Indicates that a resource could not be created because of service limits. For * a list of Amazon SES limits, see the Amazon SES Developer Guide.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.CreateReceiptRuleSet * @see AWS API * Documentation */ @Override public CompletableFuture createReceiptRuleSet( CreateReceiptRuleSetRequest createReceiptRuleSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, createReceiptRuleSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "CreateReceiptRuleSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(CreateReceiptRuleSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("CreateReceiptRuleSet") .withMarshaller(new CreateReceiptRuleSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(createReceiptRuleSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = createReceiptRuleSetRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Creates an email template. Email templates enable you to send personalized email to one or more destinations in a * single API operation. For more information, see the Amazon SES * Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param createTemplateRequest * Represents a request to create an email template. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the CreateTemplate operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • AlreadyExistsException Indicates that a resource could not be created because of a naming conflict.
    • *
    • InvalidTemplateException Indicates that the template that you specified could not be rendered. This * issue may occur when a template refers to a partial that does not exist.
    • *
    • LimitExceededException Indicates that a resource could not be created because of service limits. For * a list of Amazon SES limits, see the Amazon SES Developer Guide.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.CreateTemplate * @see AWS API * Documentation */ @Override public CompletableFuture createTemplate(CreateTemplateRequest createTemplateRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, createTemplateRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "CreateTemplate"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(CreateTemplateResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("CreateTemplate") .withMarshaller(new CreateTemplateRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(createTemplateRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = createTemplateRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes a configuration set. Configuration sets enable you to publish email sending events. For information about * using configuration sets, see the Amazon SES Developer * Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param deleteConfigurationSetRequest * Represents a request to delete a configuration set. Configuration sets enable you to publish email sending * events. For information about using configuration sets, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DeleteConfigurationSet operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteConfigurationSet * @see AWS * API Documentation */ @Override public CompletableFuture deleteConfigurationSet( DeleteConfigurationSetRequest deleteConfigurationSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteConfigurationSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteConfigurationSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteConfigurationSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteConfigurationSet") .withMarshaller(new DeleteConfigurationSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteConfigurationSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteConfigurationSetRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes a configuration set event destination. Configuration set event destinations are associated with * configuration sets, which enable you to publish email sending events. For information about using configuration * sets, see the Amazon SES Developer * Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param deleteConfigurationSetEventDestinationRequest * Represents a request to delete a configuration set event destination. Configuration set event destinations * are associated with configuration sets, which enable you to publish email sending events. For information * about using configuration sets, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DeleteConfigurationSetEventDestination operation returned by * the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • EventDestinationDoesNotExistException Indicates that the event destination does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteConfigurationSetEventDestination * @see AWS API Documentation */ @Override public CompletableFuture deleteConfigurationSetEventDestination( DeleteConfigurationSetEventDestinationRequest deleteConfigurationSetEventDestinationRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteConfigurationSetEventDestinationRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteConfigurationSetEventDestination"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteConfigurationSetEventDestinationResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteConfigurationSetEventDestination") .withMarshaller(new DeleteConfigurationSetEventDestinationRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteConfigurationSetEventDestinationRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteConfigurationSetEventDestinationRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes an association between a configuration set and a custom domain for open and click event tracking. *

    *

    * By default, images and links used for tracking open and click events are hosted on domains operated by Amazon * SES. You can configure a subdomain of your own to handle these events. For information about using custom * domains, see the Amazon SES * Developer Guide. *

    * *

    * Deleting this kind of association will result in emails sent using the specified configuration set to capture * open and click events using the standard, Amazon SES-operated domains. *

    *
    * * @param deleteConfigurationSetTrackingOptionsRequest * Represents a request to delete open and click tracking options in a configuration set. * @return A Java Future containing the result of the DeleteConfigurationSetTrackingOptions operation returned by * the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • TrackingOptionsDoesNotExistException Indicates that the TrackingOptions object you specified does not * exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteConfigurationSetTrackingOptions * @see AWS API Documentation */ @Override public CompletableFuture deleteConfigurationSetTrackingOptions( DeleteConfigurationSetTrackingOptionsRequest deleteConfigurationSetTrackingOptionsRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteConfigurationSetTrackingOptionsRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteConfigurationSetTrackingOptions"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteConfigurationSetTrackingOptionsResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteConfigurationSetTrackingOptions") .withMarshaller(new DeleteConfigurationSetTrackingOptionsRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteConfigurationSetTrackingOptionsRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteConfigurationSetTrackingOptionsRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes an existing custom verification email template. *

    *

    * For more information about custom verification email templates, see Using Custom * Verification Email Templates in the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param deleteCustomVerificationEmailTemplateRequest * Represents a request to delete an existing custom verification email template. * @return A Java Future containing the result of the DeleteCustomVerificationEmailTemplate operation returned by * the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteCustomVerificationEmailTemplate * @see AWS API Documentation */ @Override public CompletableFuture deleteCustomVerificationEmailTemplate( DeleteCustomVerificationEmailTemplateRequest deleteCustomVerificationEmailTemplateRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteCustomVerificationEmailTemplateRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteCustomVerificationEmailTemplate"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteCustomVerificationEmailTemplateResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteCustomVerificationEmailTemplate") .withMarshaller(new DeleteCustomVerificationEmailTemplateRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteCustomVerificationEmailTemplateRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteCustomVerificationEmailTemplateRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes the specified identity (an email address or a domain) from the list of verified identities. *

    *

    * You can execute this operation no more than once per second. *

    * * @param deleteIdentityRequest * Represents a request to delete one of your Amazon SES identities (an email address or domain). * @return A Java Future containing the result of the DeleteIdentity operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteIdentity * @see AWS API * Documentation */ @Override public CompletableFuture deleteIdentity(DeleteIdentityRequest deleteIdentityRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteIdentityRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteIdentity"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteIdentityResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteIdentity") .withMarshaller(new DeleteIdentityRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteIdentityRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteIdentityRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes the specified sending authorization policy for the given identity (an email address or a domain). This * API returns successfully even if a policy with the specified name does not exist. *

    * *

    * This API is for the identity owner only. If you have not verified the identity, this API will return an error. *

    *
    *

    * Sending authorization is a feature that enables an identity owner to authorize other senders to use its * identities. For information about using sending authorization, see the Amazon SES Developer * Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param deleteIdentityPolicyRequest * Represents a request to delete a sending authorization policy for an identity. Sending authorization is an * Amazon SES feature that enables you to authorize other senders to use your identities. For information, * see the Amazon * SES Developer Guide. * @return A Java Future containing the result of the DeleteIdentityPolicy operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteIdentityPolicy * @see AWS API * Documentation */ @Override public CompletableFuture deleteIdentityPolicy( DeleteIdentityPolicyRequest deleteIdentityPolicyRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteIdentityPolicyRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteIdentityPolicy"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteIdentityPolicyResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteIdentityPolicy") .withMarshaller(new DeleteIdentityPolicyRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteIdentityPolicyRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteIdentityPolicyRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes the specified IP address filter. *

    *

    * For information about managing IP address filters, see the Amazon SES * Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param deleteReceiptFilterRequest * Represents a request to delete an IP address filter. You use IP address filters when you receive email * with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DeleteReceiptFilter operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteReceiptFilter * @see AWS API * Documentation */ @Override public CompletableFuture deleteReceiptFilter( DeleteReceiptFilterRequest deleteReceiptFilterRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteReceiptFilterRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteReceiptFilter"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteReceiptFilterResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteReceiptFilter") .withMarshaller(new DeleteReceiptFilterRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteReceiptFilterRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteReceiptFilterRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes the specified receipt rule. *

    *

    * For information about managing receipt rules, see the Amazon * SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param deleteReceiptRuleRequest * Represents a request to delete a receipt rule. You use receipt rules to receive email with Amazon SES. For * more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DeleteReceiptRule operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • RuleSetDoesNotExistException Indicates that the provided receipt rule set does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteReceiptRule * @see AWS API * Documentation */ @Override public CompletableFuture deleteReceiptRule(DeleteReceiptRuleRequest deleteReceiptRuleRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteReceiptRuleRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteReceiptRule"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteReceiptRuleResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteReceiptRule") .withMarshaller(new DeleteReceiptRuleRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteReceiptRuleRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteReceiptRuleRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes the specified receipt rule set and all of the receipt rules it contains. *

    * *

    * The currently active rule set cannot be deleted. *

    *
    *

    * For information about managing receipt rule sets, see the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param deleteReceiptRuleSetRequest * Represents a request to delete a receipt rule set and all of the receipt rules it contains. You use * receipt rule sets to receive email with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DeleteReceiptRuleSet operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • CannotDeleteException Indicates that the delete operation could not be completed.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteReceiptRuleSet * @see AWS API * Documentation */ @Override public CompletableFuture deleteReceiptRuleSet( DeleteReceiptRuleSetRequest deleteReceiptRuleSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteReceiptRuleSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteReceiptRuleSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteReceiptRuleSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteReceiptRuleSet") .withMarshaller(new DeleteReceiptRuleSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteReceiptRuleSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteReceiptRuleSetRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deletes an email template. *

    *

    * You can execute this operation no more than once per second. *

    * * @param deleteTemplateRequest * Represents a request to delete an email template. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DeleteTemplate operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteTemplate * @see AWS API * Documentation */ @Override public CompletableFuture deleteTemplate(DeleteTemplateRequest deleteTemplateRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteTemplateRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteTemplate"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteTemplateResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteTemplate") .withMarshaller(new DeleteTemplateRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteTemplateRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteTemplateRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deprecated. Use the DeleteIdentity operation to delete email addresses and domains. *

    * * @param deleteVerifiedEmailAddressRequest * Represents a request to delete an email address from the list of email addresses you have attempted to * verify under your AWS account. * @return A Java Future containing the result of the DeleteVerifiedEmailAddress operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DeleteVerifiedEmailAddress * @see AWS API Documentation */ @Override public CompletableFuture deleteVerifiedEmailAddress( DeleteVerifiedEmailAddressRequest deleteVerifiedEmailAddressRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, deleteVerifiedEmailAddressRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DeleteVerifiedEmailAddress"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DeleteVerifiedEmailAddressResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DeleteVerifiedEmailAddress") .withMarshaller(new DeleteVerifiedEmailAddressRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(deleteVerifiedEmailAddressRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = deleteVerifiedEmailAddressRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns the metadata and receipt rules for the receipt rule set that is currently active. *

    *

    * For information about setting up receipt rule sets, see the Amazon SES * Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param describeActiveReceiptRuleSetRequest * Represents a request to return the metadata and receipt rules for the receipt rule set that is currently * active. You use receipt rule sets to receive email with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DescribeActiveReceiptRuleSet operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DescribeActiveReceiptRuleSet * @see AWS API Documentation */ @Override public CompletableFuture describeActiveReceiptRuleSet( DescribeActiveReceiptRuleSetRequest describeActiveReceiptRuleSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, describeActiveReceiptRuleSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DescribeActiveReceiptRuleSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DescribeActiveReceiptRuleSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DescribeActiveReceiptRuleSet") .withMarshaller(new DescribeActiveReceiptRuleSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(describeActiveReceiptRuleSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = describeActiveReceiptRuleSetRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns the details of the specified configuration set. For information about using configuration sets, see the * Amazon SES * Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param describeConfigurationSetRequest * Represents a request to return the details of a configuration set. Configuration sets enable you to * publish email sending events. For information about using configuration sets, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DescribeConfigurationSet operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DescribeConfigurationSet * @see AWS * API Documentation */ @Override public CompletableFuture describeConfigurationSet( DescribeConfigurationSetRequest describeConfigurationSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, describeConfigurationSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DescribeConfigurationSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DescribeConfigurationSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DescribeConfigurationSet") .withMarshaller(new DescribeConfigurationSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(describeConfigurationSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = describeConfigurationSetRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns the details of the specified receipt rule. *

    *

    * For information about setting up receipt rules, see the Amazon SES * Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param describeReceiptRuleRequest * Represents a request to return the details of a receipt rule. You use receipt rules to receive email with * Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DescribeReceiptRule operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • RuleDoesNotExistException Indicates that the provided receipt rule does not exist.
    • *
    • RuleSetDoesNotExistException Indicates that the provided receipt rule set does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DescribeReceiptRule * @see AWS API * Documentation */ @Override public CompletableFuture describeReceiptRule( DescribeReceiptRuleRequest describeReceiptRuleRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, describeReceiptRuleRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DescribeReceiptRule"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DescribeReceiptRuleResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DescribeReceiptRule") .withMarshaller(new DescribeReceiptRuleRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(describeReceiptRuleRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = describeReceiptRuleRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns the details of the specified receipt rule set. *

    *

    * For information about managing receipt rule sets, see the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param describeReceiptRuleSetRequest * Represents a request to return the details of a receipt rule set. You use receipt rule sets to receive * email with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the DescribeReceiptRuleSet operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • RuleSetDoesNotExistException Indicates that the provided receipt rule set does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.DescribeReceiptRuleSet * @see AWS * API Documentation */ @Override public CompletableFuture describeReceiptRuleSet( DescribeReceiptRuleSetRequest describeReceiptRuleSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, describeReceiptRuleSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "DescribeReceiptRuleSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(DescribeReceiptRuleSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("DescribeReceiptRuleSet") .withMarshaller(new DescribeReceiptRuleSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(describeReceiptRuleSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = describeReceiptRuleSetRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns the email sending status of the Amazon SES account for the current region. *

    *

    * You can execute this operation no more than once per second. *

    * * @param getAccountSendingEnabledRequest * @return A Java Future containing the result of the GetAccountSendingEnabled operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetAccountSendingEnabled * @see AWS * API Documentation */ @Override public CompletableFuture getAccountSendingEnabled( GetAccountSendingEnabledRequest getAccountSendingEnabledRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getAccountSendingEnabledRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetAccountSendingEnabled"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetAccountSendingEnabledResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetAccountSendingEnabled") .withMarshaller(new GetAccountSendingEnabledRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getAccountSendingEnabledRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getAccountSendingEnabledRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns the custom email verification template for the template name you specify. *

    *

    * For more information about custom verification email templates, see Using Custom * Verification Email Templates in the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param getCustomVerificationEmailTemplateRequest * Represents a request to retrieve an existing custom verification email template. * @return A Java Future containing the result of the GetCustomVerificationEmailTemplate operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • CustomVerificationEmailTemplateDoesNotExistException Indicates that a custom verification email * template with the name you specified does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetCustomVerificationEmailTemplate * @see AWS API Documentation */ @Override public CompletableFuture getCustomVerificationEmailTemplate( GetCustomVerificationEmailTemplateRequest getCustomVerificationEmailTemplateRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getCustomVerificationEmailTemplateRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetCustomVerificationEmailTemplate"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetCustomVerificationEmailTemplateResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetCustomVerificationEmailTemplate") .withMarshaller(new GetCustomVerificationEmailTemplateRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getCustomVerificationEmailTemplateRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getCustomVerificationEmailTemplateRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns the current status of Easy DKIM signing for an entity. For domain name identities, this operation also * returns the DKIM tokens that are required for Easy DKIM signing, and whether Amazon SES has successfully verified * that these tokens have been published. *

    *

    * This operation takes a list of identities as input and returns the following information for each: *

    *
      *
    • *

      * Whether Easy DKIM signing is enabled or disabled. *

      *
    • *
    • *

      * A set of DKIM tokens that represent the identity. If the identity is an email address, the tokens represent the * domain of that address. *

      *
    • *
    • *

      * Whether Amazon SES has successfully verified the DKIM tokens published in the domain's DNS. This information is * only returned for domain name identities, not for email addresses. *

      *
    • *
    *

    * This operation is throttled at one request per second and can only get DKIM attributes for up to 100 identities * at a time. *

    *

    * For more information about creating DNS records using DKIM tokens, go to the Amazon SES Developer * Guide. *

    * * @param getIdentityDkimAttributesRequest * Represents a request for the status of Amazon SES Easy DKIM signing for an identity. For domain * identities, this request also returns the DKIM tokens that are required for Easy DKIM signing, and whether * Amazon SES successfully verified that these tokens were published. For more information about Easy DKIM, * see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the GetIdentityDkimAttributes operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetIdentityDkimAttributes * @see AWS API Documentation */ @Override public CompletableFuture getIdentityDkimAttributes( GetIdentityDkimAttributesRequest getIdentityDkimAttributesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getIdentityDkimAttributesRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetIdentityDkimAttributes"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetIdentityDkimAttributesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetIdentityDkimAttributes") .withMarshaller(new GetIdentityDkimAttributesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getIdentityDkimAttributesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getIdentityDkimAttributesRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns the custom MAIL FROM attributes for a list of identities (email addresses : domains). *

    *

    * This operation is throttled at one request per second and can only get custom MAIL FROM attributes for up to 100 * identities at a time. *

    * * @param getIdentityMailFromDomainAttributesRequest * Represents a request to return the Amazon SES custom MAIL FROM attributes for a list of identities. For * information about using a custom MAIL FROM domain, see the Amazon SES Developer * Guide. * @return A Java Future containing the result of the GetIdentityMailFromDomainAttributes operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetIdentityMailFromDomainAttributes * @see AWS API Documentation */ @Override public CompletableFuture getIdentityMailFromDomainAttributes( GetIdentityMailFromDomainAttributesRequest getIdentityMailFromDomainAttributesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getIdentityMailFromDomainAttributesRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetIdentityMailFromDomainAttributes"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetIdentityMailFromDomainAttributesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetIdentityMailFromDomainAttributes") .withMarshaller(new GetIdentityMailFromDomainAttributesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getIdentityMailFromDomainAttributesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getIdentityMailFromDomainAttributesRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Given a list of verified identities (email addresses and/or domains), returns a structure describing identity * notification attributes. *

    *

    * This operation is throttled at one request per second and can only get notification attributes for up to 100 * identities at a time. *

    *

    * For more information about using notifications with Amazon SES, see the Amazon SES Developer Guide. *

    * * @param getIdentityNotificationAttributesRequest * Represents a request to return the notification attributes for a list of identities you verified with * Amazon SES. For information about Amazon SES notifications, see the Amazon SES Developer * Guide. * @return A Java Future containing the result of the GetIdentityNotificationAttributes operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetIdentityNotificationAttributes * @see AWS API Documentation */ @Override public CompletableFuture getIdentityNotificationAttributes( GetIdentityNotificationAttributesRequest getIdentityNotificationAttributesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getIdentityNotificationAttributesRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetIdentityNotificationAttributes"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetIdentityNotificationAttributesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetIdentityNotificationAttributes") .withMarshaller(new GetIdentityNotificationAttributesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getIdentityNotificationAttributesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getIdentityNotificationAttributesRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns the requested sending authorization policies for the given identity (an email address or a domain). The * policies are returned as a map of policy names to policy contents. You can retrieve a maximum of 20 policies at a * time. *

    * *

    * This API is for the identity owner only. If you have not verified the identity, this API will return an error. *

    *
    *

    * Sending authorization is a feature that enables an identity owner to authorize other senders to use its * identities. For information about using sending authorization, see the Amazon SES Developer * Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param getIdentityPoliciesRequest * Represents a request to return the requested sending authorization policies for an identity. Sending * authorization is an Amazon SES feature that enables you to authorize other senders to use your identities. * For information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the GetIdentityPolicies operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetIdentityPolicies * @see AWS API * Documentation */ @Override public CompletableFuture getIdentityPolicies( GetIdentityPoliciesRequest getIdentityPoliciesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getIdentityPoliciesRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetIdentityPolicies"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetIdentityPoliciesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetIdentityPolicies") .withMarshaller(new GetIdentityPoliciesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getIdentityPoliciesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getIdentityPoliciesRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Given a list of identities (email addresses and/or domains), returns the verification status and (for domain * identities) the verification token for each identity. *

    *

    * The verification status of an email address is "Pending" until the email address owner clicks the link within the * verification email that Amazon SES sent to that address. If the email address owner clicks the link within 24 * hours, the verification status of the email address changes to "Success". If the link is not clicked within 24 * hours, the verification status changes to "Failed." In that case, if you still want to verify the email address, * you must restart the verification process from the beginning. *

    *

    * For domain identities, the domain's verification status is "Pending" as Amazon SES searches for the required TXT * record in the DNS settings of the domain. When Amazon SES detects the record, the domain's verification status * changes to "Success". If Amazon SES is unable to detect the record within 72 hours, the domain's verification * status changes to "Failed." In that case, if you still want to verify the domain, you must restart the * verification process from the beginning. *

    *

    * This operation is throttled at one request per second and can only get verification attributes for up to 100 * identities at a time. *

    * * @param getIdentityVerificationAttributesRequest * Represents a request to return the Amazon SES verification status of a list of identities. For domain * identities, this request also returns the verification token. For information about verifying identities * with Amazon SES, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the GetIdentityVerificationAttributes operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetIdentityVerificationAttributes * @see AWS API Documentation */ @Override public CompletableFuture getIdentityVerificationAttributes( GetIdentityVerificationAttributesRequest getIdentityVerificationAttributesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getIdentityVerificationAttributesRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetIdentityVerificationAttributes"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetIdentityVerificationAttributesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetIdentityVerificationAttributes") .withMarshaller(new GetIdentityVerificationAttributesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getIdentityVerificationAttributesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getIdentityVerificationAttributesRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Provides the sending limits for the Amazon SES account. *

    *

    * You can execute this operation no more than once per second. *

    * * @param getSendQuotaRequest * @return A Java Future containing the result of the GetSendQuota operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetSendQuota * @see AWS API * Documentation */ @Override public CompletableFuture getSendQuota(GetSendQuotaRequest getSendQuotaRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getSendQuotaRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetSendQuota"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetSendQuotaResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetSendQuota").withMarshaller(new GetSendQuotaRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getSendQuotaRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getSendQuotaRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Provides sending statistics for the current AWS Region. The result is a list of data points, representing the * last two weeks of sending activity. Each data point in the list contains statistics for a 15-minute period of * time. *

    *

    * You can execute this operation no more than once per second. *

    * * @param getSendStatisticsRequest * @return A Java Future containing the result of the GetSendStatistics operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetSendStatistics * @see AWS API * Documentation */ @Override public CompletableFuture getSendStatistics(GetSendStatisticsRequest getSendStatisticsRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getSendStatisticsRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetSendStatistics"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetSendStatisticsResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetSendStatistics") .withMarshaller(new GetSendStatisticsRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getSendStatisticsRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getSendStatisticsRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Displays the template object (which includes the Subject line, HTML part and text part) for the template you * specify. *

    *

    * You can execute this operation no more than once per second. *

    * * @param getTemplateRequest * @return A Java Future containing the result of the GetTemplate operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • TemplateDoesNotExistException Indicates that the Template object you specified does not exist in your * Amazon SES account.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.GetTemplate * @see AWS API * Documentation */ @Override public CompletableFuture getTemplate(GetTemplateRequest getTemplateRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, getTemplateRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "GetTemplate"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(GetTemplateResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("GetTemplate").withMarshaller(new GetTemplateRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(getTemplateRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = getTemplateRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Provides a list of the configuration sets associated with your Amazon SES account in the current AWS Region. For * information about using configuration sets, see Monitoring Your Amazon * SES Sending Activity in the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. This operation will return up to 1,000 configuration * sets each time it is run. If your Amazon SES account has more than 1,000 configuration sets, this operation will * also return a NextToken element. You can then execute the ListConfigurationSets operation again, * passing the NextToken parameter and the value of the NextToken element to retrieve additional * results. *

    * * @param listConfigurationSetsRequest * Represents a request to list the configuration sets associated with your AWS account. Configuration sets * enable you to publish email sending events. For information about using configuration sets, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the ListConfigurationSets operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.ListConfigurationSets * @see AWS * API Documentation */ @Override public CompletableFuture listConfigurationSets( ListConfigurationSetsRequest listConfigurationSetsRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, listConfigurationSetsRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "ListConfigurationSets"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(ListConfigurationSetsResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("ListConfigurationSets") .withMarshaller(new ListConfigurationSetsRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(listConfigurationSetsRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = listConfigurationSetsRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Lists the existing custom verification email templates for your account in the current AWS Region. *

    *

    * For more information about custom verification email templates, see Using Custom * Verification Email Templates in the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param listCustomVerificationEmailTemplatesRequest * Represents a request to list the existing custom verification email templates for your account.

    *

    * For more information about custom verification email templates, see Using Custom * Verification Email Templates in the Amazon SES Developer Guide. * @return A Java Future containing the result of the ListCustomVerificationEmailTemplates operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *

      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • SdkClientException If any client side error occurs such as * an IO related failure, failure to get credentials, etc.
    • SesException Base class for all service * exceptions. Unknown exceptions will be thrown as an instance of this type.
    • *
    * @sample SesAsyncClient.ListCustomVerificationEmailTemplates * @see AWS API Documentation */ @Override public CompletableFuture listCustomVerificationEmailTemplates( ListCustomVerificationEmailTemplatesRequest listCustomVerificationEmailTemplatesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, listCustomVerificationEmailTemplatesRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "ListCustomVerificationEmailTemplates"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(ListCustomVerificationEmailTemplatesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("ListCustomVerificationEmailTemplates") .withMarshaller(new ListCustomVerificationEmailTemplatesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(listCustomVerificationEmailTemplatesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = listCustomVerificationEmailTemplatesRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Lists the existing custom verification email templates for your account in the current AWS Region. *

    *

    * For more information about custom verification email templates, see Using Custom * Verification Email Templates in the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    *
    *

    * This is a variant of * {@link #listCustomVerificationEmailTemplates(software.amazon.awssdk.services.ses.model.ListCustomVerificationEmailTemplatesRequest)} * operation. The return type is a custom publisher that can be subscribed to request a stream of response pages. * SDK will internally handle making service calls for you. *

    *

    * When the operation is called, an instance of this class is returned. At this point, no service calls are made yet * and so there is no guarantee that the request is valid. If there are errors in your request, you will see the * failures only after you start streaming the data. The subscribe method should be called as a request to start * streaming data. For more info, see * {@link org.reactivestreams.Publisher#subscribe(org.reactivestreams.Subscriber)}. Each call to the subscribe * method will result in a new {@link org.reactivestreams.Subscription} i.e., a new contract to stream data from the * starting request. *

    * *

    * The following are few ways to use the response class: *

    * 1) Using the subscribe helper method * *
         * {@code
         * software.amazon.awssdk.services.ses.paginators.ListCustomVerificationEmailTemplatesPublisher publisher = client.listCustomVerificationEmailTemplatesPaginator(request);
         * CompletableFuture future = publisher.subscribe(res -> { // Do something with the response });
         * future.get();
         * }
         * 
    * * 2) Using a custom subscriber * *
         * {@code
         * software.amazon.awssdk.services.ses.paginators.ListCustomVerificationEmailTemplatesPublisher publisher = client.listCustomVerificationEmailTemplatesPaginator(request);
         * publisher.subscribe(new Subscriber() {
         * 
         * public void onSubscribe(org.reactivestreams.Subscriber subscription) { //... };
         * 
         * 
         * public void onNext(software.amazon.awssdk.services.ses.model.ListCustomVerificationEmailTemplatesResponse response) { //... };
         * });}
         * 
    * * As the response is a publisher, it can work well with third party reactive streams implementations like RxJava2. *

    * Please notice that the configuration of MaxResults won't limit the number of results you get with the * paginator. It only limits the number of results in each page. *

    *

    * Note: If you prefer to have control on service calls, use the * {@link #listCustomVerificationEmailTemplates(software.amazon.awssdk.services.ses.model.ListCustomVerificationEmailTemplatesRequest)} * operation. *

    * * @param listCustomVerificationEmailTemplatesRequest * Represents a request to list the existing custom verification email templates for your account.

    *

    * For more information about custom verification email templates, see Using Custom * Verification Email Templates in the Amazon SES Developer Guide. * @return A custom publisher that can be subscribed to request a stream of response pages.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *

      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • SdkClientException If any client side error occurs such as * an IO related failure, failure to get credentials, etc.
    • SesException Base class for all service * exceptions. Unknown exceptions will be thrown as an instance of this type.
    • *
    * @sample SesAsyncClient.ListCustomVerificationEmailTemplates * @see AWS API Documentation */ public ListCustomVerificationEmailTemplatesPublisher listCustomVerificationEmailTemplatesPaginator( ListCustomVerificationEmailTemplatesRequest listCustomVerificationEmailTemplatesRequest) { return new ListCustomVerificationEmailTemplatesPublisher(this, applyPaginatorUserAgent(listCustomVerificationEmailTemplatesRequest)); } /** *

    * Returns a list containing all of the identities (email addresses and domains) for your AWS account in the current * AWS Region, regardless of verification status. *

    *

    * You can execute this operation no more than once per second. *

    * * @param listIdentitiesRequest * Represents a request to return a list of all identities (email addresses and domains) that you have * attempted to verify under your AWS account, regardless of verification status. * @return A Java Future containing the result of the ListIdentities operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.ListIdentities * @see AWS API * Documentation */ @Override public CompletableFuture listIdentities(ListIdentitiesRequest listIdentitiesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, listIdentitiesRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "ListIdentities"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(ListIdentitiesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("ListIdentities") .withMarshaller(new ListIdentitiesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(listIdentitiesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = listIdentitiesRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Returns a list containing all of the identities (email addresses and domains) for your AWS account in the current * AWS Region, regardless of verification status. *

    *

    * You can execute this operation no more than once per second. *

    *
    *

    * This is a variant of {@link #listIdentities(software.amazon.awssdk.services.ses.model.ListIdentitiesRequest)} * operation. The return type is a custom publisher that can be subscribed to request a stream of response pages. * SDK will internally handle making service calls for you. *

    *

    * When the operation is called, an instance of this class is returned. At this point, no service calls are made yet * and so there is no guarantee that the request is valid. If there are errors in your request, you will see the * failures only after you start streaming the data. The subscribe method should be called as a request to start * streaming data. For more info, see * {@link org.reactivestreams.Publisher#subscribe(org.reactivestreams.Subscriber)}. Each call to the subscribe * method will result in a new {@link org.reactivestreams.Subscription} i.e., a new contract to stream data from the * starting request. *

    * *

    * The following are few ways to use the response class: *

    * 1) Using the subscribe helper method * *
         * {@code
         * software.amazon.awssdk.services.ses.paginators.ListIdentitiesPublisher publisher = client.listIdentitiesPaginator(request);
         * CompletableFuture future = publisher.subscribe(res -> { // Do something with the response });
         * future.get();
         * }
         * 
    * * 2) Using a custom subscriber * *
         * {@code
         * software.amazon.awssdk.services.ses.paginators.ListIdentitiesPublisher publisher = client.listIdentitiesPaginator(request);
         * publisher.subscribe(new Subscriber() {
         * 
         * public void onSubscribe(org.reactivestreams.Subscriber subscription) { //... };
         * 
         * 
         * public void onNext(software.amazon.awssdk.services.ses.model.ListIdentitiesResponse response) { //... };
         * });}
         * 
    * * As the response is a publisher, it can work well with third party reactive streams implementations like RxJava2. *

    * Please notice that the configuration of MaxItems won't limit the number of results you get with the paginator. * It only limits the number of results in each page. *

    *

    * Note: If you prefer to have control on service calls, use the * {@link #listIdentities(software.amazon.awssdk.services.ses.model.ListIdentitiesRequest)} operation. *

    * * @param listIdentitiesRequest * Represents a request to return a list of all identities (email addresses and domains) that you have * attempted to verify under your AWS account, regardless of verification status. * @return A custom publisher that can be subscribed to request a stream of response pages.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.ListIdentities * @see AWS API * Documentation */ public ListIdentitiesPublisher listIdentitiesPaginator(ListIdentitiesRequest listIdentitiesRequest) { return new ListIdentitiesPublisher(this, applyPaginatorUserAgent(listIdentitiesRequest)); } /** *

    * Returns a list of sending authorization policies that are attached to the given identity (an email address or a * domain). This API returns only a list. If you want the actual policy content, you can use * GetIdentityPolicies. *

    * *

    * This API is for the identity owner only. If you have not verified the identity, this API will return an error. *

    *
    *

    * Sending authorization is a feature that enables an identity owner to authorize other senders to use its * identities. For information about using sending authorization, see the Amazon SES Developer * Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param listIdentityPoliciesRequest * Represents a request to return a list of sending authorization policies that are attached to an identity. * Sending authorization is an Amazon SES feature that enables you to authorize other senders to use your * identities. For information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the ListIdentityPolicies operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.ListIdentityPolicies * @see AWS API * Documentation */ @Override public CompletableFuture listIdentityPolicies( ListIdentityPoliciesRequest listIdentityPoliciesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, listIdentityPoliciesRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "ListIdentityPolicies"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(ListIdentityPoliciesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("ListIdentityPolicies") .withMarshaller(new ListIdentityPoliciesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(listIdentityPoliciesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = listIdentityPoliciesRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Lists the IP address filters associated with your AWS account in the current AWS Region. *

    *

    * For information about managing IP address filters, see the Amazon SES * Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param listReceiptFiltersRequest * Represents a request to list the IP address filters that exist under your AWS account. You use IP address * filters when you receive email with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the ListReceiptFilters operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.ListReceiptFilters * @see AWS API * Documentation */ @Override public CompletableFuture listReceiptFilters(ListReceiptFiltersRequest listReceiptFiltersRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, listReceiptFiltersRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "ListReceiptFilters"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(ListReceiptFiltersResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("ListReceiptFilters") .withMarshaller(new ListReceiptFiltersRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(listReceiptFiltersRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = listReceiptFiltersRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Lists the receipt rule sets that exist under your AWS account in the current AWS Region. If there are additional * receipt rule sets to be retrieved, you will receive a NextToken that you can provide to the next * call to ListReceiptRuleSets to retrieve the additional entries. *

    *

    * For information about managing receipt rule sets, see the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param listReceiptRuleSetsRequest * Represents a request to list the receipt rule sets that exist under your AWS account. You use receipt rule * sets to receive email with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the ListReceiptRuleSets operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.ListReceiptRuleSets * @see AWS API * Documentation */ @Override public CompletableFuture listReceiptRuleSets( ListReceiptRuleSetsRequest listReceiptRuleSetsRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, listReceiptRuleSetsRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "ListReceiptRuleSets"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(ListReceiptRuleSetsResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("ListReceiptRuleSets") .withMarshaller(new ListReceiptRuleSetsRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(listReceiptRuleSetsRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = listReceiptRuleSetsRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Lists the email templates present in your Amazon SES account in the current AWS Region. *

    *

    * You can execute this operation no more than once per second. *

    * * @param listTemplatesRequest * @return A Java Future containing the result of the ListTemplates operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.ListTemplates * @see AWS API * Documentation */ @Override public CompletableFuture listTemplates(ListTemplatesRequest listTemplatesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, listTemplatesRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "ListTemplates"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(ListTemplatesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("ListTemplates") .withMarshaller(new ListTemplatesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(listTemplatesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = listTemplatesRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Deprecated. Use the ListIdentities operation to list the email addresses and domains associated with * your account. *

    * * @param listVerifiedEmailAddressesRequest * @return A Java Future containing the result of the ListVerifiedEmailAddresses operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.ListVerifiedEmailAddresses * @see AWS API Documentation */ @Override public CompletableFuture listVerifiedEmailAddresses( ListVerifiedEmailAddressesRequest listVerifiedEmailAddressesRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, listVerifiedEmailAddressesRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "ListVerifiedEmailAddresses"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(ListVerifiedEmailAddressesResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("ListVerifiedEmailAddresses") .withMarshaller(new ListVerifiedEmailAddressesRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(listVerifiedEmailAddressesRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = listVerifiedEmailAddressesRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Adds or updates the delivery options for a configuration set. *

    * * @param putConfigurationSetDeliveryOptionsRequest * A request to modify the delivery options for a configuration set. * @return A Java Future containing the result of the PutConfigurationSetDeliveryOptions operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • InvalidDeliveryOptionsException Indicates that provided delivery option is invalid.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.PutConfigurationSetDeliveryOptions * @see AWS API Documentation */ @Override public CompletableFuture putConfigurationSetDeliveryOptions( PutConfigurationSetDeliveryOptionsRequest putConfigurationSetDeliveryOptionsRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, putConfigurationSetDeliveryOptionsRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "PutConfigurationSetDeliveryOptions"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(PutConfigurationSetDeliveryOptionsResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("PutConfigurationSetDeliveryOptions") .withMarshaller(new PutConfigurationSetDeliveryOptionsRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(putConfigurationSetDeliveryOptionsRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = putConfigurationSetDeliveryOptionsRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Adds or updates a sending authorization policy for the specified identity (an email address or a domain). *

    * *

    * This API is for the identity owner only. If you have not verified the identity, this API will return an error. *

    *
    *

    * Sending authorization is a feature that enables an identity owner to authorize other senders to use its * identities. For information about using sending authorization, see the Amazon SES Developer * Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param putIdentityPolicyRequest * Represents a request to add or update a sending authorization policy for an identity. Sending * authorization is an Amazon SES feature that enables you to authorize other senders to use your identities. * For information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the PutIdentityPolicy operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • InvalidPolicyException Indicates that the provided policy is invalid. Check the error stack for more * information about what caused the error.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.PutIdentityPolicy * @see AWS API * Documentation */ @Override public CompletableFuture putIdentityPolicy(PutIdentityPolicyRequest putIdentityPolicyRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, putIdentityPolicyRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "PutIdentityPolicy"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(PutIdentityPolicyResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("PutIdentityPolicy") .withMarshaller(new PutIdentityPolicyRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(putIdentityPolicyRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = putIdentityPolicyRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Reorders the receipt rules within a receipt rule set. *

    * *

    * All of the rules in the rule set must be represented in this request. That is, this API will return an error if * the reorder request doesn't explicitly position all of the rules. *

    *
    *

    * For information about managing receipt rule sets, see the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param reorderReceiptRuleSetRequest * Represents a request to reorder the receipt rules within a receipt rule set. You use receipt rule sets to * receive email with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the ReorderReceiptRuleSet operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • RuleSetDoesNotExistException Indicates that the provided receipt rule set does not exist.
    • *
    • RuleDoesNotExistException Indicates that the provided receipt rule does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.ReorderReceiptRuleSet * @see AWS * API Documentation */ @Override public CompletableFuture reorderReceiptRuleSet( ReorderReceiptRuleSetRequest reorderReceiptRuleSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, reorderReceiptRuleSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "ReorderReceiptRuleSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(ReorderReceiptRuleSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("ReorderReceiptRuleSet") .withMarshaller(new ReorderReceiptRuleSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(reorderReceiptRuleSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = reorderReceiptRuleSetRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Generates and sends a bounce message to the sender of an email you received through Amazon SES. You can only use * this API on an email up to 24 hours after you receive it. *

    * *

    * You cannot use this API to send generic bounces for mail that was not received by Amazon SES. *

    *
    *

    * For information about receiving email through Amazon SES, see the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param sendBounceRequest * Represents a request to send a bounce message to the sender of an email you received through Amazon SES. * @return A Java Future containing the result of the SendBounce operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • MessageRejectedException Indicates that the action failed, and the message could not be sent. Check * the error stack for more information about what caused the error.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SendBounce * @see AWS API * Documentation */ @Override public CompletableFuture sendBounce(SendBounceRequest sendBounceRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, sendBounceRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SendBounce"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SendBounceResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams().withOperationName("SendBounce") .withMarshaller(new SendBounceRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(sendBounceRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = sendBounceRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Composes an email message to multiple destinations. The message body is created using an email template. *

    *

    * In order to send email using the SendBulkTemplatedEmail operation, your call to the API must meet * the following requirements: *

    *
      *
    • *

      * The call must refer to an existing email template. You can create email templates using the CreateTemplate * operation. *

      *
    • *
    • *

      * The message must be sent from a verified email address or domain. *

      *
    • *
    • *

      * If your account is still in the Amazon SES sandbox, you may only send to verified addresses or domains, or to * email addresses associated with the Amazon SES Mailbox Simulator. For more information, see Verifying Email * Addresses and Domains in the Amazon SES Developer Guide. *

      *
    • *
    • *

      * The maximum message size is 10 MB. *

      *
    • *
    • *

      * Each Destination parameter must include at least one recipient email address. The recipient address * can be a To: address, a CC: address, or a BCC: address. If a recipient email address is invalid (that is, it is * not in the format UserName@[SubDomain.]Domain.TopLevelDomain), the entire message will be rejected, even * if the message contains other recipients that are valid. *

      *
    • *
    • *

      * The message may not include more than 50 recipients, across the To:, CC: and BCC: fields. If you need to send an * email message to a larger audience, you can divide your recipient list into groups of 50 or fewer, and then call * the SendBulkTemplatedEmail operation several times to send the message to each group. *

      *
    • *
    • *

      * The number of destinations you can contact in a single call to the API may be limited by your account's maximum * sending rate. *

      *
    • *
    * * @param sendBulkTemplatedEmailRequest * Represents a request to send a templated email to multiple destinations using Amazon SES. For more * information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the SendBulkTemplatedEmail operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • MessageRejectedException Indicates that the action failed, and the message could not be sent. Check * the error stack for more information about what caused the error.
    • *
    • MailFromDomainNotVerifiedException Indicates that the message could not be sent because Amazon SES * could not read the MX record required to use the specified MAIL FROM domain. For information about * editing the custom MAIL FROM domain settings for an identity, see the Amazon SES Developer * Guide.
    • *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • TemplateDoesNotExistException Indicates that the Template object you specified does not exist in your * Amazon SES account.
    • *
    • ConfigurationSetSendingPausedException Indicates that email sending is disabled for the configuration * set.

      *

      * You can enable or disable email sending for a configuration set using * UpdateConfigurationSetSendingEnabled.

    • *
    • AccountSendingPausedException Indicates that email sending is disabled for your entire Amazon SES * account.

      *

      * You can enable or disable email sending for your Amazon SES account using * UpdateAccountSendingEnabled.

    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SendBulkTemplatedEmail * @see AWS * API Documentation */ @Override public CompletableFuture sendBulkTemplatedEmail( SendBulkTemplatedEmailRequest sendBulkTemplatedEmailRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, sendBulkTemplatedEmailRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SendBulkTemplatedEmail"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SendBulkTemplatedEmailResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SendBulkTemplatedEmail") .withMarshaller(new SendBulkTemplatedEmailRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(sendBulkTemplatedEmailRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = sendBulkTemplatedEmailRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Adds an email address to the list of identities for your Amazon SES account in the current AWS Region and * attempts to verify it. As a result of executing this operation, a customized verification email is sent to the * specified address. *

    *

    * To use this operation, you must first create a custom verification email template. For more information about * creating and using custom verification email templates, see Using Custom * Verification Email Templates in the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param sendCustomVerificationEmailRequest * Represents a request to send a custom verification email to a specified recipient. * @return A Java Future containing the result of the SendCustomVerificationEmail operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • MessageRejectedException Indicates that the action failed, and the message could not be sent. Check * the error stack for more information about what caused the error.
    • *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • CustomVerificationEmailTemplateDoesNotExistException Indicates that a custom verification email * template with the name you specified does not exist.
    • *
    • FromEmailAddressNotVerifiedException Indicates that the sender address specified for a custom * verification email is not verified, and is therefore not eligible to send the custom verification email.
    • *
    • ProductionAccessNotGrantedException Indicates that the account has not been granted production * access.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SendCustomVerificationEmail * @see AWS API Documentation */ @Override public CompletableFuture sendCustomVerificationEmail( SendCustomVerificationEmailRequest sendCustomVerificationEmailRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, sendCustomVerificationEmailRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SendCustomVerificationEmail"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SendCustomVerificationEmailResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SendCustomVerificationEmail") .withMarshaller(new SendCustomVerificationEmailRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(sendCustomVerificationEmailRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = sendCustomVerificationEmailRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Composes an email message and immediately queues it for sending. In order to send email using the * SendEmail operation, your message must meet the following requirements: *

    *
      *
    • *

      * The message must be sent from a verified email address or domain. If you attempt to send email using a * non-verified address or domain, the operation will result in an "Email address not verified" error. *

      *
    • *
    • *

      * If your account is still in the Amazon SES sandbox, you may only send to verified addresses or domains, or to * email addresses associated with the Amazon SES Mailbox Simulator. For more information, see Verifying Email * Addresses and Domains in the Amazon SES Developer Guide. *

      *
    • *
    • *

      * The maximum message size is 10 MB. *

      *
    • *
    • *

      * The message must include at least one recipient email address. The recipient address can be a To: address, a CC: * address, or a BCC: address. If a recipient email address is invalid (that is, it is not in the format * UserName@[SubDomain.]Domain.TopLevelDomain), the entire message will be rejected, even if the message * contains other recipients that are valid. *

      *
    • *
    • *

      * The message may not include more than 50 recipients, across the To:, CC: and BCC: fields. If you need to send an * email message to a larger audience, you can divide your recipient list into groups of 50 or fewer, and then call * the SendEmail operation several times to send the message to each group. *

      *
    • *
    * *

    * For every message that you send, the total number of recipients (including each recipient in the To:, CC: and * BCC: fields) is counted against the maximum number of emails you can send in a 24-hour period (your sending * quota). For more information about sending quotas in Amazon SES, see Managing Your Amazon SES * Sending Limits in the Amazon SES Developer Guide. *

    *
    * * @param sendEmailRequest * Represents a request to send a single formatted email using Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the SendEmail operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • MessageRejectedException Indicates that the action failed, and the message could not be sent. Check * the error stack for more information about what caused the error.
    • *
    • MailFromDomainNotVerifiedException Indicates that the message could not be sent because Amazon SES * could not read the MX record required to use the specified MAIL FROM domain. For information about * editing the custom MAIL FROM domain settings for an identity, see the Amazon SES Developer * Guide.
    • *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • ConfigurationSetSendingPausedException Indicates that email sending is disabled for the configuration * set.

      *

      * You can enable or disable email sending for a configuration set using * UpdateConfigurationSetSendingEnabled.

    • *
    • AccountSendingPausedException Indicates that email sending is disabled for your entire Amazon SES * account.

      *

      * You can enable or disable email sending for your Amazon SES account using * UpdateAccountSendingEnabled.

    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SendEmail * @see AWS API * Documentation */ @Override public CompletableFuture sendEmail(SendEmailRequest sendEmailRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, sendEmailRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SendEmail"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SendEmailResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams().withOperationName("SendEmail") .withMarshaller(new SendEmailRequestMarshaller(protocolFactory)).withResponseHandler(responseHandler) .withErrorResponseHandler(errorResponseHandler).withMetricCollector(apiCallMetricCollector) .withInput(sendEmailRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = sendEmailRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Composes an email message and immediately queues it for sending. *

    *

    * This operation is more flexible than the SendEmail API operation. When you use the * SendRawEmail operation, you can specify the headers of the message as well as its content. This * flexibility is useful, for example, when you want to send a multipart MIME email (such a message that contains * both a text and an HTML version). You can also use this operation to send messages that include attachments. *

    *

    * The SendRawEmail operation has the following requirements: *

    *
      *
    • *

      * You can only send email from verified email * addresses or domains. If you try to send email from an address that isn't verified, the operation results in * an "Email address not verified" error. *

      *
    • *
    • *

      * If your account is still in the Amazon SES * sandbox, you can only send email to other verified addresses in your account, or to addresses that are * associated with the Amazon * SES mailbox simulator. *

      *
    • *
    • *

      * The maximum message size, including attachments, is 10 MB. *

      *
    • *
    • *

      * Each message has to include at least one recipient address. A recipient address includes any address on the To:, * CC:, or BCC: lines. *

      *
    • *
    • *

      * If you send a single message to more than one recipient address, and one of the recipient addresses isn't in a * valid format (that is, it's not in the format UserName@[SubDomain.]Domain.TopLevelDomain), Amazon SES * rejects the entire message, even if the other addresses are valid. *

      *
    • *
    • *

      * Each message can include up to 50 recipient addresses across the To:, CC:, or BCC: lines. If you need to send a * single message to more than 50 recipients, you have to split the list of recipient addresses into groups of less * than 50 recipients, and send separate messages to each group. *

      *
    • *
    • *

      * Amazon SES allows you to specify 8-bit Content-Transfer-Encoding for MIME message parts. However, if Amazon SES * has to modify the contents of your message (for example, if you use open and click tracking), 8-bit content isn't * preserved. For this reason, we highly recommend that you encode all content that isn't 7-bit ASCII. For more * information, see MIME * Encoding in the Amazon SES Developer Guide. *

      *
    • *
    *

    * Additionally, keep the following considerations in mind when using the SendRawEmail operation: *

    *
      *
    • *

      * Although you can customize the message headers when using the SendRawEmail operation, Amazon SES * will automatically apply its own Message-ID and Date headers; if you passed these * headers when creating the message, they will be overwritten by the values that Amazon SES provides. *

      *
    • *
    • *

      * If you are using sending authorization to send on behalf of another user, SendRawEmail enables you * to specify the cross-account identity for the email's Source, From, and Return-Path parameters in one of two * ways: you can pass optional parameters SourceArn, FromArn, and/or * ReturnPathArn to the API, or you can include the following X-headers in the header of your raw * email: *

      *
        *
      • *

        * X-SES-SOURCE-ARN *

        *
      • *
      • *

        * X-SES-FROM-ARN *

        *
      • *
      • *

        * X-SES-RETURN-PATH-ARN *

        *
      • *
      * *

      * Don't include these X-headers in the DKIM signature. Amazon SES removes these before it sends the email. *

      *
      *

      * If you only specify the SourceIdentityArn parameter, Amazon SES sets the From and Return-Path * addresses to the same identity that you specified. *

      *

      * For more information about sending authorization, see the Using Sending * Authorization with Amazon SES in the Amazon SES Developer Guide. *

      *
    • *
    • *

      * For every message that you send, the total number of recipients (including each recipient in the To:, CC: and * BCC: fields) is counted against the maximum number of emails you can send in a 24-hour period (your sending * quota). For more information about sending quotas in Amazon SES, see Managing Your Amazon SES * Sending Limits in the Amazon SES Developer Guide. *

      *
    • *
    * * @param sendRawEmailRequest * Represents a request to send a single raw email using Amazon SES. For more information, see the Amazon SES Developer * Guide. * @return A Java Future containing the result of the SendRawEmail operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • MessageRejectedException Indicates that the action failed, and the message could not be sent. Check * the error stack for more information about what caused the error.
    • *
    • MailFromDomainNotVerifiedException Indicates that the message could not be sent because Amazon SES * could not read the MX record required to use the specified MAIL FROM domain. For information about * editing the custom MAIL FROM domain settings for an identity, see the Amazon SES Developer * Guide.
    • *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • ConfigurationSetSendingPausedException Indicates that email sending is disabled for the configuration * set.

      *

      * You can enable or disable email sending for a configuration set using * UpdateConfigurationSetSendingEnabled.

    • *
    • AccountSendingPausedException Indicates that email sending is disabled for your entire Amazon SES * account.

      *

      * You can enable or disable email sending for your Amazon SES account using * UpdateAccountSendingEnabled.

    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SendRawEmail * @see AWS API * Documentation */ @Override public CompletableFuture sendRawEmail(SendRawEmailRequest sendRawEmailRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, sendRawEmailRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SendRawEmail"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SendRawEmailResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SendRawEmail").withMarshaller(new SendRawEmailRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(sendRawEmailRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = sendRawEmailRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Composes an email message using an email template and immediately queues it for sending. *

    *

    * In order to send email using the SendTemplatedEmail operation, your call to the API must meet the * following requirements: *

    *
      *
    • *

      * The call must refer to an existing email template. You can create email templates using the CreateTemplate * operation. *

      *
    • *
    • *

      * The message must be sent from a verified email address or domain. *

      *
    • *
    • *

      * If your account is still in the Amazon SES sandbox, you may only send to verified addresses or domains, or to * email addresses associated with the Amazon SES Mailbox Simulator. For more information, see Verifying Email * Addresses and Domains in the Amazon SES Developer Guide. *

      *
    • *
    • *

      * The maximum message size is 10 MB. *

      *
    • *
    • *

      * Calls to the SendTemplatedEmail operation may only include one Destination parameter. A * destination is a set of recipients who will receive the same version of the email. The Destination * parameter can include up to 50 recipients, across the To:, CC: and BCC: fields. *

      *
    • *
    • *

      * The Destination parameter must include at least one recipient email address. The recipient address * can be a To: address, a CC: address, or a BCC: address. If a recipient email address is invalid (that is, it is * not in the format UserName@[SubDomain.]Domain.TopLevelDomain), the entire message will be rejected, even * if the message contains other recipients that are valid. *

      *
    • *
    * *

    * If your call to the SendTemplatedEmail operation includes all of the required parameters, Amazon SES * accepts it and returns a Message ID. However, if Amazon SES can't render the email because the template contains * errors, it doesn't send the email. Additionally, because it already accepted the message, Amazon SES doesn't * return a message stating that it was unable to send the email. *

    *

    * For these reasons, we highly recommend that you set up Amazon SES to send you notifications when Rendering * Failure events occur. For more information, see Sending * Personalized Email Using the Amazon SES API in the Amazon Simple Email Service Developer Guide. *

    *
    * * @param sendTemplatedEmailRequest * Represents a request to send a templated email using Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the SendTemplatedEmail operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • MessageRejectedException Indicates that the action failed, and the message could not be sent. Check * the error stack for more information about what caused the error.
    • *
    • MailFromDomainNotVerifiedException Indicates that the message could not be sent because Amazon SES * could not read the MX record required to use the specified MAIL FROM domain. For information about * editing the custom MAIL FROM domain settings for an identity, see the Amazon SES Developer * Guide.
    • *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • TemplateDoesNotExistException Indicates that the Template object you specified does not exist in your * Amazon SES account.
    • *
    • ConfigurationSetSendingPausedException Indicates that email sending is disabled for the configuration * set.

      *

      * You can enable or disable email sending for a configuration set using * UpdateConfigurationSetSendingEnabled.

    • *
    • AccountSendingPausedException Indicates that email sending is disabled for your entire Amazon SES * account.

      *

      * You can enable or disable email sending for your Amazon SES account using * UpdateAccountSendingEnabled.

    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SendTemplatedEmail * @see AWS API * Documentation */ @Override public CompletableFuture sendTemplatedEmail(SendTemplatedEmailRequest sendTemplatedEmailRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, sendTemplatedEmailRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SendTemplatedEmail"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SendTemplatedEmailResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SendTemplatedEmail") .withMarshaller(new SendTemplatedEmailRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(sendTemplatedEmailRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = sendTemplatedEmailRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Sets the specified receipt rule set as the active receipt rule set. *

    * *

    * To disable your email-receiving through Amazon SES completely, you can call this API with RuleSetName set to * null. *

    *
    *

    * For information about managing receipt rule sets, see the Amazon SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param setActiveReceiptRuleSetRequest * Represents a request to set a receipt rule set as the active receipt rule set. You use receipt rule sets * to receive email with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the SetActiveReceiptRuleSet operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • RuleSetDoesNotExistException Indicates that the provided receipt rule set does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SetActiveReceiptRuleSet * @see AWS * API Documentation */ @Override public CompletableFuture setActiveReceiptRuleSet( SetActiveReceiptRuleSetRequest setActiveReceiptRuleSetRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, setActiveReceiptRuleSetRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SetActiveReceiptRuleSet"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SetActiveReceiptRuleSetResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SetActiveReceiptRuleSet") .withMarshaller(new SetActiveReceiptRuleSetRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(setActiveReceiptRuleSetRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = setActiveReceiptRuleSetRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Enables or disables Easy DKIM signing of email sent from an identity. If Easy DKIM signing is enabled for a * domain, then Amazon SES uses DKIM to sign all email that it sends from addresses on that domain. If Easy DKIM * signing is enabled for an email address, then Amazon SES uses DKIM to sign all email it sends from that address. *

    * *

    * For email addresses (for example, [email protected]), you can only enable DKIM signing if the * corresponding domain (in this case, example.com) has been set up to use Easy DKIM. *

    *
    *

    * You can enable DKIM signing for an identity at any time after you start the verification process for the * identity, even if the verification process isn't complete. *

    *

    * You can execute this operation no more than once per second. *

    *

    * For more information about Easy DKIM signing, go to the Amazon SES Developer Guide. *

    * * @param setIdentityDkimEnabledRequest * Represents a request to enable or disable Amazon SES Easy DKIM signing for an identity. For more * information about setting up Easy DKIM, see the Amazon SES Developer * Guide. * @return A Java Future containing the result of the SetIdentityDkimEnabled operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SetIdentityDkimEnabled * @see AWS * API Documentation */ @Override public CompletableFuture setIdentityDkimEnabled( SetIdentityDkimEnabledRequest setIdentityDkimEnabledRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, setIdentityDkimEnabledRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SetIdentityDkimEnabled"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SetIdentityDkimEnabledResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SetIdentityDkimEnabled") .withMarshaller(new SetIdentityDkimEnabledRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(setIdentityDkimEnabledRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = setIdentityDkimEnabledRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Given an identity (an email address or a domain), enables or disables whether Amazon SES forwards bounce and * complaint notifications as email. Feedback forwarding can only be disabled when Amazon Simple Notification * Service (Amazon SNS) topics are specified for both bounces and complaints. *

    * *

    * Feedback forwarding does not apply to delivery notifications. Delivery notifications are only available through * Amazon SNS. *

    *
    *

    * You can execute this operation no more than once per second. *

    *

    * For more information about using notifications with Amazon SES, see the Amazon SES Developer Guide. *

    * * @param setIdentityFeedbackForwardingEnabledRequest * Represents a request to enable or disable whether Amazon SES forwards you bounce and complaint * notifications through email. For information about email feedback forwarding, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the SetIdentityFeedbackForwardingEnabled operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SetIdentityFeedbackForwardingEnabled * @see AWS API Documentation */ @Override public CompletableFuture setIdentityFeedbackForwardingEnabled( SetIdentityFeedbackForwardingEnabledRequest setIdentityFeedbackForwardingEnabledRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, setIdentityFeedbackForwardingEnabledRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SetIdentityFeedbackForwardingEnabled"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SetIdentityFeedbackForwardingEnabledResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SetIdentityFeedbackForwardingEnabled") .withMarshaller(new SetIdentityFeedbackForwardingEnabledRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(setIdentityFeedbackForwardingEnabledRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = setIdentityFeedbackForwardingEnabledRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Given an identity (an email address or a domain), sets whether Amazon SES includes the original email headers in * the Amazon Simple Notification Service (Amazon SNS) notifications of a specified type. *

    *

    * You can execute this operation no more than once per second. *

    *

    * For more information about using notifications with Amazon SES, see the Amazon SES Developer Guide. *

    * * @param setIdentityHeadersInNotificationsEnabledRequest * Represents a request to set whether Amazon SES includes the original email headers in the Amazon SNS * notifications of a specified type. For information about notifications, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the SetIdentityHeadersInNotificationsEnabled operation returned by * the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SetIdentityHeadersInNotificationsEnabled * @see AWS API Documentation */ @Override public CompletableFuture setIdentityHeadersInNotificationsEnabled( SetIdentityHeadersInNotificationsEnabledRequest setIdentityHeadersInNotificationsEnabledRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, setIdentityHeadersInNotificationsEnabledRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SetIdentityHeadersInNotificationsEnabled"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SetIdentityHeadersInNotificationsEnabledResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SetIdentityHeadersInNotificationsEnabled") .withMarshaller(new SetIdentityHeadersInNotificationsEnabledRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector) .withInput(setIdentityHeadersInNotificationsEnabledRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = setIdentityHeadersInNotificationsEnabledRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Enables or disables the custom MAIL FROM domain setup for a verified identity (an email address or a domain). *

    * *

    * To send emails using the specified MAIL FROM domain, you must add an MX record to your MAIL FROM domain's DNS * settings. If you want your emails to pass Sender Policy Framework (SPF) checks, you must also add or update an * SPF record. For more information, see the Amazon SES Developer Guide. *

    *
    *

    * You can execute this operation no more than once per second. *

    * * @param setIdentityMailFromDomainRequest * Represents a request to enable or disable the Amazon SES custom MAIL FROM domain setup for a verified * identity. For information about using a custom MAIL FROM domain, see the Amazon SES Developer * Guide. * @return A Java Future containing the result of the SetIdentityMailFromDomain operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SetIdentityMailFromDomain * @see AWS API Documentation */ @Override public CompletableFuture setIdentityMailFromDomain( SetIdentityMailFromDomainRequest setIdentityMailFromDomainRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, setIdentityMailFromDomainRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SetIdentityMailFromDomain"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SetIdentityMailFromDomainResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SetIdentityMailFromDomain") .withMarshaller(new SetIdentityMailFromDomainRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(setIdentityMailFromDomainRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = setIdentityMailFromDomainRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Sets an Amazon Simple Notification Service (Amazon SNS) topic to use when delivering notifications. When you use * this operation, you specify a verified identity, such as an email address or domain. When you send an email that * uses the chosen identity in the Source field, Amazon SES sends notifications to the topic you specified. You can * send bounce, complaint, or delivery notifications (or any combination of the three) to the Amazon SNS topic that * you specify. *

    *

    * You can execute this operation no more than once per second. *

    *

    * For more information about feedback notification, see the Amazon SES Developer Guide. *

    * * @param setIdentityNotificationTopicRequest * Represents a request to specify the Amazon SNS topic to which Amazon SES will publish bounce, complaint, * or delivery notifications for emails sent with that identity as the Source. For information about Amazon * SES notifications, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the SetIdentityNotificationTopic operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SetIdentityNotificationTopic * @see AWS API Documentation */ @Override public CompletableFuture setIdentityNotificationTopic( SetIdentityNotificationTopicRequest setIdentityNotificationTopicRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, setIdentityNotificationTopicRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SetIdentityNotificationTopic"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SetIdentityNotificationTopicResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SetIdentityNotificationTopic") .withMarshaller(new SetIdentityNotificationTopicRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(setIdentityNotificationTopicRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = setIdentityNotificationTopicRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Sets the position of the specified receipt rule in the receipt rule set. *

    *

    * For information about managing receipt rules, see the Amazon * SES Developer Guide. *

    *

    * You can execute this operation no more than once per second. *

    * * @param setReceiptRulePositionRequest * Represents a request to set the position of a receipt rule in a receipt rule set. You use receipt rule * sets to receive email with Amazon SES. For more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the SetReceiptRulePosition operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • RuleSetDoesNotExistException Indicates that the provided receipt rule set does not exist.
    • *
    • RuleDoesNotExistException Indicates that the provided receipt rule does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.SetReceiptRulePosition * @see AWS * API Documentation */ @Override public CompletableFuture setReceiptRulePosition( SetReceiptRulePositionRequest setReceiptRulePositionRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, setReceiptRulePositionRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "SetReceiptRulePosition"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(SetReceiptRulePositionResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("SetReceiptRulePosition") .withMarshaller(new SetReceiptRulePositionRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(setReceiptRulePositionRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = setReceiptRulePositionRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Creates a preview of the MIME content of an email when provided with a template and a set of replacement data. *

    *

    * You can execute this operation no more than once per second. *

    * * @param testRenderTemplateRequest * @return A Java Future containing the result of the TestRenderTemplate operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • TemplateDoesNotExistException Indicates that the Template object you specified does not exist in your * Amazon SES account.
    • *
    • InvalidRenderingParameterException Indicates that one or more of the replacement values you provided * is invalid. This error may occur when the TemplateData object contains invalid JSON.
    • *
    • MissingRenderingAttributeException Indicates that one or more of the replacement values for the * specified template was not specified. Ensure that the TemplateData object contains references to all of * the replacement tags in the specified template.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.TestRenderTemplate * @see AWS API * Documentation */ @Override public CompletableFuture testRenderTemplate(TestRenderTemplateRequest testRenderTemplateRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, testRenderTemplateRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "TestRenderTemplate"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(TestRenderTemplateResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("TestRenderTemplate") .withMarshaller(new TestRenderTemplateRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(testRenderTemplateRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = testRenderTemplateRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Enables or disables email sending across your entire Amazon SES account in the current AWS Region. You can use * this operation in conjunction with Amazon CloudWatch alarms to temporarily pause email sending across your Amazon * SES account in a given AWS Region when reputation metrics (such as your bounce or complaint rates) reach certain * thresholds. *

    *

    * You can execute this operation no more than once per second. *

    * * @param updateAccountSendingEnabledRequest * Represents a request to enable or disable the email sending capabilities for your entire Amazon SES * account. * @return A Java Future containing the result of the UpdateAccountSendingEnabled operation returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.UpdateAccountSendingEnabled * @see AWS API Documentation */ @Override public CompletableFuture updateAccountSendingEnabled( UpdateAccountSendingEnabledRequest updateAccountSendingEnabledRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, updateAccountSendingEnabledRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "UpdateAccountSendingEnabled"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(UpdateAccountSendingEnabledResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("UpdateAccountSendingEnabled") .withMarshaller(new UpdateAccountSendingEnabledRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(updateAccountSendingEnabledRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = updateAccountSendingEnabledRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Updates the event destination of a configuration set. Event destinations are associated with configuration sets, * which enable you to publish email sending events to Amazon CloudWatch, Amazon Kinesis Firehose, or Amazon Simple * Notification Service (Amazon SNS). For information about using configuration sets, see Monitoring Your Amazon * SES Sending Activity in the Amazon SES Developer Guide. *

    * *

    * When you create or update an event destination, you must provide one, and only one, destination. The destination * can be Amazon CloudWatch, Amazon Kinesis Firehose, or Amazon Simple Notification Service (Amazon SNS). *

    *
    *

    * You can execute this operation no more than once per second. *

    * * @param updateConfigurationSetEventDestinationRequest * Represents a request to update the event destination of a configuration set. Configuration sets enable you * to publish email sending events. For information about using configuration sets, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the UpdateConfigurationSetEventDestination operation returned by * the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • EventDestinationDoesNotExistException Indicates that the event destination does not exist.
    • *
    • InvalidCloudWatchDestinationException Indicates that the Amazon CloudWatch destination is invalid. * See the error message for details.
    • *
    • InvalidFirehoseDestinationException Indicates that the Amazon Kinesis Firehose destination is * invalid. See the error message for details.
    • *
    • InvalidSnsDestinationException Indicates that the Amazon Simple Notification Service (Amazon SNS) * destination is invalid. See the error message for details.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.UpdateConfigurationSetEventDestination * @see AWS API Documentation */ @Override public CompletableFuture updateConfigurationSetEventDestination( UpdateConfigurationSetEventDestinationRequest updateConfigurationSetEventDestinationRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, updateConfigurationSetEventDestinationRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "UpdateConfigurationSetEventDestination"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(UpdateConfigurationSetEventDestinationResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("UpdateConfigurationSetEventDestination") .withMarshaller(new UpdateConfigurationSetEventDestinationRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(updateConfigurationSetEventDestinationRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = updateConfigurationSetEventDestinationRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Enables or disables the publishing of reputation metrics for emails sent using a specific configuration set in a * given AWS Region. Reputation metrics include bounce and complaint rates. These metrics are published to Amazon * CloudWatch. By using CloudWatch, you can create alarms when bounce or complaint rates exceed certain thresholds. *

    *

    * You can execute this operation no more than once per second. *

    * * @param updateConfigurationSetReputationMetricsEnabledRequest * Represents a request to modify the reputation metric publishing settings for a configuration set. * @return A Java Future containing the result of the UpdateConfigurationSetReputationMetricsEnabled operation * returned by the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.UpdateConfigurationSetReputationMetricsEnabled * @see AWS API Documentation */ @Override public CompletableFuture updateConfigurationSetReputationMetricsEnabled( UpdateConfigurationSetReputationMetricsEnabledRequest updateConfigurationSetReputationMetricsEnabledRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, updateConfigurationSetReputationMetricsEnabledRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "UpdateConfigurationSetReputationMetricsEnabled"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(UpdateConfigurationSetReputationMetricsEnabledResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("UpdateConfigurationSetReputationMetricsEnabled") .withMarshaller(new UpdateConfigurationSetReputationMetricsEnabledRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector) .withInput(updateConfigurationSetReputationMetricsEnabledRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = updateConfigurationSetReputationMetricsEnabledRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Enables or disables email sending for messages sent using a specific configuration set in a given AWS Region. You * can use this operation in conjunction with Amazon CloudWatch alarms to temporarily pause email sending for a * configuration set when the reputation metrics for that configuration set (such as your bounce on complaint rate) * exceed certain thresholds. *

    *

    * You can execute this operation no more than once per second. *

    * * @param updateConfigurationSetSendingEnabledRequest * Represents a request to enable or disable the email sending capabilities for a specific configuration set. * @return A Java Future containing the result of the UpdateConfigurationSetSendingEnabled operation returned by the * service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
    • *
    • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
    • *
    • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
    • *
    * @sample SesAsyncClient.UpdateConfigurationSetSendingEnabled * @see AWS API Documentation */ @Override public CompletableFuture updateConfigurationSetSendingEnabled( UpdateConfigurationSetSendingEnabledRequest updateConfigurationSetSendingEnabledRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, updateConfigurationSetSendingEnabledRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "UpdateConfigurationSetSendingEnabled"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(UpdateConfigurationSetSendingEnabledResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("UpdateConfigurationSetSendingEnabled") .withMarshaller(new UpdateConfigurationSetSendingEnabledRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(updateConfigurationSetSendingEnabledRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = updateConfigurationSetSendingEnabledRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

    * Modifies an association between a configuration set and a custom domain for open and click event tracking. *

    *

    * By default, images and links used for tracking open and click events are hosted on domains operated by Amazon * SES. You can configure a subdomain of your own to handle these events. For information about using custom * domains, see the Amazon SES * Developer Guide. *

    * * @param updateConfigurationSetTrackingOptionsRequest * Represents a request to update the tracking options for a configuration set. * @return A Java Future containing the result of the UpdateConfigurationSetTrackingOptions operation returned by * the service.
    * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
      *
    • ConfigurationSetDoesNotExistException Indicates that the configuration set does not exist.
    • *
    • TrackingOptionsDoesNotExistException Indicates that the TrackingOptions object you specified does not * exist.
    • *
    • InvalidTrackingOptionsException Indicates that the custom domain to be used for open and click * tracking redirects is invalid. This error appears most often in the following situations:

      *
        *
      • *

        * When the tracking domain you specified is not verified in Amazon SES. *

        *
      • *
      • *

        * When the tracking domain you specified is not a valid domain or subdomain. *

        *
      • *
      • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
      • *
      • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
      • *
      • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
      • *
      * @sample SesAsyncClient.UpdateConfigurationSetTrackingOptions * @see AWS API Documentation */ @Override public CompletableFuture updateConfigurationSetTrackingOptions( UpdateConfigurationSetTrackingOptionsRequest updateConfigurationSetTrackingOptionsRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, updateConfigurationSetTrackingOptionsRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "UpdateConfigurationSetTrackingOptions"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(UpdateConfigurationSetTrackingOptionsResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("UpdateConfigurationSetTrackingOptions") .withMarshaller(new UpdateConfigurationSetTrackingOptionsRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(updateConfigurationSetTrackingOptionsRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = updateConfigurationSetTrackingOptionsRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

      * Updates an existing custom verification email template. *

      *

      * For more information about custom verification email templates, see Using Custom * Verification Email Templates in the Amazon SES Developer Guide. *

      *

      * You can execute this operation no more than once per second. *

      * * @param updateCustomVerificationEmailTemplateRequest * Represents a request to update an existing custom verification email template. * @return A Java Future containing the result of the UpdateCustomVerificationEmailTemplate operation returned by * the service.
      * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
        *
      • CustomVerificationEmailTemplateDoesNotExistException Indicates that a custom verification email * template with the name you specified does not exist.
      • *
      • FromEmailAddressNotVerifiedException Indicates that the sender address specified for a custom * verification email is not verified, and is therefore not eligible to send the custom verification email.
      • *
      • CustomVerificationEmailInvalidContentException Indicates that custom verification email template * provided content is invalid.
      • *
      • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
      • *
      • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
      • *
      • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
      • *
      * @sample SesAsyncClient.UpdateCustomVerificationEmailTemplate * @see AWS API Documentation */ @Override public CompletableFuture updateCustomVerificationEmailTemplate( UpdateCustomVerificationEmailTemplateRequest updateCustomVerificationEmailTemplateRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, updateCustomVerificationEmailTemplateRequest.overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "UpdateCustomVerificationEmailTemplate"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(UpdateCustomVerificationEmailTemplateResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("UpdateCustomVerificationEmailTemplate") .withMarshaller(new UpdateCustomVerificationEmailTemplateRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(updateCustomVerificationEmailTemplateRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = updateCustomVerificationEmailTemplateRequest .overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

      * Updates a receipt rule. *

      *

      * For information about managing receipt rules, see the Amazon * SES Developer Guide. *

      *

      * You can execute this operation no more than once per second. *

      * * @param updateReceiptRuleRequest * Represents a request to update a receipt rule. You use receipt rules to receive email with Amazon SES. For * more information, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the UpdateReceiptRule operation returned by the service.
      * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
        *
      • InvalidSnsTopicException Indicates that the provided Amazon SNS topic is invalid, or that Amazon SES * could not publish to the topic, possibly due to permissions issues. For information about giving * permissions, see the Amazon SES * Developer Guide.
      • *
      • InvalidS3ConfigurationException Indicates that the provided Amazon S3 bucket or AWS KMS encryption * key is invalid, or that Amazon SES could not publish to the bucket, possibly due to permissions issues. * For information about giving permissions, see the Amazon SES * Developer Guide.
      • *
      • InvalidLambdaFunctionException Indicates that the provided AWS Lambda function is invalid, or that * Amazon SES could not execute the provided function, possibly due to permissions issues. For information * about giving permissions, see the Amazon SES * Developer Guide.
      • *
      • RuleSetDoesNotExistException Indicates that the provided receipt rule set does not exist.
      • *
      • RuleDoesNotExistException Indicates that the provided receipt rule does not exist.
      • *
      • LimitExceededException Indicates that a resource could not be created because of service limits. For * a list of Amazon SES limits, see the Amazon SES Developer Guide.
      • *
      • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
      • *
      • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
      • *
      • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
      • *
      * @sample SesAsyncClient.UpdateReceiptRule * @see AWS API * Documentation */ @Override public CompletableFuture updateReceiptRule(UpdateReceiptRuleRequest updateReceiptRuleRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, updateReceiptRuleRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "UpdateReceiptRule"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(UpdateReceiptRuleResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("UpdateReceiptRule") .withMarshaller(new UpdateReceiptRuleRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(updateReceiptRuleRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = updateReceiptRuleRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

      * Updates an email template. Email templates enable you to send personalized email to one or more destinations in a * single API operation. For more information, see the Amazon SES * Developer Guide. *

      *

      * You can execute this operation no more than once per second. *

      * * @param updateTemplateRequest * @return A Java Future containing the result of the UpdateTemplate operation returned by the service.
      * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
        *
      • TemplateDoesNotExistException Indicates that the Template object you specified does not exist in your * Amazon SES account.
      • *
      • InvalidTemplateException Indicates that the template that you specified could not be rendered. This * issue may occur when a template refers to a partial that does not exist.
      • *
      • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
      • *
      • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
      • *
      • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
      • *
      * @sample SesAsyncClient.UpdateTemplate * @see AWS API * Documentation */ @Override public CompletableFuture updateTemplate(UpdateTemplateRequest updateTemplateRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, updateTemplateRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "UpdateTemplate"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(UpdateTemplateResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("UpdateTemplate") .withMarshaller(new UpdateTemplateRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(updateTemplateRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = updateTemplateRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

      * Returns a set of DKIM tokens for a domain identity. *

      * *

      * When you execute the VerifyDomainDkim operation, the domain that you specify is added to the list of * identities that are associated with your account. This is true even if you haven't already associated the domain * with your account by using the VerifyDomainIdentity operation. However, you can't send email from * the domain until you either successfully verify it or you * successfully set up DKIM for * it. *

      *
      *

      * You use the tokens that are generated by this operation to create CNAME records. When Amazon SES detects that * you've added these records to the DNS configuration for a domain, you can start sending email from that domain. * You can start sending email even if you haven't added the TXT record provided by the VerifyDomainIdentity * operation to the DNS configuration for your domain. All email that you send from the domain is authenticated * using DKIM. *

      *

      * To create the CNAME records for DKIM authentication, use the following values: *

      *
        *
      • *

        * Name: token._domainkey.example.com *

        *
      • *
      • *

        * Type: CNAME *

        *
      • *
      • *

        * Value: token.dkim.amazonses.com *

        *
      • *
      *

      * In the preceding example, replace token with one of the tokens that are generated when you execute this * operation. Replace example.com with your domain. Repeat this process for each token that's generated by * this operation. *

      *

      * You can execute this operation no more than once per second. *

      * * @param verifyDomainDkimRequest * Represents a request to generate the CNAME records needed to set up Easy DKIM with Amazon SES. For more * information about setting up Easy DKIM, see the Amazon SES Developer * Guide. * @return A Java Future containing the result of the VerifyDomainDkim operation returned by the service.
      * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
        *
      • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
      • *
      • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
      • *
      • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
      • *
      * @sample SesAsyncClient.VerifyDomainDkim * @see AWS API * Documentation */ @Override public CompletableFuture verifyDomainDkim(VerifyDomainDkimRequest verifyDomainDkimRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, verifyDomainDkimRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "VerifyDomainDkim"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(VerifyDomainDkimResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("VerifyDomainDkim") .withMarshaller(new VerifyDomainDkimRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(verifyDomainDkimRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = verifyDomainDkimRequest.overrideConfiguration().orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

      * Adds a domain to the list of identities for your Amazon SES account in the current AWS Region and attempts to * verify it. For more information about verifying domains, see Verifying Email * Addresses and Domains in the Amazon SES Developer Guide. *

      *

      * You can execute this operation no more than once per second. *

      * * @param verifyDomainIdentityRequest * Represents a request to begin Amazon SES domain verification and to generate the TXT records that you must * publish to the DNS server of your domain to complete the verification. For information about domain * verification, see the Amazon SES Developer * Guide. * @return A Java Future containing the result of the VerifyDomainIdentity operation returned by the service.
      * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
        *
      • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
      • *
      • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
      • *
      • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
      • *
      * @sample SesAsyncClient.VerifyDomainIdentity * @see AWS API * Documentation */ @Override public CompletableFuture verifyDomainIdentity( VerifyDomainIdentityRequest verifyDomainIdentityRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, verifyDomainIdentityRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "VerifyDomainIdentity"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(VerifyDomainIdentityResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("VerifyDomainIdentity") .withMarshaller(new VerifyDomainIdentityRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(verifyDomainIdentityRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = verifyDomainIdentityRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

      * Deprecated. Use the VerifyEmailIdentity operation to verify a new email address. *

      * * @param verifyEmailAddressRequest * Represents a request to begin email address verification with Amazon SES. For information about email * address verification, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the VerifyEmailAddress operation returned by the service.
      * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
        *
      • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
      • *
      • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
      • *
      • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
      • *
      * @sample SesAsyncClient.VerifyEmailAddress * @see AWS API * Documentation */ @Override public CompletableFuture verifyEmailAddress(VerifyEmailAddressRequest verifyEmailAddressRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, verifyEmailAddressRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "VerifyEmailAddress"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(VerifyEmailAddressResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("VerifyEmailAddress") .withMarshaller(new VerifyEmailAddressRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(verifyEmailAddressRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = verifyEmailAddressRequest.overrideConfiguration() .orElse(null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } /** *

      * Adds an email address to the list of identities for your Amazon SES account in the current AWS region and * attempts to verify it. As a result of executing this operation, a verification email is sent to the specified * address. *

      *

      * You can execute this operation no more than once per second. *

      * * @param verifyEmailIdentityRequest * Represents a request to begin email address verification with Amazon SES. For information about email * address verification, see the Amazon SES * Developer Guide. * @return A Java Future containing the result of the VerifyEmailIdentity operation returned by the service.
      * The CompletableFuture returned by this method can be completed exceptionally with the following * exceptions. *
        *
      • SdkException Base class for all exceptions that can be thrown by the SDK (both service and client). * Can be used for catch all scenarios.
      • *
      • SdkClientException If any client side error occurs such as an IO related failure, failure to get * credentials, etc.
      • *
      • SesException Base class for all service exceptions. Unknown exceptions will be thrown as an instance * of this type.
      • *
      * @sample SesAsyncClient.VerifyEmailIdentity * @see AWS API * Documentation */ @Override public CompletableFuture verifyEmailIdentity( VerifyEmailIdentityRequest verifyEmailIdentityRequest) { List metricPublishers = resolveMetricPublishers(clientConfiguration, verifyEmailIdentityRequest .overrideConfiguration().orElse(null)); MetricCollector apiCallMetricCollector = metricPublishers.isEmpty() ? NoOpMetricCollector.create() : MetricCollector .create("ApiCall"); try { apiCallMetricCollector.reportMetric(CoreMetric.SERVICE_ID, "SES"); apiCallMetricCollector.reportMetric(CoreMetric.OPERATION_NAME, "VerifyEmailIdentity"); HttpResponseHandler responseHandler = protocolFactory .createResponseHandler(VerifyEmailIdentityResponse::builder); HttpResponseHandler errorResponseHandler = protocolFactory.createErrorResponseHandler(); CompletableFuture executeFuture = clientHandler .execute(new ClientExecutionParams() .withOperationName("VerifyEmailIdentity") .withMarshaller(new VerifyEmailIdentityRequestMarshaller(protocolFactory)) .withResponseHandler(responseHandler).withErrorResponseHandler(errorResponseHandler) .withMetricCollector(apiCallMetricCollector).withInput(verifyEmailIdentityRequest)); AwsRequestOverrideConfiguration requestOverrideConfig = verifyEmailIdentityRequest.overrideConfiguration().orElse( null); CompletableFuture whenCompleteFuture = null; whenCompleteFuture = executeFuture.whenComplete((r, e) -> { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); }); return CompletableFutureUtils.forwardExceptionTo(whenCompleteFuture, executeFuture); } catch (Throwable t) { metricPublishers.forEach(p -> p.publish(apiCallMetricCollector.collect())); return CompletableFutureUtils.failedFuture(t); } } @Override public void close() { clientHandler.close(); } private AwsQueryProtocolFactory init() { return AwsQueryProtocolFactory .builder() .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidFirehoseDestination") .exceptionBuilderSupplier(InvalidFirehoseDestinationException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidS3Configuration") .exceptionBuilderSupplier(InvalidS3ConfigurationException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidDeliveryOptions") .exceptionBuilderSupplier(InvalidDeliveryOptionsException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidRenderingParameter") .exceptionBuilderSupplier(InvalidRenderingParameterException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidSNSDestination") .exceptionBuilderSupplier(InvalidSnsDestinationException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("MessageRejected") .exceptionBuilderSupplier(MessageRejectedException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidCloudWatchDestination") .exceptionBuilderSupplier(InvalidCloudWatchDestinationException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("AccountSendingPausedException") .exceptionBuilderSupplier(AccountSendingPausedException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("RuleSetDoesNotExist") .exceptionBuilderSupplier(RuleSetDoesNotExistException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidSnsTopic") .exceptionBuilderSupplier(InvalidSnsTopicException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("LimitExceeded") .exceptionBuilderSupplier(LimitExceededException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("ConfigurationSetSendingPausedException") .exceptionBuilderSupplier(ConfigurationSetSendingPausedException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("EventDestinationDoesNotExist") .exceptionBuilderSupplier(EventDestinationDoesNotExistException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidLambdaFunction") .exceptionBuilderSupplier(InvalidLambdaFunctionException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("TemplateDoesNotExist") .exceptionBuilderSupplier(TemplateDoesNotExistException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("MissingRenderingAttribute") .exceptionBuilderSupplier(MissingRenderingAttributeException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("AlreadyExists") .exceptionBuilderSupplier(AlreadyExistsException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("CannotDelete") .exceptionBuilderSupplier(CannotDeleteException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("TrackingOptionsAlreadyExistsException") .exceptionBuilderSupplier(TrackingOptionsAlreadyExistsException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("ConfigurationSetAlreadyExists") .exceptionBuilderSupplier(ConfigurationSetAlreadyExistsException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("CustomVerificationEmailInvalidContent") .exceptionBuilderSupplier(CustomVerificationEmailInvalidContentException::builder) .httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidTemplate") .exceptionBuilderSupplier(InvalidTemplateException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("MailFromDomainNotVerifiedException") .exceptionBuilderSupplier(MailFromDomainNotVerifiedException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("ConfigurationSetDoesNotExist") .exceptionBuilderSupplier(ConfigurationSetDoesNotExistException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("ProductionAccessNotGranted") .exceptionBuilderSupplier(ProductionAccessNotGrantedException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidTrackingOptions") .exceptionBuilderSupplier(InvalidTrackingOptionsException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("TrackingOptionsDoesNotExistException") .exceptionBuilderSupplier(TrackingOptionsDoesNotExistException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("EventDestinationAlreadyExists") .exceptionBuilderSupplier(EventDestinationAlreadyExistsException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("FromEmailAddressNotVerified") .exceptionBuilderSupplier(FromEmailAddressNotVerifiedException::builder).httpStatusCode(400) .build()) .registerModeledException( ExceptionMetadata.builder().errorCode("RuleDoesNotExist") .exceptionBuilderSupplier(RuleDoesNotExistException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidConfigurationSet") .exceptionBuilderSupplier(InvalidConfigurationSetException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("CustomVerificationEmailTemplateDoesNotExist") .exceptionBuilderSupplier(CustomVerificationEmailTemplateDoesNotExistException::builder) .httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("InvalidPolicy") .exceptionBuilderSupplier(InvalidPolicyException::builder).httpStatusCode(400).build()) .registerModeledException( ExceptionMetadata.builder().errorCode("CustomVerificationEmailTemplateAlreadyExists") .exceptionBuilderSupplier(CustomVerificationEmailTemplateAlreadyExistsException::builder) .httpStatusCode(400).build()).clientConfiguration(clientConfiguration) .defaultServiceExceptionSupplier(SesException::builder).build(); } private static List resolveMetricPublishers(SdkClientConfiguration clientConfiguration, RequestOverrideConfiguration requestOverrideConfiguration) { List publishers = null; if (requestOverrideConfiguration != null) { publishers = requestOverrideConfiguration.metricPublishers(); } if (publishers == null || publishers.isEmpty()) { publishers = clientConfiguration.option(SdkClientOption.METRIC_PUBLISHERS); } if (publishers == null) { publishers = Collections.emptyList(); } return publishers; } private T applyPaginatorUserAgent(T request) { Consumer userAgentApplier = b -> b.addApiName(ApiName.builder() .version(VersionInfo.SDK_VERSION).name("PAGINATED").build()); AwsRequestOverrideConfiguration overrideConfiguration = request.overrideConfiguration() .map(c -> c.toBuilder().applyMutation(userAgentApplier).build()) .orElse((AwsRequestOverrideConfiguration.builder().applyMutation(userAgentApplier).build())); return (T) request.toBuilder().overrideConfiguration(overrideConfiguration).build(); } @Override public SesAsyncWaiter waiter() { return SesAsyncWaiter.builder().client(this).scheduledExecutorService(executorService).build(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy