

# SendBulkEmail


Composes an email message to multiple destinations.

## Request Syntax


```
POST /v2/email/outbound-bulk-emails HTTP/1.1
Content-type: application/json

{
   "BulkEmailEntries": [ 
      { 
         "Destination": { 
            "BccAddresses": [ "string" ],
            "CcAddresses": [ "string" ],
            "ToAddresses": [ "string" ]
         },
         "ReplacementEmailContent": { 
            "ReplacementTemplate": { 
               "ReplacementTemplateData": "string"
            }
         },
         "ReplacementHeaders": [ 
            { 
               "Name": "string",
               "Value": "string"
            }
         ],
         "ReplacementTags": [ 
            { 
               "Name": "string",
               "Value": "string"
            }
         ]
      }
   ],
   "ConfigurationSetName": "string",
   "DefaultContent": { 
      "Template": { 
         "Attachments": [ 
            { 
               "ContentDescription": "string",
               "ContentDisposition": "string",
               "ContentId": "string",
               "ContentTransferEncoding": "string",
               "ContentType": "string",
               "FileName": "string",
               "RawContent": blob
            }
         ],
         "Headers": [ 
            { 
               "Name": "string",
               "Value": "string"
            }
         ],
         "TemplateArn": "string",
         "TemplateContent": { 
            "Html": "string",
            "Subject": "string",
            "Text": "string"
         },
         "TemplateData": "string",
         "TemplateName": "string"
      }
   },
   "DefaultEmailTags": [ 
      { 
         "Name": "string",
         "Value": "string"
      }
   ],
   "EndpointId": "string",
   "FeedbackForwardingEmailAddress": "string",
   "FeedbackForwardingEmailAddressIdentityArn": "string",
   "FromEmailAddress": "string",
   "FromEmailAddressIdentityArn": "string",
   "ReplyToAddresses": [ "string" ],
   "TenantName": "string"
}
```

## URI Request Parameters


The request does not use any URI parameters.

## Request Body


