From Code to Community: Sponsoring The Perl and Raku Conference 2025 Learn more

package Paws::ACM;
use Moose;
sub service { 'acm' }
sub signing_name { 'acm' }
sub version { '2015-12-08' }
sub target_prefix { 'CertificateManager' }
sub json_version { "1.1" }
has max_attempts => (is => 'ro', isa => 'Int', default => 5);
has retry => (is => 'ro', isa => 'HashRef', default => sub {
{ base => 'rand', type => 'exponential', growth_factor => 2 }
});
has retriables => (is => 'ro', isa => 'ArrayRef', default => sub { [
] });
with 'Paws::API::Caller', 'Paws::API::EndpointResolver', 'Paws::Net::V4Signature', 'Paws::Net::JsonCaller';
sub AddTagsToCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::AddTagsToCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub DeleteCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::DeleteCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub DescribeCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::DescribeCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub ExportCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::ExportCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub GetAccountConfiguration {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::GetAccountConfiguration', @_);
return $self->caller->do_call($self, $call_object);
}
sub GetCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::GetCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub ImportCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::ImportCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub ListCertificates {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::ListCertificates', @_);
return $self->caller->do_call($self, $call_object);
}
sub ListTagsForCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::ListTagsForCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub PutAccountConfiguration {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::PutAccountConfiguration', @_);
return $self->caller->do_call($self, $call_object);
}
sub RemoveTagsFromCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::RemoveTagsFromCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub RenewCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::RenewCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub RequestCertificate {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::RequestCertificate', @_);
return $self->caller->do_call($self, $call_object);
}
sub ResendValidationEmail {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::ResendValidationEmail', @_);
return $self->caller->do_call($self, $call_object);
}
sub UpdateCertificateOptions {
my $self = shift;
my $call_object = $self->new_with_coercions('Paws::ACM::UpdateCertificateOptions', @_);
return $self->caller->do_call($self, $call_object);
}
sub ListAllCertificates {
my $self = shift;
my $callback = shift @_ if (ref($_[0]) eq 'CODE');
my $result = $self->ListCertificates(@_);
my $next_result = $result;
if (not defined $callback) {
while ($next_result->NextToken) {
$next_result = $self->ListCertificates(@_, NextToken => $next_result->NextToken);
push @{ $result->CertificateSummaryList }, @{ $next_result->CertificateSummaryList };
}
return $result;
} else {
while ($result->NextToken) {
$callback->($_ => 'CertificateSummaryList') foreach (@{ $result->CertificateSummaryList });
$result = $self->ListCertificates(@_, NextToken => $result->NextToken);
}
$callback->($_ => 'CertificateSummaryList') foreach (@{ $result->CertificateSummaryList });
}
return undef
}
sub operations { qw/AddTagsToCertificate DeleteCertificate DescribeCertificate ExportCertificate GetAccountConfiguration GetCertificate ImportCertificate ListCertificates ListTagsForCertificate PutAccountConfiguration RemoveTagsFromCertificate RenewCertificate RequestCertificate ResendValidationEmail UpdateCertificateOptions / }
1;
### main pod documentation begin ###
=head1 NAME
Paws::ACM - Perl Interface to AWS AWS Certificate Manager
=head1 SYNOPSIS
use Paws;
my $obj = Paws->service('ACM');
my $res = $obj->Method(
Arg1 => $val1,
Arg2 => [ 'V1', 'V2' ],
# if Arg3 is an object, the HashRef will be used as arguments to the constructor
# of the arguments type
Arg3 => { Att1 => 'Val1' },
# if Arg4 is an array of objects, the HashRefs will be passed as arguments to
# the constructor of the arguments type
Arg4 => [ { Att1 => 'Val1' }, { Att1 => 'Val2' } ],
);
=head1 DESCRIPTION
AWS Certificate Manager
You can use AWS Certificate Manager (ACM) to manage SSL/TLS
certificates for your AWS-based websites and applications. For more
information about using ACM, see the AWS Certificate Manager User Guide
For the AWS API documentation, see L<https://docs.aws.amazon.com/goto/WebAPI/acm-2015-12-08>
=head1 METHODS
=head2 AddTagsToCertificate
=over
=item CertificateArn => Str
=item Tags => ArrayRef[L<Paws::ACM::Tag>]
=back
Each argument is described in detail in: L<Paws::ACM::AddTagsToCertificate>
Returns: nothing
Adds one or more tags to an ACM certificate. Tags are labels that you
can use to identify and organize your AWS resources. Each tag consists
of a C<key> and an optional C<value>. You specify the certificate on
input by its Amazon Resource Name (ARN). You specify the tag by using a
key-value pair.
You can apply a tag to just one certificate if you want to identify a
specific characteristic of that certificate, or you can apply the same
tag to multiple certificates if you want to filter for a common
relationship among those certificates. Similarly, you can apply the
same tag to multiple resources if you want to specify a relationship
among those resources. For example, you can add the same tag to an ACM
certificate and an Elastic Load Balancing load balancer to indicate
that they are both used by the same website. For more information, see
Tagging ACM certificates
To remove one or more tags, use the RemoveTagsFromCertificate action.
To view all of the tags that have been applied to the certificate, use
the ListTagsForCertificate action.
=head2 DeleteCertificate
=over
=item CertificateArn => Str
=back
Each argument is described in detail in: L<Paws::ACM::DeleteCertificate>
Returns: nothing
Deletes a certificate and its associated private key. If this action
succeeds, the certificate no longer appears in the list that can be
displayed by calling the ListCertificates action or be retrieved by
calling the GetCertificate action. The certificate will not be
available for use by AWS services integrated with ACM.
You cannot delete an ACM certificate that is being used by another AWS
service. To delete a certificate that is in use, the certificate
association must first be removed.
=head2 DescribeCertificate
=over
=item CertificateArn => Str
=back
Each argument is described in detail in: L<Paws::ACM::DescribeCertificate>
Returns: a L<Paws::ACM::DescribeCertificateResponse> instance
Returns detailed metadata about the specified ACM certificate.
=head2 ExportCertificate
=over
=item CertificateArn => Str
=item Passphrase => Str
=back
Each argument is described in detail in: L<Paws::ACM::ExportCertificate>
Returns: a L<Paws::ACM::ExportCertificateResponse> instance
Exports a private certificate issued by a private certificate authority
(CA) for use anywhere. The exported file contains the certificate, the
certificate chain, and the encrypted private 2048-bit RSA key
associated with the public key that is embedded in the certificate. For
security, you must assign a passphrase for the private key when
exporting it.
For information about exporting and formatting a certificate using the
ACM console or CLI, see Export a Private Certificate
=head2 GetAccountConfiguration
=over
=item =>
=back
Each argument is described in detail in: L<Paws::ACM::GetAccountConfiguration>
Returns: a L<Paws::ACM::GetAccountConfigurationResponse> instance
Returns the account configuration options associated with an AWS
account.
=head2 GetCertificate
=over
=item CertificateArn => Str
=back
Each argument is described in detail in: L<Paws::ACM::GetCertificate>
Returns: a L<Paws::ACM::GetCertificateResponse> instance
Retrieves an Amazon-issued certificate and its certificate chain. The
chain consists of the certificate of the issuing CA and the
intermediate certificates of any other subordinate CAs. All of the
certificates are base64 encoded. You can use OpenSSL
the certificates and inspect individual fields.
=head2 ImportCertificate
=over
=item Certificate => Str
=item PrivateKey => Str
=item [CertificateArn => Str]
=item [CertificateChain => Str]
=item [Tags => ArrayRef[L<Paws::ACM::Tag>]]
=back
Each argument is described in detail in: L<Paws::ACM::ImportCertificate>
Returns: a L<Paws::ACM::ImportCertificateResponse> instance
Imports a certificate into AWS Certificate Manager (ACM) to use with
services that are integrated with ACM. Note that integrated services
allow only certificate types and keys they support to be associated
with their resources. Further, their support differs depending on
whether the certificate is imported into IAM or into ACM. For more
information, see the documentation for each service. For more
information about importing certificates into ACM, see Importing
Certificates
in the I<AWS Certificate Manager User Guide>.
ACM does not provide managed renewal
certificates that you import.
Note the following guidelines when importing third party certificates:
=over
=item *
You must enter the private key that matches the certificate you are
importing.
=item *
The private key must be unencrypted. You cannot import a private key
that is protected by a password or a passphrase.
=item *
The private key must be no larger than 5 KB (5,120 bytes).
=item *
If the certificate you are importing is not self-signed, you must enter
its certificate chain.
=item *
If a certificate chain is included, the issuer must be the subject of
one of the certificates in the chain.
=item *
The certificate, private key, and certificate chain must be
PEM-encoded.
=item *
The current time must be between the C<Not Before> and C<Not After>
certificate fields.
=item *
The C<Issuer> field must not be empty.
=item *
The OCSP authority URL, if present, must not exceed 1000 characters.
=item *
To import a new certificate, omit the C<CertificateArn> argument.
Include this argument only when you want to replace a previously
imported certificate.
=item *
When you import a certificate by using the CLI, you must specify the
certificate, the certificate chain, and the private key by their file
names preceded by C<fileb://>. For example, you can specify a
certificate saved in the C<C:\temp> folder as
C<fileb://C:\temp\certificate_to_import.pem>. If you are making an HTTP
or HTTPS Query request, include these arguments as BLOBs.
=item *
When you import a certificate by using an SDK, you must specify the
certificate, the certificate chain, and the private key files in the
manner required by the programming language you're using.
=item *
The cryptographic algorithm of an imported certificate must match the
algorithm of the signing CA. For example, if the signing CA key type is
RSA, then the certificate key type must also be RSA.
=back
This operation returns the Amazon Resource Name (ARN)
of the imported certificate.
=head2 ListCertificates
=over
=item [CertificateStatuses => ArrayRef[Str|Undef]]
=item [Includes => L<Paws::ACM::Filters>]
=item [MaxItems => Int]
=item [NextToken => Str]
=back
Each argument is described in detail in: L<Paws::ACM::ListCertificates>
Returns: a L<Paws::ACM::ListCertificatesResponse> instance
Retrieves a list of certificate ARNs and domain names. You can request
that only certificates that match a specific status be listed. You can
also filter by specific attributes of the certificate. Default
filtering returns only C<RSA_2048> certificates. For more information,
see Filters.
=head2 ListTagsForCertificate
=over
=item CertificateArn => Str
=back
Each argument is described in detail in: L<Paws::ACM::ListTagsForCertificate>
Returns: a L<Paws::ACM::ListTagsForCertificateResponse> instance
Lists the tags that have been applied to the ACM certificate. Use the
certificate's Amazon Resource Name (ARN) to specify the certificate. To
add a tag to an ACM certificate, use the AddTagsToCertificate action.
To delete a tag, use the RemoveTagsFromCertificate action.
=head2 PutAccountConfiguration
=over
=item IdempotencyToken => Str
=item [ExpiryEvents => L<Paws::ACM::ExpiryEventsConfiguration>]
=back
Each argument is described in detail in: L<Paws::ACM::PutAccountConfiguration>
Returns: nothing
Adds or modifies account-level configurations in ACM.
The supported configuration option is C<DaysBeforeExpiry>. This option
specifies the number of days prior to certificate expiration when ACM
starts generating C<EventBridge> events. ACM sends one event per day
per certificate until the certificate expires. By default, accounts
receive events starting 45 days before certificate expiration.
=head2 RemoveTagsFromCertificate
=over
=item CertificateArn => Str
=item Tags => ArrayRef[L<Paws::ACM::Tag>]
=back
Each argument is described in detail in: L<Paws::ACM::RemoveTagsFromCertificate>
Returns: nothing
Remove one or more tags from an ACM certificate. A tag consists of a
key-value pair. If you do not specify the value portion of the tag when
calling this function, the tag will be removed regardless of value. If
you specify a value, the tag is removed only if it is associated with
the specified value.
To add tags to a certificate, use the AddTagsToCertificate action. To
view all of the tags that have been applied to a specific ACM
certificate, use the ListTagsForCertificate action.
=head2 RenewCertificate
=over
=item CertificateArn => Str
=back
Each argument is described in detail in: L<Paws::ACM::RenewCertificate>
Returns: nothing
Renews an eligible ACM certificate. At this time, only exported private
certificates can be renewed with this operation. In order to renew your
ACM PCA certificates with ACM, you must first grant the ACM service
principal permission to do so
For more information, see Testing Managed Renewal
in the ACM User Guide.
=head2 RequestCertificate
=over
=item DomainName => Str
=item [CertificateAuthorityArn => Str]
=item [DomainValidationOptions => ArrayRef[L<Paws::ACM::DomainValidationOption>]]
=item [IdempotencyToken => Str]
=item [Options => L<Paws::ACM::CertificateOptions>]
=item [SubjectAlternativeNames => ArrayRef[Str|Undef]]
=item [Tags => ArrayRef[L<Paws::ACM::Tag>]]
=item [ValidationMethod => Str]
=back
Each argument is described in detail in: L<Paws::ACM::RequestCertificate>
Returns: a L<Paws::ACM::RequestCertificateResponse> instance
Requests an ACM certificate for use with other AWS services. To request
an ACM certificate, you must specify a fully qualified domain name
(FQDN) in the C<DomainName> parameter. You can also specify additional
FQDNs in the C<SubjectAlternativeNames> parameter.
If you are requesting a private certificate, domain validation is not
required. If you are requesting a public certificate, each domain name
that you specify must be validated to verify that you own or control
the domain. You can use DNS validation
or email validation
We recommend that you use DNS validation. ACM issues public
certificates after receiving approval from the domain owner.
=head2 ResendValidationEmail
=over
=item CertificateArn => Str
=item Domain => Str
=item ValidationDomain => Str
=back
Each argument is described in detail in: L<Paws::ACM::ResendValidationEmail>
Returns: nothing
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 B<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
=head2 UpdateCertificateOptions
=over
=item CertificateArn => Str
=item Options => L<Paws::ACM::CertificateOptions>
=back
Each argument is described in detail in: L<Paws::ACM::UpdateCertificateOptions>
Returns: nothing
Updates a certificate. Currently, you can use this function to specify
whether to opt in to or out of recording your certificate in a
certificate transparency log. For more information, see Opting Out of
Certificate Transparency Logging
=head1 PAGINATORS
Paginator methods are helpers that repetively call methods that return partial results
=head2 ListAllCertificates(sub { },[CertificateStatuses => ArrayRef[Str|Undef], Includes => L<Paws::ACM::Filters>, MaxItems => Int, NextToken => Str])
=head2 ListAllCertificates([CertificateStatuses => ArrayRef[Str|Undef], Includes => L<Paws::ACM::Filters>, MaxItems => Int, NextToken => Str])
If passed a sub as first parameter, it will call the sub for each element found in :
- CertificateSummaryList, passing the object as the first parameter, and the string 'CertificateSummaryList' as the second parameter
If not, it will return a a L<Paws::ACM::ListCertificatesResponse> instance with all the C<param>s; from all the responses. Please take into account that this mode can potentially consume vasts ammounts of memory.
=head1 SEE ALSO
This service class forms part of L<Paws>
=head1 BUGS and CONTRIBUTIONS
The source code is located here: L<https://github.com/pplu/aws-sdk-perl>
=cut