resendValidationEmail method

Future<void> resendValidationEmail({
  1. required String certificateArn,
  2. required String domain,
  3. required String validationDomain,
})

Resends the email that requests domain ownership validation. The domain owner or an authorized representative must approve the ACM certificate before it can be issued. The certificate can be approved by clicking a link in the mail to navigate to the Amazon certificate approval website and then clicking I Approve. However, the validation email can be blocked by spam filters. Therefore, if you do not receive the original mail, you can request that the mail be resent within 72 hours of requesting the ACM certificate. If more than 72 hours have elapsed since your original request or since your last attempt to resend validation mail, you must request a new certificate. For more information about setting up your contact email addresses, see Configure Email for your Domain.

May throw ResourceNotFoundException. May throw InvalidStateException. May throw InvalidArnException. May throw InvalidDomainValidationOptionsException.

Parameter certificateArn : String that contains the ARN of the requested certificate. The certificate ARN is generated and returned by the RequestCertificate action as soon as the request is made. By default, using this parameter causes email to be sent to all top-level domains you specified in the certificate request. The ARN must be of the form:

arn:aws:acm:us-east-1:123456789012:certificate/12345678-1234-1234-1234-123456789012

Parameter domain : The fully qualified domain name (FQDN) of the certificate that needs to be validated.

Parameter validationDomain : The base validation domain that will act as the suffix of the email addresses that are used to send the emails. This must be the same as the Domain value or a superdomain of the Domain value. For example, if you requested a certificate for site.subdomain.example.com and specify a ValidationDomain of subdomain.example.com, ACM sends email to the domain registrant, technical contact, and administrative contact in WHOIS and the following five addresses:

  • admin@subdomain.example.com
  • administrator@subdomain.example.com
  • hostmaster@subdomain.example.com
  • postmaster@subdomain.example.com
  • webmaster@subdomain.example.com

Implementation

Future<void> resendValidationEmail({
  required String certificateArn,
  required String domain,
  required String validationDomain,
}) async {
  ArgumentError.checkNotNull(certificateArn, 'certificateArn');
  _s.validateStringLength(
    'certificateArn',
    certificateArn,
    20,
    2048,
    isRequired: true,
  );
  ArgumentError.checkNotNull(domain, 'domain');
  _s.validateStringLength(
    'domain',
    domain,
    1,
    253,
    isRequired: true,
  );
  ArgumentError.checkNotNull(validationDomain, 'validationDomain');
  _s.validateStringLength(
    'validationDomain',
    validationDomain,
    1,
    253,
    isRequired: true,
  );
  final headers = <String, String>{
    'Content-Type': 'application/x-amz-json-1.1',
    'X-Amz-Target': 'CertificateManager.ResendValidationEmail'
  };
  await _protocol.send(
    method: 'POST',
    requestUri: '/',
    exceptionFnMap: _exceptionFns,
    // TODO queryParams
    headers: headers,
    payload: {
      'CertificateArn': certificateArn,
      'Domain': domain,
      'ValidationDomain': validationDomain,
    },
  );
}