The request accepts the following data in JSON format.

 ** [BulkEmailEntries](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-BulkEmailEntries"></a>
The list of bulk email entry objects.  
Type: Array of [BulkEmailEntry](API_BulkEmailEntry.md) objects  
Required: Yes

 ** [ConfigurationSetName](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-ConfigurationSetName"></a>
The name of the configuration set to use when sending the email.  
Type: String  
Required: No

 ** [DefaultContent](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-DefaultContent"></a>
An object that contains the body of the message. You can specify a template message.  
Type: [BulkEmailContent](API_BulkEmailContent.md) object  
Required: Yes

 ** [DefaultEmailTags](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-DefaultEmailTags"></a>
A list of tags, in the form of name/value pairs, to apply to an email that you send using the `SendEmail` operation. Tags correspond to characteristics of the email that you define, so that you can publish email sending events.  
Type: Array of [MessageTag](API_MessageTag.md) objects  
Required: No

 ** [EndpointId](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-EndpointId"></a>
The ID of the multi-region endpoint (global-endpoint).  
Type: String  
Required: No

 ** [FeedbackForwardingEmailAddress](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-FeedbackForwardingEmailAddress"></a>
The address that you want bounce and complaint notifications to be sent to.  
Type: String  
Required: No

 ** [FeedbackForwardingEmailAddressIdentityArn](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-FeedbackForwardingEmailAddressIdentityArn"></a>
This parameter is used only for sending authorization. It is the ARN of the identity that is associated with the sending authorization policy that permits you to use the email address specified in the `FeedbackForwardingEmailAddress` parameter.  
For example, if the owner of example.com (which has ARN arn:aws:ses:us-east-1:123456789012:identity/example.com) attaches a policy to it that authorizes you to use feedback@example.com, then you would specify the `FeedbackForwardingEmailAddressIdentityArn` to be arn:aws:ses:us-east-1:123456789012:identity/example.com, and the `FeedbackForwardingEmailAddress` to be feedback@example.com.  
For more information about sending authorization, see the [Amazon SES Developer Guide](https://docs.aws.amazon.com/ses/latest/DeveloperGuide/sending-authorization.html).  
Type: String  
Length Constraints: Minimum length of 1.  
Required: No

 ** [FromEmailAddress](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-FromEmailAddress"></a>
The email address to use as the "From" address for the email. The address that you specify has to be verified.  
Type: String  
Required: No

 ** [FromEmailAddressIdentityArn](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-FromEmailAddressIdentityArn"></a>
This parameter is used only for sending authorization. It is the ARN of the identity that is associated with the sending authorization policy that permits you to use the email address specified in the `FromEmailAddress` parameter.  
For example, if the owner of example.com (which has ARN arn:aws:ses:us-east-1:123456789012:identity/example.com) attaches a policy to it that authorizes you to use sender@example.com, then you would specify the `FromEmailAddressIdentityArn` to be arn:aws:ses:us-east-1:123456789012:identity/example.com, and the `FromEmailAddress` to be sender@example.com.  
For more information about sending authorization, see the [Amazon SES Developer Guide](https://docs.aws.amazon.com/ses/latest/DeveloperGuide/sending-authorization.html).  
Type: String  
Length Constraints: Minimum length of 1.  
Required: No

 ** [ReplyToAddresses](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-ReplyToAddresses"></a>
The "Reply-to" email addresses for the message. When the recipient replies to the message, each Reply-to address receives the reply.  
Type: Array of strings  
Required: No

 ** [TenantName](#API_SendBulkEmail_RequestSyntax) **   <a name="SES-SendBulkEmail-request-TenantName"></a>
The name of the tenant through which this bulk email will be sent.  
 The email sending operation will only succeed if all referenced resources (identities, configuration sets, and templates) are associated with this tenant. 
Type: String  
Length Constraints: Minimum length of 1.  
Required: No

## Response Syntax


```
HTTP/1.1 200
Content-type: application/json

{
   "BulkEmailEntryResults": [ 
      { 
         "Error": "string",
         "MessageId": "string",
         "Status": "string"
      }
   ]
}
```

## Response Elements


If the action is successful, the service sends back an HTTP 200 response.

The following data is returned in JSON format by the service.

 ** [BulkEmailEntryResults](#API_SendBulkEmail_ResponseSyntax) **   <a name="SES-SendBulkEmail-response-BulkEmailEntryResults"></a>
One object per intended recipient. Check each response object and retry any messages with a failure status.  
Type: Array of [BulkEmailEntryResult](API_BulkEmailEntryResult.md) objects

## Errors


For information about the errors that are common to all actions, see [Common Error Types](CommonErrors.md).

 ** AccountSuspendedException **   
The message can't be sent because the account's ability to send email has been permanently restricted.  
HTTP Status Code: 400

 ** BadRequestException **   
The input you provided is invalid.  
HTTP Status Code: 400

 ** LimitExceededException **   
There are too many instances of the specified resource type.  
HTTP Status Code: 400

 ** MailFromDomainNotVerifiedException **   
The message can't be sent because the sending domain isn't verified.  
HTTP Status Code: 400

 ** MessageRejected **   
The message can't be sent because it contains invalid content.  
HTTP Status Code: 400

 ** NotFoundException **   
The resource you attempted to access doesn't exist.  
HTTP Status Code: 404

 ** SendingPausedException **   
The message can't be sent because the account's ability to send email is currently paused.  
HTTP Status Code: 400

 ** TooManyRequestsException **   
Too many requests have been made to the operation.  
HTTP Status Code: 429

## See Also


For more information about using this API in one of the language-specific AWS SDKs, see the following:
+  [AWS Command Line Interface V2](https://docs.aws.amazon.com/goto/cli2/sesv2-2019-09-27/SendBulkEmail) 
+  [AWS SDK for .NET V4](https://docs.aws.amazon.com/goto/DotNetSDKV4/sesv2-2019-09-27/SendBulkEmail) 
+  [AWS SDK for C\$1\$1](https://docs.aws.amazon.com/goto/SdkForCpp/sesv2-2019-09-27/SendBulkEmail) 
+  [AWS SDK for Go v2](https://docs.aws.amazon.com/goto/SdkForGoV2/sesv2-2019-09-27/SendBulkEmail) 
+  [AWS SDK for Java V2](https://docs.aws.amazon.com/goto/SdkForJavaV2/sesv2-2019-09-27/SendBulkEmail) 
+  [AWS SDK for JavaScript V3](https://docs.aws.amazon.com/goto/SdkForJavaScriptV3/sesv2-2019-09-27/SendBulkEmail) 
+  [AWS SDK for Kotlin](https://docs.aws.amazon.com/goto/SdkForKotlin/sesv2-2019-09-27/SendBulkEmail) 
+  [AWS SDK for PHP V3](https://docs.aws.amazon.com/goto/SdkForPHPV3/sesv2-2019-09-27/SendBulkEmail) 
+  [AWS SDK for Python](https://docs.aws.amazon.com/goto/boto3/sesv2-2019-09-27/SendBulkEmail) 
+  [AWS SDK for Ruby V3](https://docs.aws.amazon.com/goto/SdkForRubyV3/sesv2-2019-09-27/SendBulkEmail) 