Sample code for 30+ languages & platforms
Swift

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 Swift Downloads

Swift

func chilkatTest() {
    var success: Bool = false

    // 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

    let sbPem = CkoStringBuilder()!
    success = sbPem.loadFile(path: "qa_data/pem/lets_encrypt/privkey.pem", charset: "utf-8")
    if success == false {
        print("Failed to load privkey.pem")
        return
    }

    // To be safe, append a blank line..
    sbPem.appendLine(str: "", crlf: false)

    let sbFullChainPem = CkoStringBuilder()!
    success = sbFullChainPem.loadFile(path: "qa_data/pem/lets_encrypt/fullchain.pem", charset: "utf-8")
    if success == false {
        print("Failed to load fullchain.pem")
        return
    }

    // Append the full cert chain PEM to the private key PEM.
    sbPem.appendSb(sb: sbFullChainPem)

    // Load the combined PEM into a Chilkat PFX object.
    let pfx = CkoPfx()!
    success = pfx.loadPem(pemStr: sbPem.getAsString(), password: "no password required")
    if success == false {
        print("\(pfx.lastErrorText!)")
        return
    }

    // Write the PFX w/ a password.
    var pfxPassword: String? = "secret"
    success = pfx.toFile(password: pfxPassword, path: "qa_output/sample.pfx")
    if success == false {
        print("\(pfx.lastErrorText!)")
        return
    }

    print("Success!")

}