DataFlex
DataFlex
Convert Let's Encrypt PEM Files to a PFX
See more PFX/P12 Examples
Demonstrates how to convert the .pem files provided by Let's Encrypt to a single PFX.Chilkat DataFlex Downloads
Use ChilkatAx-win32.pkg
Procedure Test
Boolean iSuccess
Handle hoSbPem
Variant vSbFullChainPem
Handle hoSbFullChainPem
Handle hoPfx
String sPfxPassword
String sTemp1
Move False To iSuccess
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// Let's Encrypt provides four .pem files
// 1. fullchain.pem
// 2. privkey.pem
// 3. cert.pem
// 4. chain.pem
// The cert.pem and chain.pem are redundant.
// The fullchain.pem is composed of the cert.pem and chain.pem.
// To convert the PEM's to a single .pfx, we don't need the redundant data.
// The privkey.pem and fullchain.pem provide the required data.
// We can ignore cert.pem and chain.pem (because those certs are already found in fullchain.pem).
// We need a single .pem file that contains both the private key, the cert,
// and the certs in the chain of authentication.
// Let's combine priveky.pem and fullchain.pem into a single .pem
Get Create (RefClass(cComChilkatStringBuilder)) To hoSbPem
If (Not(IsComObjectCreated(hoSbPem))) Begin
Send CreateComObject of hoSbPem
End
Get ComLoadFile Of hoSbPem "qa_data/pem/lets_encrypt/privkey.pem" "utf-8" To iSuccess
If (iSuccess = False) Begin
Showln "Failed to load privkey.pem"
Procedure_Return
End
// To be safe, append a blank line..
Get ComAppendLine Of hoSbPem "" False To iSuccess
Get Create (RefClass(cComChilkatStringBuilder)) To hoSbFullChainPem
If (Not(IsComObjectCreated(hoSbFullChainPem))) Begin
Send CreateComObject of hoSbFullChainPem
End
Get ComLoadFile Of hoSbFullChainPem "qa_data/pem/lets_encrypt/fullchain.pem" "utf-8" To iSuccess
If (iSuccess = False) Begin
Showln "Failed to load fullchain.pem"
Procedure_Return
End
// Append the full cert chain PEM to the private key PEM.
Get pvComObject of hoSbFullChainPem to vSbFullChainPem
Get ComAppendSb Of hoSbPem vSbFullChainPem To iSuccess
// Load the combined PEM into a Chilkat PFX object.
Get Create (RefClass(cComChilkatPfx)) To hoPfx
If (Not(IsComObjectCreated(hoPfx))) Begin
Send CreateComObject of hoPfx
End
Get ComGetAsString Of hoSbPem To sTemp1
Get ComLoadPem Of hoPfx sTemp1 "no password required" To iSuccess
If (iSuccess = False) Begin
Get ComLastErrorText Of hoPfx To sTemp1
Showln sTemp1
Procedure_Return
End
// Write the PFX w/ a password.
Move "secret" To sPfxPassword
Get ComToFile Of hoPfx sPfxPassword "qa_output/sample.pfx" To iSuccess
If (iSuccess = False) Begin
Get ComLastErrorText Of hoPfx To sTemp1
Showln sTemp1
Procedure_Return
End
Showln "Success!"
End_Procedure