// Code generated by private/model/cli/gen-api/main.go. DO NOT EDIT. package ses import ( "context" "fmt" "github.com/aws/aws-sdk-go-v2/aws" "github.com/aws/aws-sdk-go-v2/internal/awsutil" ) // Represents a request to send a templated email using Amazon SES. For more // information, see the Amazon SES Developer Guide (https://docs.aws.amazon.com/ses/latest/DeveloperGuide/send-personalized-email-api.html). type SendTemplatedEmailInput struct { _ struct{} `type:"structure"` // The name of the configuration set to use when you send an email using SendTemplatedEmail. ConfigurationSetName *string `type:"string"` // The destination for this email, composed of To:, CC:, and BCC: fields. A // Destination can include up to 50 recipients across these three fields. // // Destination is a required field Destination *Destination `type:"structure" required:"true"` // The reply-to email address(es) for the message. If the recipient replies // to the message, each reply-to address will receive the reply. ReplyToAddresses []string `type:"list"` // The email address that bounces and complaints will be forwarded to when feedback // forwarding is enabled. If the message cannot be delivered to the recipient, // then an error message will be returned from the recipient's ISP; this message // will then be forwarded to the email address specified by the ReturnPath parameter. // The ReturnPath parameter is never overwritten. This email address must be // either individually verified with Amazon SES, or from a domain that has been // verified with Amazon SES. ReturnPath *string `type:"string"` // 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 ReturnPath 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 ReturnPathArn to be arn:aws:ses:us-east-1:123456789012:identity/example.com, // and the ReturnPath 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). ReturnPathArn *string `type:"string"` // The email address that is sending the email. This email address must be either // individually verified with Amazon SES, or from a domain that has been verified // with Amazon SES. For information about verifying identities, see the Amazon // SES Developer Guide (https://docs.aws.amazon.com/ses/latest/DeveloperGuide/verify-addresses-and-domains.html). // // If you are sending on behalf of another user and have been permitted to do // so by a sending authorization policy, then you must also specify the SourceArn // parameter. For more information about sending authorization, see the Amazon // SES Developer Guide (https://docs.aws.amazon.com/ses/latest/DeveloperGuide/sending-authorization.html). // // Amazon SES does not support the SMTPUTF8 extension, as described in RFC6531 // (https://tools.ietf.org/html/rfc6531). For this reason, the local part of // a source email address (the part of the email address that precedes the @ // sign) may only contain 7-bit ASCII characters (https://en.wikipedia.org/wiki/Email_address#Local-part). // If the domain part of an address (the part after the @ sign) contains non-ASCII // characters, they must be encoded using Punycode, as described in RFC3492 // (https://tools.ietf.org/html/rfc3492.html). The sender name (also known as // the friendly name) may contain non-ASCII characters. These characters must // be encoded using MIME encoded-word syntax, as described inRFC 2047 (https://tools.ietf.org/html/rfc2047). // MIME encoded-word syntax uses the following form: =?charset?encoding?encoded-text?=. // // Source is a required field Source *string `type:"string" required:"true"` // 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 send for the email address specified in the Source 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 send from user@example.com, // then you would specify the SourceArn to be arn:aws:ses:us-east-1:123456789012:identity/example.com, // and the Source to be user@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). SourceArn *string `type:"string"` // A list of tags, in the form of name/value pairs, to apply to an email that // you send using SendTemplatedEmail. Tags correspond to characteristics of // the email that you define, so that you can publish email sending events. Tags []MessageTag `type:"list"` // The template to use when sending this email. // // Template is a required field Template *string `type:"string" required:"true"` // The ARN of the template to use when sending this email. TemplateArn *string `type:"string"` // A list of replacement values to apply to the template. This parameter is // a JSON object, typically consisting of key-value pairs in which the keys // correspond to replacement tags in the email template. // // TemplateData is a required field TemplateData *string `type:"string" required:"true"` } // String returns the string representation func (s SendTemplatedEmailInput) String() string { return awsutil.Prettify(s) } // Validate inspects the fields of the type to determine if they are valid. func (s *SendTemplatedEmailInput) Validate() error { invalidParams := aws.ErrInvalidParams{Context: "SendTemplatedEmailInput"} if s.Destination == nil { invalidParams.Add(aws.NewErrParamRequired("Destination")) } if s.Source == nil { invalidParams.Add(aws.NewErrParamRequired("Source")) } if s.Template == nil { invalidParams.Add(aws.NewErrParamRequired("Template")) } if s.TemplateData == nil { invalidParams.Add(aws.NewErrParamRequired("TemplateData")) } if s.Tags != nil { for i, v := range s.Tags { if err := v.Validate(); err != nil { invalidParams.AddNested(fmt.Sprintf("%s[%v]", "Tags", i), err.(aws.ErrInvalidParams)) } } } if invalidParams.Len() > 0 { return invalidParams } return nil } type SendTemplatedEmailOutput struct { _ struct{} `type:"structure"` // The unique message identifier returned from the SendTemplatedEmail action. // // MessageId is a required field MessageId *string `type:"string" required:"true"` } // String returns the string representation func (s SendTemplatedEmailOutput) String() string { return awsutil.Prettify(s) } const opSendTemplatedEmail = "SendTemplatedEmail" // SendTemplatedEmailRequest returns a request value for making API operation for // Amazon Simple Email Service. // // 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 (https://docs.aws.amazon.com/ses/latest/DeveloperGuide/verify-addresses-and-domains.html) // 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 (https://docs.aws.amazon.com/ses/latest/DeveloperGuide/send-personalized-email-api.html) // in the Amazon Simple Email Service Developer Guide. // // // Example sending a request using SendTemplatedEmailRequest. // req := client.SendTemplatedEmailRequest(params) // resp, err := req.Send(context.TODO()) // if err == nil { // fmt.Println(resp) // } // // Please also see https://docs.aws.amazon.com/goto/WebAPI/email-2010-12-01/SendTemplatedEmail func (c *Client) SendTemplatedEmailRequest(input *SendTemplatedEmailInput) SendTemplatedEmailRequest { op := &aws.Operation{ Name: opSendTemplatedEmail, HTTPMethod: "POST", HTTPPath: "/", } if input == nil { input = &SendTemplatedEmailInput{} } req := c.newRequest(op, input, &SendTemplatedEmailOutput{}) return SendTemplatedEmailRequest{Request: req, Input: input, Copy: c.SendTemplatedEmailRequest} } // SendTemplatedEmailRequest is the request type for the // SendTemplatedEmail API operation. type SendTemplatedEmailRequest struct { *aws.Request Input *SendTemplatedEmailInput Copy func(*SendTemplatedEmailInput) SendTemplatedEmailRequest } // Send marshals and sends the SendTemplatedEmail API request. func (r SendTemplatedEmailRequest) Send(ctx context.Context) (*SendTemplatedEmailResponse, error) { r.Request.SetContext(ctx) err := r.Request.Send() if err != nil { return nil, err } resp := &SendTemplatedEmailResponse{ SendTemplatedEmailOutput: r.Request.Data.(*SendTemplatedEmailOutput), response: &aws.Response{Request: r.Request}, } return resp, nil } // SendTemplatedEmailResponse is the response type for the // SendTemplatedEmail API operation. type SendTemplatedEmailResponse struct { *SendTemplatedEmailOutput response *aws.Response } // SDKResponseMetdata returns the response metadata for the // SendTemplatedEmail request. func (r *SendTemplatedEmailResponse) SDKResponseMetdata() *aws.Response { return r.response }