// Code generated by smithy-go-codegen DO NOT EDIT. package sesv2 import ( "context" awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware" "github.com/aws/aws-sdk-go-v2/aws/signer/v4" "github.com/aws/aws-sdk-go-v2/service/sesv2/types" "github.com/aws/smithy-go/middleware" smithyhttp "github.com/aws/smithy-go/transport/http" ) // Starts the process of verifying an email identity. An identity is an email // address or domain that you use when you send email. Before you can use an // identity to send email, you first have to verify it. By verifying an identity, // you demonstrate that you're the owner of the identity, and that you've given // Amazon SES API v2 permission to send email from the identity. When you verify an // email address, Amazon SES sends an email to the address. Your email address is // verified as soon as you follow the link in the verification email. When you // verify a domain without specifying the DkimSigningAttributes object, this // operation provides a set of DKIM tokens. You can convert these tokens into CNAME // records, which you then add to the DNS configuration for your domain. Your // domain is verified when Amazon SES detects these records in the DNS // configuration for your domain. This verification method is known as Easy DKIM (https://docs.aws.amazon.com/ses/latest/DeveloperGuide/easy-dkim.html) // . Alternatively, you can perform the verification process by providing your own // public-private key pair. This verification method is known as Bring Your Own // DKIM (BYODKIM). To use BYODKIM, your call to the CreateEmailIdentity operation // has to include the DkimSigningAttributes object. When you specify this object, // you provide a selector (a component of the DNS record name that identifies the // public key to use for DKIM authentication) and a private key. When you verify a // domain, this operation provides a set of DKIM tokens, which you can convert into // CNAME tokens. You add these CNAME tokens to the DNS configuration for your // domain. Your domain is verified when Amazon SES detects these records in the DNS // configuration for your domain. For some DNS providers, it can take 72 hours or // more to complete the domain verification process. Additionally, you can // associate an existing configuration set with the email identity that you're // verifying. func (c *Client) CreateEmailIdentity(ctx context.Context, params *CreateEmailIdentityInput, optFns ...func(*Options)) (*CreateEmailIdentityOutput, error) { if params == nil { params = &CreateEmailIdentityInput{} } result, metadata, err := c.invokeOperation(ctx, "CreateEmailIdentity", params, optFns, c.addOperationCreateEmailIdentityMiddlewares) if err != nil { return nil, err } out := result.(*CreateEmailIdentityOutput) out.ResultMetadata = metadata return out, nil } // A request to begin the verification process for an email identity (an email // address or domain). type CreateEmailIdentityInput struct { // The email address or domain to verify. // // This member is required. EmailIdentity *string // The configuration set to use by default when sending from this identity. Note // that any configuration set defined in the email sending request takes // precedence. ConfigurationSetName *string // If your request includes this object, Amazon SES configures the identity to use // Bring Your Own DKIM (BYODKIM) for DKIM authentication purposes, or, configures // the key length to be used for Easy DKIM (https://docs.aws.amazon.com/ses/latest/DeveloperGuide/easy-dkim.html) // . You can only specify this object if the email identity is a domain, as opposed // to an address. DkimSigningAttributes *types.DkimSigningAttributes // An array of objects that define the tags (keys and values) to associate with // the email identity. Tags []types.Tag noSmithyDocumentSerde } // If the email identity is a domain, this object contains information about the // DKIM verification status for the domain. If the email identity is an email // address, this object is empty. type CreateEmailIdentityOutput struct { // An object that contains information about the DKIM attributes for the identity. DkimAttributes *types.DkimAttributes // The email identity type. Note: the MANAGED_DOMAIN identity type is not // supported. IdentityType types.IdentityType // Specifies whether or not the identity is verified. You can only send email from // verified email addresses or domains. For more information about verifying // identities, see the Amazon Pinpoint User Guide (https://docs.aws.amazon.com/pinpoint/latest/userguide/channels-email-manage-verify.html) // . VerifiedForSendingStatus bool // Metadata pertaining to the operation's result. ResultMetadata middleware.Metadata noSmithyDocumentSerde } func (c *Client) addOperationCreateEmailIdentityMiddlewares(stack *middleware.Stack, options Options) (err error) { err = stack.Serialize.Add(&awsRestjson1_serializeOpCreateEmailIdentity{}, middleware.After) if err != nil { return err } err = stack.Deserialize.Add(&awsRestjson1_deserializeOpCreateEmailIdentity{}, middleware.After) if err != nil { return err } if err = addSetLoggerMiddleware(stack, options); err != nil { return err } if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil { return err } if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil { return err } if err = addResolveEndpointMiddleware(stack, options); err != nil { return err } if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil { return err } if err = addRetryMiddlewares(stack, options); err != nil { return err } if err = addHTTPSignerV4Middleware(stack, options); err != nil { return err } if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil { return err } if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil { return err } if err = addClientUserAgent(stack, options); err != nil { return err } if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil { return err } if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil { return err } if err = addOpCreateEmailIdentityValidationMiddleware(stack); err != nil { return err } if err = stack.Initialize.Add(newServiceMetadataMiddleware_opCreateEmailIdentity(options.Region), middleware.Before); err != nil { return err } if err = awsmiddleware.AddRecursionDetection(stack); err != nil { return err } if err = addRequestIDRetrieverMiddleware(stack); err != nil { return err } if err = addResponseErrorMiddleware(stack); err != nil { return err } if err = addRequestResponseLogging(stack, options); err != nil { return err } return nil } func newServiceMetadataMiddleware_opCreateEmailIdentity(region string) *awsmiddleware.RegisterServiceMetadata { return &awsmiddleware.RegisterServiceMetadata{ Region: region, ServiceID: ServiceID, SigningName: "ses", OperationName: "CreateEmailIdentity", } }