POST Enrollment PFX
POST Enrollment PFX
The POST /Enrollment Certificate enrollment refers to the process by which a user requests a digital certificate. The user must submit the request to a certificate authority (CA)./PFX A PFX file (personal information exchange format), also known as a PKCS#12 archive, is a single, password-protected certificate archive that contains both the public and matching private key and, optionally, the certificate chain. It is a common format for Windows servers. method is used to enroll for a certificate by supplying data in the desired fields. This method returns HTTP 200 OK on a success with a message body containing a list of certificate details and any metadata Metadata provides information about a piece of data. It is used to summarize basic information about data, which can make working with the data easier. In the context of Keyfactor Command, the certificate metadata feature allows you to create custom metadata fields that allow you to tag certificates with tracking information about certificates. that was associated with the certificate request.
Global or container-level schedule permissions for certificate stores are needed to install a certificate generated with this method into a certificate store (see the x-CertificateFormat parameter A parameter or argument is a value that is passed into a function in an application.) using the POST /Enrollment/PFX/Deploy method (see POST Enrollment PFX Deploy) or POST /Enrollment/PFX/Replace method (see POST Enrollment PFX Replace).
This method has two available versions. Keyfactor recommends using the newer method when possible. For more information about versioning, see Versioning.
Version 2 of the POST /Enrollment/PFX method redesigns how enrollment flow works to handle require approval functionality in a Keyfactor Command workflow with support for delivery into certificate stores. Users who are planning to use require approval workflow functionality and deliver enrolled certificates into certificate stores must use version 2 of this endpoint An endpoint is a URL that enables the API to gain access to resources on a server..
Table 331: POST Enrollment PFX v2 Input Parameters
Name | In | Description |
---|---|---|
Stores | Body |
An object containing a comma delimited set of arrays indicating the certificate stores to which the certificate should be distributed. Show store details. |
CustomFriendlyName | Body |
Required*. A string that sets a custom friendly name for the certificate. This field is required if the Require Custom Friendly Name application setting is set to true (the default is false). See Application Settings: Enrollment Tab in the Keyfactor Command Reference Guide for more information. |
Password | Body |
Required. A string that sets the password used to encrypt the contents of the PFX file. The minimum password length is controlled by the Password Length application setting. The default is 12. See Application Settings: Enrollment Tab in the Keyfactor Command Reference Guide for more information. |
Subject | Body |
Required*. A string containing the subject name using X.500 format. For example: "Subject": "CN=websrvr14.keyexample.com,OU=IT,O=\"Key Example, Inc.\",L=Independence,ST=OH,C=US"
This field is required if the Common Name Regular Expression application setting is set to the default value of .+. See Application Settings: Enrollment Tab in the Keyfactor Command Reference Guide for more information. |
IncludeChain | Body |
A Boolean that sets whether to include the certificate chain in the response (true) or not (false). The default is true. |
ChainOrder | Body | A string indicating the order in which the certificate chain should be returned if IncludeChain is set to true. Supported values are EndEntityFirst or RootFirst. |
RenewalCertificateId | Body |
An integer that sets the ID of the certificate to be renewed when the method is called on a certificate renewal. The RenewalCertificateId parameter is used in conjunction with InstallIntoExistingCertificateStores parameter to make the determination as to distribution of the certificate to certificate stores. If InstallIntoExistingCertificateStores is true, the certificate will be distributed to certificate stores that the certificate identified in RenewalCertificateId is found in. |
CertificateAuthority | Body |
Required*. A string that sets the name of the certificate authority that will be used to enroll against if there is more than one available with the provided template name. The certificate authority name can either be provided in hostname\\logical name format or as just the logical name. For example: corpca01.keyexample.com\\CorpIssuingCA1 OR CorpIssuingCA1
If no certificate authority is provided, one will be chosen at random from the certificate authorities available for enrollment with the provided Template. This field is optional unless the enrollment is being done against a standalone CA, in which case it is required. |
Metadata | Body |
An array of key/value pairs that set the values for the metadata fields that will be associated with the certificate once it is in Keyfactor Command. The key is the field name and the value is the value for the field. For example: "Metadata": { "AppOwnerFirstName": "William", // This is a String field. "AppOwnerLastName": "Smith", "AppOwnerEmailAddress": "william.smith@keyexample.com", "BusinessCritical": "true", // This is a Boolean field. "BusinessUnit": "E-Business", // This is a Multiple Choice field with a pre-defined value. "Notes": "Here are some notes.", // This is a BigText field. "SiteCode": 3, // This is an integer field. "TicketResolutionDate": "2021-07-23" // This is a Date field in yyyy-mm-dd format. } See Certificate Metadata in the Keyfactor Command Reference Guide for more information. |
Timestamp | Body | The current date and time. The date and time should be given using the ISO 8601 UTC time format YYYY-MM-DDTHH:mm:ss.000Z (e.g. 2021-05-19T16:23:01Z). |
Template | Body |
Required*. A string that sets the name of the certificate template that should be used to issue the certificate. The template short name should be used. This field is required unless the enrollment is being done against a standalone CA. |
SANs | Body |
An array of key/value pairs that represent the elements for Keyfactor Command to use when generating the subject alternative name (SAN) for the certificate requested by the CSR. Show SAN key values. For example: "SANs": { "dns": [ "dnssan1.keyexample.com", "dnssan2.keyexample.com", "dnssan3.keyexample.com" ], "ip4": [ "192.168.2.73" ] } |
InstallIntoExistingCertificateStores | Body |
A Boolean that sets whether to deploy the certificate to certificate stores (true) or not (false). The default is true. The RenewalCertificateId parameter is used in conjunction with InstallIntoExistingCertificateStores parameter to make the determination as to distribution of the certificate to certificate stores. If InstallIntoExistingCertificateStores is true, the certificate will be distributed to certificate stores that the certificate identified in RenewalCertificateId is found in. |
AdditionalEnrollmentFields | Body | An array of key/value pairs that provide values for any custom enrollment fields set on the certificate template to supply custom request attributes to the CA during the enrollment process. For example: "AdditionalEnrollmentFields": { "CustomStringOne": "MyValue", "CustomMultiChoiceOne": "ValueTwo" } See Certificate Template Operations in the Keyfactor Command Reference Guide for more information. |
x-CertificateFormat | Header |
Required. The desired output format for the certificate. Available options are:
|
Table 332: POST Enrollment PFX v2 Response Data
Value | Description |
---|---|
SuccessfulStores | An object containing a comma delimited list of certificate stores, referenced by certificate store GUID, to which the certificate was successfully scheduled for deployment. |
CertificateInformation |
Information about the certificate that was requested. Show certificate information details. |
Metadata |
An array of the custom metadata values set on the certificate. The values vary depending on customization done in your environment. Show metadata structure details. See Certificate Metadata in the Keyfactor Command Reference Guide for more information. |
Version 1 of the POST /Enrollment/PFX method includes the same capabilities as version 2 except when used in conjunction with Keyfactor Command workflows that require approval with an intended end goal of delivering the resulting certificate into a certificate store. In this specific case, version 2 must be used.
Table 333: POST Enrollment PFX v1 Input Parameters
Name | In | Description |
---|---|---|
CustomFriendlyName | Body |
Required*. A string that sets a custom friendly name for the certificate. This field is required if the Require Custom Friendly Name application setting is set to true (the default is false). See Application Settings: Enrollment Tab in the Keyfactor Command Reference Guide for more information. |
Password | Body |
Required. A string that sets the password used to encrypt the contents of the PFX file. The minimum password length is controlled by the Password Length application setting. The default is 12. See Application Settings: Enrollment Tab in the Keyfactor Command Reference Guide for more information. |
PopulateMissingValuesFromAD | Body |
A Boolean that sets whether to populate the information in the subject from Active Directory (true) or not (false). The default is false. |
Subject | Body |
Required*. A string containing the subject name using X.500 format. For example: "Subject": "CN=websrvr14.keyexample.com,OU=IT,O=\"Key Example, Inc.\",L=Independence,ST=OH,C=US"
This field is required if the Common Name Regular Expression application setting is set to the default value of .+. See Application Settings: Enrollment Tab in the Keyfactor Command Reference Guide for more information. |
IncludeChain | Body |
A Boolean that sets whether to include the certificate chain in the response (true) or not (false). The default is true. |
ChainOrder | Body | A string indicating the order in which the certificate chain should be returned if IncludeChain is set to true. Supported values are EndEntityFirst or RootFirst. |
RenewalCertificateId | Body |
An integer that sets the ID of the certificate to be renewed when the method is called on a certificate renewal. |
CertificateAuthority | Body |
Required*. A string that sets the name of the certificate authority that will be used to enroll against if there is more than one available with the provided template name. The certificate authority name can either be provided in hostname\\logical name format or as just the logical name. For example: corpca01.keyexample.com\\CorpIssuingCA1 OR CorpIssuingCA1
If no certificate authority is provided, one will be chosen at random from the certificate authorities available for enrollment with the provided Template. This field is optional unless the enrollment is being done against a standalone CA, in which case it is required. |
Timestamp | Body | The current date and time. The date and time should be given using the ISO 8601 UTC time format YYYY-MM-DDTHH:mm:ss.000Z (e.g. 2021-05-19T16:23:01Z). |
Template | Body |
Required*. A string that sets the name of the certificate template that should be used to issue the certificate. The template short name should be used. This field is required unless the enrollment is being done against a standalone CA. |
Metadata | Body |
An array of key/value pairs that set the values for the metadata fields that will be associated with the certificate once it is in Keyfactor Command. The key is the field name and the value is the value for the field. For example: "Metadata": { "AppOwnerFirstName": "William", // This is a String field. "AppOwnerLastName": "Smith", "AppOwnerEmailAddress": "william.smith@keyexample.com", "BusinessCritical": "true", // This is a Boolean field. "BusinessUnit": "E-Business", // This is a Multiple Choice field with a pre-defined value. "Notes": "Here are some notes.", // This is a BigText field. "SiteCode": 3, // This is an integer field. "TicketResolutionDate": "2021-07-23" // This is a Date field in yyyy-mm-dd format. } See Certificate Metadata in the Keyfactor Command Reference Guide for more information. |
SANs | Body |
An array of key/value pairs that represent the elements for Keyfactor Command to use when generating the subject alternative name (SAN) for the certificate requested by the CSR. Show SAN key values. For example: "SANs": { "dns": [ "dnssan1.keyexample.com", "dnssan2.keyexample.com", "dnssan3.keyexample.com" ], "ip4": [ "192.168.2.73" ] } |
AdditionalEnrollmentFields | Body | An array of key/value pairs that provide values for any custom enrollment fields set on the certificate template to supply custom request attributes to the CA during the enrollment process. For example: "AdditionalEnrollmentFields": { "CustomStringOne": "MyValue", "CustomMultiChoiceOne": "ValueTwo" } See Certificate Template Operations in the Keyfactor Command Reference Guide for more information. |
x-CertificateFormat | Header |
Required. The desired output format for the certificate. Available options are:
|
Table 334: POST Enrollment PFX v1 Response Data
Value | Description |
---|---|
CertificateInformation |
Information about the certificate that was requested. Show certificate information details. |
Metadata |
An array of the custom metadata values set on the certificate. The values vary depending on customization done in your environment. Show metadata structure details. See Certificate Metadata in the Keyfactor Command Reference Guide for more information. |