Provision certificates
Increase your customers' trust, encrypt sensitive information, and improve SEO rankings using TLS domain validation or third-party certificates that securely deliver content to and from your site.
Akamai managed certificates
Akamai managed enrollments provide certificates that verify ownership of the domains you provide.
When you create a domain validation enrollment, we automatically verify your domains and set a certificate expiry of 90 days.
Create new
Use your contract ID to send an enrollment object with all required parameters as a variable or JSON string in the new enrollment command.
Parameter | Description |
---|---|
Required | |
ra | The registration or certificate authority you want to use for your certificate. Choose one of symantec , lets-encrypt , or third-party . |
validationType | The type of validation performed for your certificate. Values are:
|
certificateType | The type of certificate. Values are
|
networkConfiguration | An object that contains your network settings. Required parameters:
|
changeManagement | Manages the deployment of your certificate.
Set-CPSDeploymentSchedule cmdlet. |
csr | An object containing your certificate signing request specifics.
|
org | An object containing your company's address information.
|
adminContact | An object containing the contact information for your admin representative.
|
techContact | An object containing the contact information for your technical representative.
|
enableMultiStackedCertificates | Whether to enable Dual-Stacked certificate deployment for your enrollment.", |
signatureAlgorithm | Your digital signature hash designation. Values are SHA-1 or SHA-256 . |
Optional | |
networkConfiguration.disallowedTlsVersions | An array of TLS protocol versions to disallow.", |
networkConfiguration.dnsNameSettings.dnsNames | An array of DNS names served by SNI-only enabled enrollments.", |
networkConfiguration.mustHaveCiphers " | Must use ciphers to use while your certificate deploys to the network. Default is ak-akamai-default .", |
networkConfiguration.oscpStapling | Enables OSCP stapling for your enrollment. Values are on , off , not-set .", |
networkConfiguration.preferredCiphers | Ciphers you prefer to use while your certificate deploys to the network. Default is ak-akamai-default .", |
orgId | The Digicert identifier for your company. If you use this, leave null the org , techContact , and adminContact parameters. |
$body = @{
ra = "lets-encrypt"
validationType = "dv"
certificateType = "san"
networkConfiguration = @{
geography = "core"
secureNetwork = "standard-tls"
sniOnly = $true
quicEnabled = $false
dnsNameSettings = @{
cloneDnsNames = $true
}
}
changeManagement = $true
csr = @{
cn = "example.enrollment.net"
c = "US"
st = "Cambridge"
l = "Cambridge"
o = "Akamai"
sans = @(
"example.enrollment.net"
)
}
org = @{
name = "Akamai"
addressLineOne = "1234 Main Street"
city = "Boston"
region = "MA"
postalCode = "02142"
country = "US"
phone = "(617) 555-1234"
}
adminContact = @{
firstName = "John"
lastName = "Smith"
phone = "(617) 555-1234"
email = "jsmith@example.com"
}
techContact = @{
firstName = "John"
lastName = "Smith"
phone = "(617) 555-1234"
email = "jsmith@example.com"
}
enableMultiStackedCertificates = $false
signatureAlgorithm = "SHA-256"
}
New-CPSEnrollment -ContractID "ctr_C-0N7RAC7" -Body $body
New-CPSEnrollment -ContractID "ctr_C-0N7RAC7" -Body '{@{"ra": "lets-encrypt", "validationType": "dv", "certificateType": "san", "networkConfiguration": {"geography": "core", "secureNetwork": "standard-tls", "sniOnly": true"quicEnabled": false, "dnsNameSettings": {"cloneDnsNames": true}}, "changeManagement": true, "csr": {"cn": "example.enrollment.net", "c": "US", "st": "Cambridge", "l": "Cambridge", "o": "Akamai", "sans": ["example.enrollment.net"]}, "org": {"name": "Akamai", "addressLineOne": "1234 Main Street", "city": "Boston", "region": "MA", "postalCode": "02142", "country": "US", "phone": "(617) 555-1234"}, "adminContact": {"firstName": "John", "lastName": "Smith", "phone": "(617) 555-1234", "email": "jsmith@example.com"}, "techContact": {"firstName": "John", "lastName": "Smith", "phone": "(617) 555-1234", "email": "jsmith@example.com"}, "enableMultiStackedCertificates": false, "signatureAlgorithm": "SHA-256"}}'
Akamai automatically verifies your domain and deploys it to both the staging and production networks when you set changeManagement
to false
.
If you would rather test on staging before deploying to production, set the value to true
, run your tests, and then use the Set-CPSDeploymentSchedule
cmdlet to deploy your certificate to the production network.
New from existing
To create a new domain validation certificate from an existing enrollment, get the enrollment, make changes, and send your enrollment object as a variable or JSON string in the new enrollment command.
-
Get your enrollments to find the ID of the one you want to use as your starting point.
Get-CPSEnrollment
id : 123456 productionSlots : {112233} stagingSlots : {112233} assignedSlots : {112233} location : /cps/v2/enrollments/123456 ra : lets-encrypt validationType : dv certificateType : san certificateChainType : default networkConfiguration : @{geography=core; secureNetwork=enhanced-tls; mustHaveCiphers=ak-akamai-default; preferredCiphers=ak-akamai-default; disallowedTlsVersions=System.Object[]; sniOnly=True; quicEnabled=True; dnsNameSettings=; ocspStapling=on; clientMutualAuthentication=} signatureAlgorithm : SHA-256 changeManagement : False csr : @{cn=example.enrollment.net; c=US; st=Cambridge; l=Cambridge; o=Akamai; ou=; sans=System.Object[]; preferredTrustChain=dst-root-ca-x3} org : @{name=Akamai; addressLineOne=1234 Main Street; addressLineTwo=; city=Cambridge; region=MA; postalCode=02142; country=US; phone=+1-6175551234} orgId : adminContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} techContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} thirdParty : enableMultiStackedCertificates : False autoRenewalStartTime : 12/31/2023 11:42:25 PM pendingChanges : {} maxAllowedSanNames : 100 maxAllowedWildcardSanNames : 25 id : 234567 productionSlots : {} stagingSlots : {} assignedSlots : {} location : /cps/v2/enrollments/234567 ra : lets-encrypt validationType : dv certificateType : san certificateChainType : default networkConfiguration : @{geography=core; secureNetwork=standard-tls; mustHaveCiphers=ak-akamai-default; preferredCiphers=ak-akamai-default; disallowedTlsVersions=System.Object[]; sniOnly=True; quicEnabled=False; dnsNameSettings=; ocspStapling=on; clientMutualAuthentication=} signatureAlgorithm : SHA-256 changeManagement : False csr : @{cn=example.enrollment2.net; c=US; st=Cambridge; l=Cambridge; o=Akamai; ou=; sans=System.Object[]; preferredTrustChain=dst-root-ca-x3} org : @{name=Akamai; addressLineOne=1234 Main Street; addressLineTwo=; city=Cambridge; region=MA; postalCode=02142; country=US; phone=+1-6175551234} orgId : adminContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} techContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} thirdParty : enableMultiStackedCertificates : False autoRenewalStartTime : pendingChanges : {@{location=/cps/v2/enrollments/234567/changes/901234; changeType=new-certificate}} maxAllowedSanNames : 100 maxAllowedWildcardSanNames : 25
-
Use an enrollment ID and set it to a variable or send its contents to a file to edit the output. Remove the enrollment specific identifiers added by Akamai.
id
productionSlots
stagingSlots
assignedSlots
location
autoRenewalStartTime
-
Send your enrollment object as the value for
-Body
in the new enrollment cmdlet.New-CPSEnrollment -ContractID "ctr_C-0N7RAC7" -Body $MyEnrollment
Akamai automatically verifies your domain and deploys it to both the staging and production networks when you set changeManagement
to false
.
If you would rather test on staging before deploying to production, set the value to true
, run your tests, and then use the Set-CPSDeploymentSchedule
cmdlet to deploy your certificate to the production network.
Certificate renewal
Thirty days before your certificate expires, we'll contact you to begin the renewal process. This communication is followed by a notice 16 days before the expiry to let you know the renewal period is open.
Enhanced TLS certificate renewal and deployment is an automatic process.
Standard TLS certificate renewal and deployment can be manual or automatic. During the open period for a renewal, your enrollment enters a change-in-progress state that you complete by adding your renewed certificate. If you don't want to manage the renewal process manually, add the autoDomainValidation
behavior to your property's default rule.
-
Copy, paste, and save the
autoDomainValidation
behavior JSON to a file.Note: The
autodv
parameter is sent empty.{ "name": "autoDomainValidation", "options": { "autodv": "" } }
-
Set the
behavior.json
content to a variable.$Behavior = Get-Content -Raw behavior.json | ConvertFrom-JSON
-
Get and set your property's rule tree to a variable.
$Rules = Get-PropertyRuleTree -PropertyName "MyProperty" -PropertyVersion "latest"
-
Add the new behavior.
$Rules.rules.behaviors += $Behavior
-
Update your property.
$Rules | Set-PropertyRuleTree -PropertyName "MyProperty" -PropertyVersion "latest"
-
Activate your property to apply the changes on a network.
New-PropertyActivation -PropertyName "MyProperty" -PropertyVersion "latest" -Network "Staging" -NotifyEmails "jsmith@email.com"
Third-party certificates
To use a certificate from an external certificate authority, create third-party enrollment and upload your certificate.
-
Get your certificate signing request.
Get-CPSCSR -EnrollmentID 12345 -ChangeID 9876543
csrs ---- {@{keyAlgorithm=RSA; csr=BEGIN CERTIFICATE REQUEST-----\n\n-----END CERTIFICATE REQUEST}
-
Use your contract ID to send an enrollment object with all required parameters as a variable or JSON string in the new enrollment command. Returned to you are the enrollments and change management resource paths. Your enrollment and change IDs are in the paths. You'll need them for the next step.
$body = @{ ra = "third-party" validationType = "third-party" thirdParty = @{ excludeSans = @false } certificateType = "third-party" networkConfiguration = @{ geography = "core" secureNetwork = "standard-tls" sniOnly = $true quicEnabled = $false dnsNameSettings = @{ cloneDnsNames = $true } } changeManagement = $true csr = @{ cn = "example.enrollment.net" c = "US" st = "Cambridge" l = "Cambridge" o = "Akamai" sans = @( "example.enrollment.net" ) } org = @{ name = "Akamai" addressLineOne = "1234 Main Street" city = "Boston" region = "MA" postalCode = "02142" country = "US" phone = "(617) 555-1234" } adminContact = @{ firstName = "John" lastName = "Smith" phone = "(617) 555-1234" email = "jsmith@example.com" } techContact = @{ firstName = "John" lastName = "Smith" phone = "(617) 555-1234" email = "jsmith@example.com" } enableMultiStackedCertificates = $false signatureAlgorithm = "SHA-256" } $ New-CPSEnrollment -ContractID "ctr_C-0N7RAC7" -Body $body
$ New-CPSEnrollment -ContractID "ctr_C-0N7RAC7" -Body '{@{"ra": "third-party", "validationType": "third-party", "thirdParty": {"excludeSans": true}, "certificateType": "third-party", "networkConfiguration": {"geography": "core", "secureNetwork": "standard-tls", "sniOnly": true"quicEnabled": false, "dnsNameSettings": {"cloneDnsNames": true}}, "changeManagement": true, "csr": {"cn": "example.enrollment.net", "c": "US", "st": "Cambridge", "l": "Cambridge", "o": "Akamai", "sans": ["example.enrollment.net"]}, "org": {"name": "Akamai", "addressLineOne": "1234 Main Street", "city": "Boston", "region": "MA", "postalCode": "02142", "country": "US", "phone": "(617) 555-1234"}, "adminContact": {"firstName": "John", "lastName": "Smith", "phone": "(617) 555-1234", "email": "jsmith@example.com"}, "techContact": {"firstName": "John", "lastName": "Smith", "phone": "(617) 555-1234", "email": "jsmith@example.com"}, "enableMultiStackedCertificates": false, "signatureAlgorithm": "SHA-256"}}'
-
Use your enrollment and change IDs to add your certificate to your property. Possible values for
KeyAlorithm
areRSA
orECDSA
.Add-CPSThirdPartyCert -EnrollmentID 123456 -ChangeID 123456 -Certificate "--- BEGIN CERTIFICATE ------ END CERTIFICATE ---" -KeyAlgorithm RSA
Certificate renewal
Thirty days before your certificate expires, we'll contact you to begin the renewal process. This communication is followed by a notice 16 days before the expiry to let you know the renewal period is open. During the open period, your enrollment enters a change-in-progress state that you complete by adding your renewed certificate.
-
Get your enrollment's change ID from the returned
pendingChanges
field.Get-CPSEnrollment -EnrollmentId 123456
id : 234567 productionSlots : {} stagingSlots : {} assignedSlots : {} location : /cps/v2/enrollments/234567 ra : third-party validationType : third-party certificateType : third-party certificateChainType : default networkConfiguration : @{geography=core; secureNetwork=standard-tls; mustHaveCiphers=ak-akamai-default; preferredCiphers=ak-akamai-default; disallowedTlsVersions=System.Object[]; sniOnly=True; quicEnabled=False; dnsNameSettings=; ocspStapling=on; clientMutualAuthentication=} signatureAlgorithm : SHA-256 changeManagement : False csr : @{cn=example.enrollment2.net; c=US; st=Cambridge; l=Cambridge; o=Akamai; ou=; sans=System.Object[]; preferredTrustChain=dst-root-ca-x3} org : @{name=Akamai; addressLineOne=1234 Main Street; addressLineTwo=; city=Cambridge; region=MA; postalCode=02142; country=US; phone=+1-6175551234} orgId : adminContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} techContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} thirdParty : enableMultiStackedCertificates : False autoRenewalStartTime : pendingChanges : {@{location=/cps/v2/enrollments/234567/changes/901234; changeType=new-certificate}} maxAllowedSanNames : 100 maxAllowedWildcardSanNames : 25
-
Use your enrollment and change IDs to add your certificate to your property. Possible values for
KeyAlorithm
areRSA
orECDSA
.Add-CPSThirdPartyCert -EnrollmentID 234567 -ChangeID 901234 -Certificate "--- BEGIN CERTIFICATE ------ END CERTIFICATE ---" -KeyAlgorithm RSA
Update an enrollment
To update an existing enrollment, set an enrollment's output to a variable and make your changes.
-
If you don't know your enrollment's ID, use the get enrollment command to return a list of your enrollments.
Get-CPSEnrollment
id : 123456 productionSlots : {112233} stagingSlots : {112233} assignedSlots : {112233} location : /cps/v2/enrollments/123456 ra : lets-encrypt validationType : dv certificateType : san certificateChainType : default networkConfiguration : @{geography=core; secureNetwork=enhanced-tls; mustHaveCiphers=ak-akamai-default; preferredCiphers=ak-akamai-default; disallowedTlsVersions=System.Object[]; sniOnly=True; quicEnabled=True; dnsNameSettings=; ocspStapling=on; clientMutualAuthentication=} signatureAlgorithm : SHA-256 changeManagement : False csr : @{cn=example.enrollment.net; c=US; st=Cambridge; l=Cambridge; o=Akamai; ou=; sans=System.Object[]; preferredTrustChain=dst-root-ca-x3} org : @{name=Akamai; addressLineOne=1234 Main Street; addressLineTwo=; city=Cambridge; region=MA; postalCode=02142; country=US; phone=+1-6175551234} orgId : adminContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} techContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} thirdParty : enableMultiStackedCertificates : False autoRenewalStartTime : 12/31/2023 11:42:25 PM pendingChanges : {} maxAllowedSanNames : 100 maxAllowedWildcardSanNames : 25 id : 234567 productionSlots : {} stagingSlots : {} assignedSlots : {} location : /cps/v2/enrollments/234567 ra : lets-encrypt validationType : dv certificateType : san certificateChainType : default networkConfiguration : @{geography=core; secureNetwork=standard-tls; mustHaveCiphers=ak-akamai-default; preferredCiphers=ak-akamai-default; disallowedTlsVersions=System.Object[]; sniOnly=True; quicEnabled=False; dnsNameSettings=; ocspStapling=on; clientMutualAuthentication=} signatureAlgorithm : SHA-256 changeManagement : False csr : @{cn=example.enrollment2.net; c=US; st=Cambridge; l=Cambridge; o=Akamai; ou=; sans=System.Object[]; preferredTrustChain=dst-root-ca-x3} org : @{name=Akamai; addressLineOne=1234 Main Street; addressLineTwo=; city=Cambridge; region=MA; postalCode=02142; country=US; phone=+1-6175551234} orgId : adminContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} techContact : @{firstName=John; lastName=Smith; phone=+1-6175551234; email=jsmith@example.com; addressLineOne=; addressLineTwo=; city=; country=; organizationName=; postalCode=; region=; title=} thirdParty : enableMultiStackedCertificates : False autoRenewalStartTime : pendingChanges : {@{location=/cps/v2/enrollments/234567/changes/901234; changeType=new-certificate}} maxAllowedSanNames : 100 maxAllowedWildcardSanNames : 25
-
Assign the enrollment you want to a variable and make your changes.
$MyEnrollment = Get-Enrollment -EnrollmentID 123456 $MyEnrollment.csr.networkConfiguration.geography = "china+core"
-
Use your contract ID to send your enrollment object as a variable or JSON string in the set enrollment command.
Set-CPSEnrollment -Body $MyEnrollment
Akamai automatically verifies your domain and deploys it to both the staging and production networks when you set changeManagement
to false
.
If you would rather test on staging before deploying to production, set the value to true
, run your tests, and then use the Set-CPSDeploymentSchedule
cmdlet to deploy your certificate to the production network.
Delete enrollment
To delete an enrollment, send its ID in the remove enrollment command.
Remove-CPSEnrollment -EnrollmentID 123456
Updated about 2 months ago