Using the connector

This page describes how to use the connector with the AWS CLI and Amazon API Gateway.

If you’re getting a 200 status code response, but the connector isn’t performing the requested operation, it’s likely that there’s a YAML syntax error in your acme-account.yaml file. Make sure to validate your YAML file using a YAML validator, for example, Code Beautify.

Using the connector with the AWS CLI

The following are example commands for enrolling and renewing certificates using the AWS CLI.

All examples of the Lambda function invocation in this document use AWS CLI v1. However, you can also invoke the function with AWS CLI v2 by adding --cli-binary-format raw-in-base64-out to the command.

aws lambda invoke --function-name sectigoawscm-multi-eu-central-1-pumped-lacewing \
--payload '{"domains": "ccmqa.com", "account": "scm_demo", "action": "enroll"}' \
--cli-binary-format raw-in-base64-out response.json

The Lamda function name uses the pattern "sectigoawscm-${terraform.workspace}-${random_pet.pet.id}".

If an attempt is made to enroll a certificate for a domain that already has a certificate, the ARN of the existing certificate will be returned.

Enroll a single-domain certificate

You can use a specific AWS profile in AWS CLI (--profile <your_aws_profile>) or the default AWS profile.
  • Enrollment using domain

  • Enrollment using CSR

aws lambda invoke --profile aws_account_1 --function-name sectigoawscm-multi-eu-central-1-pumped-lacewing \
--payload '{"domains": "ccmqa.com", "account": "scm_demo", "action": "enroll"}' \
response.json
aws lambda invoke \
--profile multi  \
--function-name sectigoawscm-multi-eu-central-1-stirred-hen \
--cli-binary-format raw-in-base64-out  \
--payload "{\"domains\": \"aws.ccmqa.com\", \"account\": \"rsa_2048\", \"action\": \"enroll\", \"csrParameters\":{\"counry\": \"CA\", \"location\": \"Ottawa\", \"state\": \"Ontario\", \"organization\": \"SrideviPrivateCA\", \"sans\": \"san1.ccmqa.com, san2.ccmqa.com\"}}" response.json

Enroll a multi-domain (SAN) or wildcard certificate

If you use both options, all domains will be added to the SAN.
  • Enrollment using domain

  • Enrolling using CSR

aws lambda invoke --profile aws_account_1 --function-name sectigoawscm-multi-eu-central-1-pumped-lacewing \
--payload '{"domains": "*.ccmqa.com,d2.ccmqa.com,d3.ccmqa.com", \
"account": "scm_demo", "action": "enroll"}' \
response.json
aws lambda invoke \
--profile multi  \
--function-name sectigoawscm-multi-eu-central-1-stirred-hen \
--cli-binary-format raw-in-base64-out  \
--payload "{\"domains\": \"aws.ccmqa.com\", \"account\": \"rsa_2048\", \"action\": \"enroll\", \"csrParameters\":{\"counry\": \"CA\", \"location\": \"Ottawa\", \"state\": \"Ontario\", \"organization\": \"SrideviPrivateCA\", \"sans\": \"san1.ccmqa.com, san2.ccmqa.com\"}}" response.json

Renew revoked certificates for a specific ACME account

This command renews certificates created under a specific ACME account alias from the acme_accounts.yaml file.

aws lambda invoke --function-name sectigoawscm-multi-eu-central-1-pumped-lacewing \
--payload '{"account": "scm_demo", "action": "renew"}' \
response.json

Renew revoked certificates for all ACME accounts

This command renews all certificates created under ACME account aliases from the acme_accounts.yaml file.

aws lambda invoke --profile aws_account_1 --function-name sectigoawscm-multi-eu-central-1-pumped-lacewing \
--payload '{"action": "renew"}' \
response.json

Renew a specific certificate

To renew a specific certificate using its Amazon resource name (ARN):

 aws lambda invoke --profile multi  --function-name sectigoawscm-multi-eu-central-1-game-dragon \
--cli-binary-format raw-in-base64-out  --payload "{ \"account\": \"action_name\", \"action\": \"renew\", \"arn\":\"arn:aws:acm:eu-central-1:011400459177:certificate/28771f49-947f-41d8-a507-0f0522bf0372\"}" response.json
Issued certificates in AWS CM
Certificate status in AWS CM

Using the connector with API Gateway

The following are example commands for enrolling and renewing certificates using Amazon API Gateway (scroll right to view the full command).

If you need to renew more than 30 certificates, use the connector with the AWS CLI.

Enroll a single-domain certificate

curl --location --request GET \
'https://kxiinwdhxk.execute-api.ca-central-1.amazonaws.com/SectigoAWSCM/queries?domains=d1_124.ccmqa.com&account=scm_demo&action=enroll' \
--header 'x-api-key: GKIbu7ukcY4gRdahVK70x2lP4ANKMubJ2WBNHISG'

Enroll a multi-domain (SAN) or wildcard certificate

curl --location --request GET \
'https://kxiinwdhxk.execute-api.ca-central-1.amazonaws.com/SectigoAWSCM/queries?domains=d1.ccmqa.com,d2.ccmqa.com&account=scm_demo&action=enroll' \
--header 'x-api-key: GKIbu7ukcY4gRdahVK70x2lP4ANKMubJ2WBNHISG'

Renew revoked certificates for a specific ACME alias

This command renews certificates created under a specific ACME account alias from the acme_accounts.yaml file.

curl --location --request GET \
'https://kxiinwdhxk.execute-api.ca-central-1.amazonaws.com/SectigoAWSCM/queries?account=scm_demo&action=renew' \
--header 'x-api-key: GKIbu7ukcY4gRdahVK70x2lP4ANKMubJ2WBNHISG'

Renew revoked certificates for all ACME aliases

This command renews all certificates created under ACME account aliases from the acme_accounts.yaml file.

curl --location --request GET \
'https://kxiinwdhxk.execute-api.ca-central-1.amazonaws.com/SectigoAWSCM/queries?action=renew' \
--header 'x-api-key: GKIbu7ukcY4gRdahVK70x2lP4ANKMubJ2WBNHISG'

Notes

  • Duplicate certificates for a domain are not allowed under a single ACME account alias.

  • Multiple aliases can be defined for the same ACME account.

  • If you need different key sizes, you can create two aliases with the needed key sizes.

  • Make sure the signature algorithm of the server certificate matches the CA certificate. For example, the RSA server certificate must have the RSA CA chain, and the ECDSA server certificate must have the ECDSA CA chain.

Enable auto-renewal and logging using AWS CloudWatch

The Amazon Cloudwatch service allows you to create a cronjob that will invoke a Lambda function on a schedule. You can integrate CloudWatch with the connector to trigger the Lambda function that will check whether the certificate is eligible for renewal. For example, if you want to create a Cloudwatch event that will fire on the first day of every month, perform the following steps:

  1. Sign in to the AWS EventBridge service.

  2. Create a new rule.

  3. Give a name to your rule, and specify a pattern and cron expression.

    Create rule in CloudWatch
  4. Select the Lambda function.

  5. Specify the action.

  6. Click Create to confirm the rule.

Create Lambda function

Cloudwatch log groups were created and integrated with Lambda when you executed the installation script. After the Lambda function is invoked, you can check the logs in AWS Cloudwatch. The following is an example of invoking a Lambda function and logging this event.

Invoke Lambda function
Lambda function response

Visit the AWS CloudWatch console to view the logs.

AWS CloudWatch console
AWS CloudWatch console output