mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-08 15:13:56 -06:00
d637885dc3
``` % make testacc TEST=./builtin/providers/aws TESTARGS='-run=TestAccAwsSESDomainIdentity_' ==> Checking that code complies with gofmt requirements... go generate $(go list ./... | grep -v /terraform/vendor/) 2017/05/09 13:05:15 Generated command/internal_plugin_list.go TF_ACC=1 go test ./builtin/providers/aws -v -run=TestAccAwsSESDomainIdentity_ -timeout 120m === RUN TestAccAwsSESDomainIdentity_basic --- PASS: TestAccAwsSESDomainIdentity_basic (23.53s) PASS ok github.com/hashicorp/terraform/builtin/providers/aws 23.545s ```
104 lines
2.5 KiB
Go
104 lines
2.5 KiB
Go
package aws
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
|
|
"github.com/aws/aws-sdk-go/aws"
|
|
"github.com/aws/aws-sdk-go/service/ses"
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
)
|
|
|
|
func resourceAwsSesDomainIdentity() *schema.Resource {
|
|
return &schema.Resource{
|
|
Create: resourceAwsSesDomainIdentityCreate,
|
|
Read: resourceAwsSesDomainIdentityRead,
|
|
Delete: resourceAwsSesDomainIdentityDelete,
|
|
Importer: &schema.ResourceImporter{
|
|
State: schema.ImportStatePassthrough,
|
|
},
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
"arn": {
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
"domain": {
|
|
Type: schema.TypeString,
|
|
Required: true,
|
|
ForceNew: true,
|
|
},
|
|
"verification_token": {
|
|
Type: schema.TypeString,
|
|
Computed: true,
|
|
},
|
|
},
|
|
}
|
|
}
|
|
|
|
func resourceAwsSesDomainIdentityCreate(d *schema.ResourceData, meta interface{}) error {
|
|
conn := meta.(*AWSClient).sesConn
|
|
|
|
domainName := d.Get("domain").(string)
|
|
|
|
createOpts := &ses.VerifyDomainIdentityInput{
|
|
Domain: aws.String(domainName),
|
|
}
|
|
|
|
_, err := conn.VerifyDomainIdentity(createOpts)
|
|
if err != nil {
|
|
return fmt.Errorf("Error requesting SES domain identity verification: %s", err)
|
|
}
|
|
|
|
d.SetId(domainName)
|
|
|
|
return resourceAwsSesDomainIdentityRead(d, meta)
|
|
}
|
|
|
|
func resourceAwsSesDomainIdentityRead(d *schema.ResourceData, meta interface{}) error {
|
|
conn := meta.(*AWSClient).sesConn
|
|
|
|
domainName := d.Id()
|
|
d.Set("domain", domainName)
|
|
|
|
readOpts := &ses.GetIdentityVerificationAttributesInput{
|
|
Identities: []*string{
|
|
aws.String(domainName),
|
|
},
|
|
}
|
|
|
|
response, err := conn.GetIdentityVerificationAttributes(readOpts)
|
|
if err != nil {
|
|
log.Printf("[WARN] Error fetching identity verification attributes for %s: %s", d.Id(), err)
|
|
return err
|
|
}
|
|
|
|
verificationAttrs, ok := response.VerificationAttributes[domainName]
|
|
if !ok {
|
|
log.Printf("[WARN] Domain not listed in response when fetching verification attributes for %s", d.Id())
|
|
d.SetId("")
|
|
return nil
|
|
}
|
|
|
|
d.Set("arn", fmt.Sprintf("arn:%s:ses:%s:%s:identity/%s", meta.(*AWSClient).partition, meta.(*AWSClient).region, meta.(*AWSClient).accountid, d.Id()))
|
|
d.Set("verification_token", verificationAttrs.VerificationToken)
|
|
return nil
|
|
}
|
|
|
|
func resourceAwsSesDomainIdentityDelete(d *schema.ResourceData, meta interface{}) error {
|
|
conn := meta.(*AWSClient).sesConn
|
|
|
|
domainName := d.Get("domain").(string)
|
|
|
|
deleteOpts := &ses.DeleteIdentityInput{
|
|
Identity: aws.String(domainName),
|
|
}
|
|
|
|
_, err := conn.DeleteIdentity(deleteOpts)
|
|
if err != nil {
|
|
return fmt.Errorf("Error deleting SES domain identity: %s", err)
|
|
}
|
|
|
|
return nil
|
|
}
|