HashiCorp Vault CA Integration for SSH
Last modified on January 8, 2025
This feature is part of the Enterprise plan. If it is not enabled for your organization, please contact StrongDM at the StrongDM Help Center.
This guide provides general information on how to add an existing HashiCorp Vault certificate authority (CA) as a third-party CA to StrongDM. Integrated Vault CAs may be used for certificate-based SSH resources configured for either TLS certificate-based authentication, AppRole authentication, or token-based authentication.
Prerequisites
Before you begin, ensure that you have the following.
- Administrator permission level in StrongDM
- Running Vault server that is accessible by a StrongDM gateway or relay
- Familiarity using the HashiCorp SSH Secrets engine and configuring SSH certificates
- Properly configured CA in the Vault instance with a mount point and signing role
- Correct paths to the CA
Vault Configuration Considerations
Because StrongDM doesn’t manage or configure third-party CAs, it is up to you to configure your SSH Secrets engine appropriately for your organization, as well as to ensure that the appropriate CA is trusted by the target resources. This section briefly describes the most important parts of Vault setup to consider when integrating a Vault CA with StrongDM.
Mount point
The Vault SSH service can be mounted multiple times to distinct mount points. Each mount point is configured with its own CA and signing role. A distinct Secret Store is created and configured for each CA.
Key type
The CA defines the key type and, in the case of variable bit length key types, the key bits. The default CA in HashiCorp Vault is ssh-rsa with 4096 bits. The key type of the CA must match the key type of the certificate-based resource in StrongDM.
Signing role
Certificates that are issued by the CA must be signed by a role that is configured for the specific mount point of the CA. The signing role defines the default values for the SSH certificates as well as what extensions and features are allowed in the SSH certificates.
max_ttl
setting, which sets the maximum value for the certificate’s TTL. For example, setting max_ttl
to 30m0s
in the signing role allows the certificate to be valid for a maximum of 30 minutes. If set in the signing role, the max_ttl
value overrides the configured Certificate TTL Minutes property in StrongDM if the Certificate TTL Minutes value is higher than the signing role’s max_ttl
value.Please ensure that your signing role in Vault matches the following example signing role, which includes the minimum required settings to work with certificate-based SSH resources.
SSH example signing role
{
"algorithm_signer": "rsa-sha2-256",
"allow_user_certificates": true,
"allowed_users": "*",
"allowed_extensions": "permit-X11-forwarding,permit-agent-forwarding,permit-port-forwarding,permit-pty,permit-user-rc",
"default_extensions": {
"permit-X11-forwarding": "",
"permit-agent-forwarding": "",
"permit-port-forwarding": "",
"permit-pty": "",
"permit-user-rc": "",
},
"key_type": "ca",
"default_user": "ubuntu",
"max_ttl": "30m0s"
}
Add Vault CA in Admin UI
To add a Vault SSH CA in the Admin UI, follow these steps.
- From the Settings > Credentials Management page in the Certificate Authorities tab, click Add certificate authority.
- Enter the Name for the CA (any name).
- For Type, select HashiCorp Vault SSH, HashiCorp Vault SSH (AppRole), or HashiCorp Vault SSH (Token). The type corresponds to your chosen authentication method that enables your StrongDM relay to authenticate with Vault: TLS certificate-based authentication, AppRole authentication, or token-based authentication.
- The form updates with other CA properties, some of which are specific to the selected type. Complete all required properties.
- Click Create certificate authority.
VAULT_TOKEN
environment variable on your StrongDM node. To do so, in your command line on the node, or when logged in to the node, open the file /etc/sysconfig/sdm-proxy
(unless you have moved or renamed your sdm-proxy
file) for editing. In the file, add VAULT_TOKEN=<TOKEN>
as a new line, where <TOKEN>
is the actual value. Restart the sdm-proxy
service (with something like sudo systemctl restart sdm-proxy
, depending on your distribution).Vault SSH CA properties
The following properties are for HashiCorp Vault SSH, HashiCorp Vault SSH (AppRole), and/or HashiCorp Vault SSH (Token).
Property | Requirement | Description |
---|---|---|
Server Address | Required | Address where the CA is stored (for example, https://vault.example.com:1234 ) |
Client Certificate Path | Required | Path to where the TLS certificate is stored on the relay (for example, /etc/strongdm/certs/client.crt ) |
Client Private Key Path | Required | Path to where the TLS private key is stored on the relay (for example, /etc/strongdm/certs/client.key ) |
CA Certificate Path | Optional | Path to where the CA certificate is stored on the relay (for example, /etc/strongdm/certs/ca.crt ) |
Signing Role | Required | Signing role configured in Vault for signing the certificate (string; for example, signing-role ) |
SSH Mount Point | Required | SSH mount point (string; for example, dev-ssh ) configured for the CA to be used |
Namespace | Optional | Namespace in Vault (for example, prod-namespace/ ) |
Certificate TTL Minutes | Required | TTL of the issued certificate, in minutes (for example, 480 ); default is 5 ; if not specified, the default TTL of five minutes is used |
All third-party CAs except for AD CS and Keyfactor EJBCA have a default TTL of five minutes. A five-minute TTL ensures short-lived certificates so that authentications can’t be reused beyond the specified TTL. If you wish to have a longer TTL, please set it appropriately for your organization and consult your CA service provider and CA administrator.
Please note that in the Vault signing role, max_ttl
sets the maximum TTL for certificates issued by the CA. If that is set and if a value is also specified for Certificate TTL Minutes in StrongDM, the resulting TTL is the lower of the two values. See the signing role section of this guide for more information.
Add the Vault CA to a Certificate-Based SSH Server
- If you have not already done so, follow the instructions to add an SSH server with certificate auth.
- On the resource form, pay particular attention to Certificate Authority and Key Type.
- For Certificate Authority, select the newly added Vault CA.
- For Key Type, select the key type configured for the CA in Vault: RSA-2048, RSA-4096, ECDSA-256, ECDSA-384, ECDSA-521, or ED25519. The key type must match what is configured on the Vault side.
- Complete all required fields and save.
- Test the connection to the resource (for example, use
sdm ssh
in the CLI to connect).
Manage the CA
After you have added the Vault CA and set a certificate-based server to use it, you may manage the CA and review its settings on the Certificate Authorities tab of the Settings > Credentials Management page in the Admin UI. You may select the CA from the list or click its Details button to view diagnostics, update its settings, or delete the CA configuration.
The Diagnostics tab shows all the nodes (gateways and relays) that are configured to access the CA, as well as health information for the nodes.
If the CA is unable to be accessed by any gateway or relay, please review the CA’s Settings tab and make sure the CA credentials are correct.
Additional Information
Third-party CAs also may be added and managed in the CLI, SDKs, and Terraform. Note that third-party CAs are treated like secret stores in the CLI, SDKs, and Terraform. As such, they use secret store commands, domain objects, and resources.
API Account example-terraform-key (cc1e23eb-e456-7891-23c4-edf5678c9123) created a secret store named example-tf-ssh-ca
.Add Vault SSH CA in the CLI
To add a Vault SSH CA in the CLI instead of the Admin UI, use the sdm admin secretstores create CLI command. Create your “secret store” by choosing one the following secret store types and setting the correct options/properties.
vaultTLSCertSSH
corresponds to the HashiCorp Vault SSH CA type.vaultAppRoleCertSSH
corresponds to the HashiCorp Vault SSH (AppRole) CA type.vaultTokenCertSSH
corresponds to the HashiCorp Vault SSH (Token) CA type.
In the CLI, the options are the same as the Vault SSH CA properties set in the Admin UI.
CLI example
# Create HashiCorp Vault SSH (Token) CA
sdm admin secretstores create vaultTokenCertSSH
--name="Example SSH CA" --server-address="https://vault.example.com:1234"
--signing-role="example-ssh-signing-role"
--ssh-mount-point="example-ssh-mount-point"
--issued-cert-ttl-minutes="480"
# Create RDP (Certificate Based) server
sdm admin servers create ssh-cert
--name="Example SSH Vault"
--hostname="https://vault.example.com:1234"
--secret-store-id="se-e1b2"
--username="username"
# Run secret store healthcheck
sdm admin secretstores healthcheck se-e1b2
# Check that the secret store is reachable
sdm admin secretstores status
# Check the connection to the resource
sdm ssh "Example SSH Vault"
Add Vault SSH CA in Terraform
In addition to using the Admin UI and CLI, you may use Terraform to add a Vault CA for use with certificate-based SSH servers. This section includes a Terraform example.
For additional information, see our Terraform provider documentation.
Terraform example
# Install StrongDM provider
terraform {
required_providers {
sdm = {
source = "strongdm/sdm"
version = "7.1.1"
}
}
}
# Configure StrongDM provider
provider "sdm" {
# Add API access key and secret key from Admin UI
api_access_key = "njjSn...5hM"
api_secret_key = "ziG...="
}
variable "prefix" {
type = string
default = "example-tf-"
}
# Create Vault SSH CA
resource "sdm_secret_store" "example-tf-ssh-ca" {
vault_token_cert_ssh {
name = "${var.prefix}ssh-ca"
server_address = "https://vault.example.com:1234"
ssh_mount_point = "example-ssh-mount-point"
signing_role = "example-ssh-signing-role"
issued_cert_ttl_minutes = "480"
}
}
# Create SSH (Certificate Based) server
resource "sdm_resource" "demo-ssh-cert-based" {
ssh_cert {
name = "${var.prefix}ssh-vault-ca"
hostname = "https://vault.example.com:1234"
port=22
secret_store_id = sdm_secret_store.example-tf-ssh-ca.id
username = "ssh-username"
}
}
Add Vault SSH CA with the SDKs
To add a Vault CA with the StrongDM SDKs, please see the SDKs on GitHub: