Ruby
Ruby
Install PFX Certificates and Private Keys to Windows
See more PFX/P12 Examples
Demonstrates how to install the certificates and private keys contained in a PFX to the Windows certificate stores.Chilkat Ruby Downloads
require 'chilkat'
success = false
pfx = Chilkat::CkPfx.new()
success = pfx.LoadPfxFile("qa_data/pfx/test_secret.pfx","secret")
if (success == false)
print pfx.lastErrorText() + "\n";
exit
end
# See the online reference documentation for more information about the ImportToWindows method.
# Mark imported privae keys as exportable.
exportable = true
# If userProtected is true, the user is to be notified through a dialog box or other method when certain attempts to use this key are made.
userProtected = false
# If machineKeyset is true, the private keys are stored under the local computer and not under the current user.
machineKeyset = false
# If allowOverwriteKey is true, allow overwrite of the existing key.
allowOverwriteKey = false
# If allowExport is true, then the imported key can later be exported back to a PFX.
# (It also allows for applications to directly access the private key material.)
allowExport = true
# Indicate where to import types of certs.
leafStore = "My"
intermediateStore = "CertificationAuthority"
rootStore = "AuthRoot"
success = pfx.ImportToWindows(exportable,userProtected,machineKeyset,allowOverwriteKey,allowExport,leafStore,intermediateStore,rootStore,"")
if (success == false)
print pfx.lastErrorText() + "\n";
exit
end
# Show information about the certificates imported
json = Chilkat::CkJsonObject.new()
pfx.GetLastJsonData(json)
json.put_EmitCompact(false)
print json.emit() + "\n";
# Sample output:
# {
# "exportable": true,
# "userProtected": false,
# "machineKeyset": false,
# "allowOverwriteKey": false,
# "allowExport": true,
# "key": [
# {
# "name": "{F09B755A-1E90-444D-9851-02B86CA14961}",
# "storageProvider": "Microsoft Software Key Storage Provider"
# }
# ],
# "cert": [
# {
# "DN": "...",
# "type": "intermediate",
# "storeName": "CertificationAuthority",
# "imported": true
# },
# {
# "DN": "...",
# "type": "root",
# "storeName": "AuthRoot",
# "imported": true
# },
# {
# "DN": "....",
# "type": "leaf",
# "storeName": "My",
# "keyContainer": "{345D4EAD-B8DD-4150-9A1F-4BC6437E77A2}",
# "machineKeyset": true,
# "imported": true
# }
# ]
# }
print "Success." + "\n";