Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Perl) Renew a DigiCert Certificate from an EST-enabled profileDemonstrates how to renew a certificate from an EST-enabled profile in DigiCert® Trust Lifecycle Manager. (The certificate must be within the renewal window configured in the certificate profile. The CSR must have same Subject DN values as the original certificate.)
use chilkat(); # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. # The example below duplicates the following OpenSSL commands: # # # Name of certificate as argument 1 # # # Make new key # openssl ecparam -name prime256v1 -genkey -noout -out ${1}.key.pem # # # Make csr # openssl req -new -sha256 -key ${1}.key.pem -out ${1}.p10.csr -subj "/CN=${1}" # # # Request new cert # curl -v --cacert data/ca.pem --cert data/${1}.pem --key data/${1}.key.pem # --data-binary @${1}.p10.csr -o ${1}.p7.b64 -H "Content-Type: application/pkcs10" https://clientauth.demo.one.digicert.com/.well-known/est/IOT/simplereenroll # # # Convert to PEM # openssl base64 -d -in ${1}.p7.b64 | openssl pkcs7 -inform DER -outform PEM -print_certs -out ${1}.pem # ------------------------------------------------------------------------------------------------------------------ # Create a Fortuna PRNG and seed it with system entropy. # This will be our source of random data for generating the ECC private key. $fortuna = chilkat::CkPrng->new(); $entropy = $fortuna->getEntropy(32,"base64"); $success = $fortuna->AddEntropy($entropy,"base64"); $ec = chilkat::CkEcc->new(); # Generate a random EC private key on the prime256v1 curve. # privKey is a PrivateKey $privKey = $ec->GenEccKey("prime256v1",$fortuna); if ($ec->get_LastMethodSuccess() != 1) { print $ec->lastErrorText() . "\r\n"; exit; } # Create the CSR object and set properties. $csr = chilkat::CkCsr->new(); # Specify your CN $csr->put_CommonName("mysubdomain.mydomain.com"); # Create the CSR using the private key. $bdCsr = chilkat::CkBinData->new(); $success = $csr->GenCsrBd($privKey,$bdCsr); if ($success == 0) { print $csr->lastErrorText() . "\r\n"; exit; } # Save the private key and CSR to files. $privKey->SavePkcs8EncryptedPemFile("password","c:/temp/qa_output/ec_privkey.pem"); $bdCsr->WriteFile("c:/temp/qa_output/csr.pem"); # ---------------------------------------------------------------------- # Now do the CURL request to POST the CSR and get the new certificate. $http = chilkat::CkHttp->new(); $tlsClientCert = chilkat::CkCert->new(); $success = $tlsClientCert->LoadFromFile("data/myTlsClientCert.pem"); if ($success == 0) { print $tlsClientCert->lastErrorText() . "\r\n"; exit; } $bdTlsClientCertPrivKey = chilkat::CkBinData->new(); $success = $bdTlsClientCertPrivKey->LoadFile("data/myTlsClientCert.key.pem"); if ($success == 0) { print "Failed to load data/myTlsClientCert.key.pem" . "\r\n"; exit; } $tlsClientCertPrivKey = chilkat::CkPrivateKey->new(); $success = $tlsClientCertPrivKey->LoadAnyFormat($bdTlsClientCertPrivKey,""); if ($success == 0) { print $tlsClientCertPrivKey->lastErrorText() . "\r\n"; exit; } $success = $tlsClientCert->SetPrivateKey($tlsClientCertPrivKey); if ($success == 0) { print $tlsClientCert->lastErrorText() . "\r\n"; exit; } $http->SetSslClientCert($tlsClientCert); $http->put_RequireSslCertVerify(1); # The body of the HTTP request contains the binary CSR. # resp is a HttpResponse $resp = $http->PBinaryBd("POST","https://clientauth.demo.one.digicert.com/.well-known/est/IOT/simplereenroll",$bdCsr,"application/pkcs10",0,0); if ($http->get_LastMethodSuccess() == 0) { print $http->lastErrorText() . "\r\n"; exit; } if ($resp->get_StatusCode() != 200) { print "response status code = " . $resp->get_StatusCode() . "\r\n"; print $resp->bodyStr() . "\r\n"; print "Failed" . "\r\n"; exit; } # The response is the Base64 DER of the new certificate. $myNewCert = chilkat::CkCert->new(); $success = $myNewCert->LoadFromBase64($resp->bodyStr()); if ($success == 0) { print $myNewCert->lastErrorText() . "\r\n"; print "Cert data = " . $resp->bodyStr() . "\r\n"; print "Failed." . "\r\n"; exit; } $success = $myNewCert->SaveToFile("c:/temp/qa_output/myNewCert.cer"); if ($success == 0) { print $myNewCert->lastErrorText() . "\r\n"; print "Failed." . "\r\n"; exit; } print "Success." . "\r\n"; |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.