Skip to main content

HashiCorp Vault

Connect to your HashiCorp Vault to securely access application secrets, API keys, and sensitive data from anywhere in Superblocks. This guide covers:

Prerequisites

To set up HashiCorp Vault as a secret store for Superblocks you'll need:

  • An on-premise deployment of HashiCorp OR a HashiCorp account with Vault configured
  • Permission to manage HashiCorp Services, access to manage HashiCorp Vault cluster, and ability to create and configure Secrets engines
  • Admin permission for your Superblocks organization

Set up

Create Secrets Engine with secrets key-value pair

To set up a key-value secrets engine in HashiCorp Vault:

  1. Navigate to your Vault Cluster
  2. Launch the Vault Web UI
  3. In the Vault Web UI, navigate to Secrets Engine
  4. Proceed to create a new secrets engine
  5. Choose KV Version. Opt for either version 1 or 2 of the Key-Value (KV) secrets engine, based on your requirements
  6. Add your secrets as key-value pairs
  7. Customize the path and configure access to your secrets as needed

Configure secret store

Finally, configure a new secret store in Superblocks:

  1. Go to the Secrets Management page in Superblocks
  2. Click the HashiCorp Vault tile
  3. Name your secret store
  4. Paste or enter in the info for Address, Namespace, Path, Version, Auth Type, and Token configurations that were set in your Secrets engine
Address

The Address is your cluster's public URL. It is located on the Vault Cluster page when you select your Vault.

Namespace

The Namespace is used for creating service accounts and managing who can access what. The default value is admin. It is optional and configured on the secrets engine.

Path

The Path tells Vault which secrets engine it should route requests to. It is configured in the Key Value secrets engine.

Version

The Version is which version of Key Value secrets engine to use (either v1 or v2 currently). It is configured in the Key Value secrets engine.

Auth Type

The Auth Type specifies which Auth flavor to use for connecting to HashiCorp Vault. The default configuration is Token. App Role is also available which requires a Role ID and Secrets ID.

Token

The Token is used to authenticate requests for secrets. It is located on the Vault Cluster page when you select your Vault.

  1. Configure caching rules for this store
  2. Optionally, add more configurations for different environments
  3. Click Create
tip

Your secret store is now configured. Use it in backend APIs and integration's to reference your secrets.

Using secrets

After configuring your secret store, reference secrets using the {{sb_secrets}} object. Secrets are accessed from their respective stores using the syntax {{sb_secrets.STORE_NAME.SECRET_NAME}}.

Secrets are available to reference in Backend APIs and Integrations. Note that for security purposes, secrets cannot be referenced in Frontend JS or Components.

Secrets are fetched at runtime from a particular store based on the API's current Profile.

info

If your secret is stored as a JSON object in key:value form, use the JavaScript JSON.parse() function to reference the secret value inside integration forms: {{JSON.parse(sb_secrets.STORE_NAME.SECRET_NAME).SECRET_KEY}}



If your secret includes spaces or special characters, use array notation instead of dot notation to access the secret: {{sb_secrets.STORE_NAME['SECRET_NAME']}}

Caching

If enabled, Superblocks can cache your secrets, reducing calls to your secrets manager and improving API performance when using secrets. Caching can be configured for each of your secret store's configurations, letting you set different policies based on the environment.

To configure caches, go to Secrets Management and click into your secrets store. From here you can:

  • Update the Cache TTL (seconds) to your desired caching interval
  • Clear the cache if you've rotated a secrets and need Superblocks to refetch secret values

Manage secret caching

info

If you're running the On-Premise Agent, secrets are cached in-memory by your agent. For scaled deployments, you'll need to clear each instance's cache individually when rotating secrets.



To rotate secrets more easily, disable caching first. Then, after updating the secret, re-enable caching.

Auth Token Renewal

When using the token auth type for accessing the configured secret store, if the configured token is renewable, it will be renewed every time the secret store is accessed.

For the token to be renewed it must:

  • Be renewable (i.e. the “renewable” attribute is true)
  • Have permissions to renew itself
  • Not be expired

If the preceding conditions are met, the token will be renewed to the TTL that was set when the token was initially created (e.g. if the token was created with a TTL of 1 hour, each renewal will reset the TTL to 1 hour). The token will be renewed every time the secret store is accessed e.g. when an API executes that references the secret store.

info

Note: If the access token has a max TTL set on it, the renewed TTL will be capped so that the token's total lifetime never exceeds the max TTL.



E.g. Given a token with an initial TTL of 4 minutes and a max TTL of 5 minutes, if the token is renewed after 3 minutes (1 minute remaining), the TTL will be reset to 2 minutes (not 4 minutes)

Since the token will only be renewed when accessed, if token renewal is desired, it is suggested that you add a scheduled job that runs at a cadence more frequent than the token TTL (e.g. every original TTL / 2), and access the secret store in the job.

Manage secret caching

A scheduled job with a single JavaScript step, containing the following code, can be used to ensure the secret store is always accessed within the TTL of the access token.

// Load vault secrets to force a token renewal
const loadedSecrets = sb_secrets.STORE_NAME;
if (loadedSecrets === null || loadedSecrets === undefined) {
throw Error("Failed to load secrets");
}

return true;