Replace the TLS Certificate
On virtual platforms, the SBC can be deployed with a temporary self-signed certificate that allows a client to access the REST API. This certificate should be replaced with a certificate signed by a valid Certificate Authority (CA). The API endpoints under the certificate category, which are supported only on virtual platforms, allow a client to create a new certificate-record, generate a Certificate Signing Request (CSR) for that certificate-record, and then import a CA-signed certificate.
Table - Prerequisites
| Prerequisite | More Information |
| Authenticate | Authenticate |
This example assumes you have exported the access token to the variable $TOKEN.
Note:
The Subscriber-Aware Load Balancer does not support certificate-related endpoints.Task 1: Create the Certificate Signing Request
-
Retrieve the certificate-record template.
The template of a configuration element is a data structure containing all required sub-elements and supported attributes with their default values, along with any specified optional sub-elements.
curl -X GET -o response.xml \ --header "Authorization: Bearer $TOKEN" \ "https://10.0.0.2/rest/v1.2/configuration/elementTypes/template?elementType=certificate-record"The response is saved to the file
response.xml. -
Copy the content between the opening and closing <configElement> tags to a new file called
certificate-record.xml.If you are on a Linux system with
xmllintinstalled, you may optionally format the XML before writing it to the file system.sed -n '/<configElement>/,/<\/configElement>/p' response.xml | xmllint --format - > certificate-record.xml -
Open the
certificate-record.xmlfile and set values for each attribute.Note:
See the ACLI Reference Guide for a description of each attribute.The
nameattribute must have a value.<?xml version="1.0"?> <configElement> <elementType>certificate-record</elementType> <attribute> <name>name</name> <value>new-restless</value> </attribute> <attribute> <name>country</name> <value>US</value> </attribute> ... <configElement> -
Acquire the configuration lock.
curl -X POST \ --header "Authorization: Bearer $TOKEN" \ "https://10.0.0.2/rest/v1.2/configuration/lock" -
Add the certificate-record configuration element to the SBC.
curl -X POST \ -d@certificate-record.xml \ --header "Authorization: Bearer $TOKEN" \ "https://10.0.0.2/rest/v1.2/configuration/configElements" -
Save, verify, and activate the configuration.
-
Generate a CSR for your new certificate-record.
Use the
nameattribute to identify the new certificate-record.curl -X PUT \ --header "Authorization: Bearer $TOKEN" \ "https://10.0.0.2/rest/v1.2/configuration/certificates/generateRequest?recordName=new-restless"The server returns the CSR.
<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <response> <data> <CertificateRequest> <recordName>new-restless</recordName> <certificateSignedRequest>-----BEGIN CERTIFICATE REQUEST----- MIICzDCCAbQCAQAwVDELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAk1BMRMwEQYDVQQH ZTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALOFsEcqNpSNG+LZsuaH EwpCdXJsaW5ndG9uMRQwEgYDVQQKEwtFbmdpbmVlcmluZzENMAsGA1UEAxMEQWNt 9xC6KbZySRpbFz3XDLV+HCECZe2W9pEv6yiGMWFRg+zj4snFIdMM8+fOLiW2FMlB rEe3wysGgZ9a388v2o+5lf1MdXVUmiZyuaq5yb2k3qM/KCMdsY9Y5JnTP7jaRuTM X4XcuSY8GrYEO/WZUFSQHQxkTmr8YBucvbZIHMo+VNdzGLKtT+Whb9eFdMXoVLyw MAoGCCsGAQUFBwMBMA0GCSqGSIb3DQEBCwUAA4IBAQAT4v2F/AbwMnzcnEsGMZ5h J2d273Jv5BUARK35IFZUWcTk56/h7jYvh5wmukUlYtGg/0oAfzBHk6JFOb4sh9f/ W/pWRfgJ2iJk4eyxR4wYB3zPKmXaiDfJ/UrmmJk0kg4o4fnSld+sdFXOkHK1/JGL entSxbePd2kJr+kh91JVndQ1wKI3oMnW3afa1vLG8M/UDZh6riCEFaoFNmfLdD0S J5ySjy3pkedgQtkBVgYdgi0fwUtyUvfclLOE4rNkoLegxMaxX52kkvmhvKsJ5C4V oH0CAwEAAaAzMDEGCSqGSIb3DQEJDjEkMCIwCwYDVR0PBAQDAgWgMBMGA1UdJQQM 4hDaJMPin4i0wRh4sGPplBL3sGsHptO2HkmKWZqMzXVHlD2xSK12f0vRGkCbGaji ugKQjnkB7tjZeE4L7bm7Q/49r8bKLZIJAaJ/3laTVH5w3VtI2jWQV04MRHrVdmDy -----END CERTIFICATE REQUEST----- </certificateSignedRequest> </CertificateRequest> </data> <messages/> <links/> </response> -
Release the configuration lock.
curl -X POST \ --header "Authorization: Bearer $TOKEN" \ "https://10.0.0.2/rest/v1.2/configuration/unlock"
Task 2: Acquire the Certificate
Send the CSR to a Certificate Authority. The CA will reply with a certificate for you to install on the SBC.
Task 3: Import the Certificate
-
Create an empty file called
cert.xmlusing the XML structure shown below.<?xml version="1.0" encoding="UTF-8"?> <ImportCertificate> <recordName></recordName> <format>x509</format> <certificateRequest> </certificateRequest> </ImportCertificate> -
Set the
recordNameelement to the name of the certificate-record previously added to the SBC. -
After the certificate authority responds with a certificate, paste the certificate into the <certificateRequest> element as shown below.
<?xml version="1.0" encoding="UTF-8"?> <ImportCertificate> <recordName>new-restless</recordName> <format>x509</format> <certificateRequest>-----BEGIN CERTIFICATE----- MIIFMDCCAxigAwIBAgIBFjANBgkqhkiG9w0BAQUFADCBgTELMAkGA1UEBhMCVVMx AoIBAQCzhbBHKjaUjRvi2bLmh6xHt8MrBoGfWt/PL9qPuZX9THV1VJomcrmqucm9 ZXJpbmcxDTALBgNVBAMTBEFjbWUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEK UYPs4+LJxSHTDPPnzi4lthTJQSecko8t6ZHnYELZAVYGHYItH8FLclL33JSzhOKz CzAJBgNVBAgMAk1BMRMwEQYDVQQHDApCdXJsaW5ndG9uMRQwEgYDVQQKDAtFbmdp MDRaMD8xCzAJBgNMBIGA1UEChMLRW5naW5lVBAYTAlVTMQswCQYDVQQIEwJNQTEU EmxhcnJ5LmVAb3JhY2xlLmNvbTAeFw0yMDA5MTUxMjM0MDRaFw0yNTA5MTUxMjM0 ZKC3oMTGsV+dpJL5obyrCeQuFQcas1nZPm8h+kcskfPCCfn2pu4N/Zj2d+vcYDzG HQ4EFgQUZVBRSc1beAG+fzLfqXtqEVbi2WAwgbYGA1UdIwSBrjCBq4AU1laBwHsH pN6jPygjHbGPWOSZ0z+42kbkzPcQuim2ckkaWxc91wy1fhwhAmXtlvaRL+sohjFh 9T+iGKb1cI00khtz7EyhgYekgYQwgYExCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJN YWNsZS5jb22CCQDadtCGJeWr5DALBgNVHQ8EBAMCBaAwDQYJKoZIhvcNAQEFBQAD BgNVBAMMDkFjbWUgUGFja2V0IE1BMSEwHwYJKoZIhvcNAQkBFhJsYXJyeS5lQG9y FCowbP+DMkJeP0pSjw5KmXzGpuIQ2iTD4p+ItMEYeLBj6ZQS97BrB6bTth5Jilma bmVlcmluZzEXMBUGA1UEAwwOQWNtZSBQYWNrZXQgTUExITAfBgkqhkiG9w0BCQEW jM11R5Q9sUitdn9L0RpAmxmo4qB9AgMBAAGjgfMwgfAwCQYDVR0TBAIwADAdBgNV DdfgEutmptjNP2dmfesPmVTfVNg9v/RgrHjFxbi/z6gyy1eTumIHzbpydvjm94WC fvI12+MqToIG+xlbhCwZGvGeaBl8NbGWpStLtmisUY2/NUOyvBRPDBy8lCCdLX/w iq5GMBdW6tAA8rzxJmjRgOJtmB5tQ89actULn9vuUl/uZgVuJDZC19Sbb6yAX3Nh c0oAsC2kkp5E+Osjp2I8o7OnQ9rpu7wuIbKewFxsMNBLmaMaNDgT8t/JXzXE40Fy QTETMBEGA1UEBwwKQnVybGluZ3RvbjEUMBIGA1UECgwLRW5naW5lZXJpbmcxFzAV ggIBAA5xf2krzCC5a+FYr1/z4AIv9IMdKHM0oR2srejYqCEb7b9bGvN5Oc5PpGFa e4uDzlyTrDrCYVBNBdrusD45bssGoFyancnycfcVmImaudEn1gwvo2Kv19nXmdjg hK2hAZzq3o7PK2oy4dqjPOZ2C2UvaGvF8InxJ3C+C03RIBhP4Fjahgt7JvzyWoiU SR3KDZjKcZerFaLaFqR7CIqaC4i5DB4b3uSwsB37DhvOQxwPpnIqjVPHg6zDYcx6 Is81AhPoYg4xKZAHIoPMyiPq/zFx9nW4u2kQtyeZIoGMA7wnUuY4FOiRgXlikS49 mas/VJIi3tBpVtv2LKaOkM1UK9nH5hQNhBkCu0iWhJEwp/7q -----END CERTIFICATE-----</certificateRequest> </ImportCertificate>Replace the contents of the <certificateRequest> element with the certificate you received from your Certificate Authority.
-
Acquire the configuration lock.
curl -X POST \ --header "Authorization: Bearer $TOKEN" \ "https://10.0.0.2/rest/v1.2/configuration/lock" -
Import the certificate.
curl -X PUT \ -d@cert.xml \ --header "Authorization: Bearer $TOKEN" \ "https://10.0.0.2/rest/v1.2/configuration/certificates/import" -
Then save, verify, and activate the configuration.
-
Release the configuration lock.
curl -X POST \ --header "Authorization: Bearer $TOKEN" \ "https://10.0.0.2/rest/v1.2/configuration/unlock" -
Reboot the SBC.
curl -X POST \ --header "Authorization: Bearer $TOKEN" \ "https://10.0.0.2/rest/v1.2/admin/reboot"