Hashicorp Vault plugin for the AnyCA REST Gateway Framework
Hashicorp Vault AnyCA REST Gateway Plugin is open source and community supported, meaning that there is no support guaranteed from Keyfactor Support for these tools.
To report a problem or suggest a new feature, use the Issues tab. If you want to contribute actual bug fixes or proposed enhancements, use the Pull requests tab.
# Introduction This AnyGateway plug-in enables issuance, revocation, and synchronization of certificates from the Hashicorp Vault PKI Secrets Engine.
Currently this plug-in only supports authentication into Vault via Token.
- An instance of Hashicorp Vault v10.5+ that is accessible from the CA Gateway host
- An instance of the CA Gateway Framework (REST version)
In order to enroll for certificates the Keyfactor Command server must trust the trust chain. Once you create your Root and/or Subordinate CA, make sure to import the certificate chain into the AnyGateway and Command Server certificate store
Make sure the following information is available, as it will be needed to complete the installation.
- The fully qualified URI of the instance of Hashicorp Vault
- The namespace and mountpoint of the instance of the PKI secrets engine running in Vault
- An authentication token that has sufficient authority to perform operations on the PKI Secrets engine
- PKI Secrets Engine Roles defined that will correspond to certificate templates to be used when signing certificates with the CA.
- Install the AnyCA Gateway Rest per the official Keyfactor documentation.
- Download latest successful build from GitHub Releases
- Copy the contents of the release zip file into the (AnyGatewayRest Installation Folder)\AnyGatewayREST\net6.0\Extensions AnyGateway directory.
- The manifest.json tells the Gateway how to locate our plugin. It should be copied to the Connectors sub-folder in the AnyCA Gateway Rest installation path.
- Restart the gateway service.
- Navigate to the AnyCA Gateway Rest portal and verify that the Gateway recognizes the Hashicorp Vault CA plugin by hovering over the ⓘ symbol to the right of the Gateway name.
{
"extensions": {
"Keyfactor.AnyGateway.Extensions.IAnyCAPlugin": {
"HashicorpVaultCAPlugin": {
"assemblypath": "../HashicorpVaultCAPlugin.dll",
"TypeFullName": "Keyfactor.Extensions.CAPlugin.HashicorpVault.HashicorpVaultCAConnector"
}
}
}
}
- Follow the official AnyCA Gateway REST documentation to define a new Certificate Authority, and use the notes below to configure the Gateway Registration and CA Connection tabs:
-
Gateway Registration
In order to enroll for certificates the Keyfactor Command server must trust the trust chain. Once you know your Root and/or Subordinate CA in your Hashicorp Vault instance, make sure to download and import the certificate chain into the Command Server certificate store
Once the necessary files are copied to the appropriate locations and the AnyCA Gateway Rest is up and running, navigate to the AnyCA Gateway Rest portal and configure the CA.
-
CA Connection
Populate using the configuration fields collected in the requirements section.
- Host - The fully qualified URI including port for the instance of vault. ex: https://127.0.0.1:8001
- Namespace - If you are utilizing Vault Namespaces (Enterprise feature); the namespace containing the PKI secrets engine containing your CA.
- MountPoint - The mount point of the PKI secrets engine.
- Token - The token that will be used by the gateway for authentication. It should have policies defined that ensure it can perform operations on the path defined by
<host>/<namespace>/<mount point>
- Enabled - Flag to Enable or Disable gateway functionality. Disabling is primarily used to allow creation of the CA prior to configuration information being available.
-
Template mapping
The product ID's correspond to the role names in the Hashicorp Vault PKI Secrets engine. After the certificate profile is associated with the product ID and imported as a certificate template into Command, requests for certificates will pass the associated role name as part of the request and the issuance policies defined in Vault for that role will be applied as if you were issuing the certificates directly from Vault.
In order to create create the certificate templates associated with the role names once the CA has been defined in the gateway portal, follow these steps:
- navigate to the "Certificate Profiles" tab
- Create an entry for each of the PKI secrets engine roles you would like to use for issuing certificates from the Hashicorp Vault CA.
- Navigate to the "Certificate Authorities" tab and click "Edit"
- In the "Edit CA" window, navigate to the "Templates" tab.
- Create an association between each of the certificate profiles we just created with the PKI secrets engine roles retreived from Vault.
Now that the AnyCA Gateway Rest is configured with the details of our Hashicorp Vault hosted CA, we will need to define the CA in Keyfactor Command
- Certificate Authorities
- Log into Keyfactor Command with an account that has sufficient permissions to define a new Certificate Authorities.
- Navigate to "Locations > Certificate Authorities"
- If the AnyCA Gateway Rest host is Active Directory joined with Command
- click "Import" to automatically load the details from the Gateway
- If not Active Directory domain joined, click "Add" in order to manually fill in the details
-
Basic
- Logical Name: The logical name of the CA, as defined in the Gateway Portal.
- Host URL: The host url of the instance of the AnyCA Gateway Rest. This will be the same URL you use to navigate to the Gateway Portal
- Configuration Tenant: this can be any name. It is used by Command to create an Active Directory tenant for the CA.
- Fill in the rest of the details according to your requirements
-
Authorization Methods
You will need to have the PFX certificate, including private key, for Keyfactor Command to use when authenticating into the Gateway. This should be the certificate associated with the identifier (thumbprint or serial number) that was provided when the Gateway was installed.- Click the "Select authentication certificate" button and choose this PFX file, enter the password if prompted.
- Click "Save and Test" in order to save the configuration and see the result of Command attempting to authenticate.
-
When troubleshooting the Gateway configuration, the log files can be very useful. They are located in the "logs" sub-folder in the gateway installation path.
-
Authentication into the Gateway Portal fails
- Make sure that the authentication certificate with private key is installed into the "Current User > Personal" certificate store
- If you are seeing an error that indicates the gateway is unable to check the CRL for the certificate..
- make sure the CRL endpoint is defined on the CA in Vault
- If no CRL is available, you can turn off the CRL check on the authentication certificate by the Gateway thusly:
- stop the Gateway service on the host
- edit the "appsettings.json" file in the Gateway installation directory
- Change the value of "CheckClientCRL" to "False"
- Restart the gateway
- re-attempt login
-
If an error response is returned when attempting to sign or issue certificates via the CA in Command
- Check the CA_Gateway_Log.txt file in the "logs" subfolder of the Gateway installation path
- Make sure that the Vault PKI Role policies allow issuing certificates with the defined values