Secrets Management
Configure external secrets storage for sensitive data
Archestra stores sensitive data like API keys, OAuth tokens, and MCP server credentials as secrets. By default, secrets are encrypted at rest in the database. Optionally, you can configure external secrets storage with HashiCorp Vault.
Note: Existing secrets are not migrated when you enable external storage. Recreate secrets after changing the secrets manager.
Database Storage
Secrets are stored in the database by default. To explicitly configure database storage, set ARCHESTRA_SECRETS_MANAGER to DB.
When secrets are stored in the database, they are automatically encrypted at rest using AES-256-GCM. The encryption key is derived from your ARCHESTRA_AUTH_SECRET environment variable.
- Encryption and decryption are fully transparent — no configuration is needed beyond setting
ARCHESTRA_AUTH_SECRET. - Existing plaintext secrets are automatically migrated to encrypted format on startup.
Warning: Do not change
ARCHESTRA_AUTH_SECRETafter deployment. Rotating this secret will invalidate all user sessions (forcing re-login), make existing encrypted secrets unreadable, break JWT signing (JWKS private keys are encrypted with this secret), and break two-factor authentication for enrolled users.
See ARCHESTRA_AUTH_SECRET for more info.
HashiCorp Vault
Enterprise feature: Contact sales@archestra.ai for licensing information.
In this mode, secret values are stored in Vault instead of the database. Archestra reads, writes, and deletes them in Vault; only references to the secret paths stay in the database.
To enable Vault, set ARCHESTRA_SECRETS_MANAGER to VAULT and configure the address and authentication method.
| Variable | Required | Value |
|---|---|---|
ARCHESTRA_SECRETS_MANAGER | Yes | VAULT |
ARCHESTRA_HASHICORP_VAULT_ADDR | Yes | Your Vault server address |
ARCHESTRA_ENTERPRISE_LICENSE_ACTIVATED | Yes | Your license value |
ARCHESTRA_HASHICORP_VAULT_AUTH_METHOD | No | TOKEN (default), K8S, or AWS |
ARCHESTRA_HASHICORP_VAULT_KV_VERSION | No | KV secrets engine version, 1 or 2 (default: 2) |
ARCHESTRA_HASHICORP_VAULT_SECRET_PATH | No | Path prefix to store secrets under (see Secret Storage Paths) |
ARCHESTRA_HASHICORP_VAULT_SECRET_METADATA_PATH | No | Override path prefix for KV v2 metadata operations (see Secret Storage Paths) |
Required next step: Set the credentials for your chosen auth method — see Vault Authentication.
Note: If
ARCHESTRA_SECRETS_MANAGERis set toVAULTbut the required environment variables are missing, the system falls back to database storage.
Secret Storage Paths
Vault paths are built as {prefix}/{secretName} — a secret named github_token is written to {prefix}/github_token. ARCHESTRA_HASHICORP_VAULT_SECRET_PATH sets the prefix; its default depends on the configured KV engine version.
| KV version | Default prefix | Resolved path |
|---|---|---|
2 | secret/data/archestra | secret/data/archestra/{secretName} |
1 | secret/archestra | secret/archestra/{secretName} |
For KV v2, list and delete operations use a metadata path derived from ARCHESTRA_HASHICORP_VAULT_SECRET_PATH by swapping /data/ for /metadata/ (e.g., kv/data/platform/archestra → kv/metadata/platform/archestra). Only set ARCHESTRA_HASHICORP_VAULT_SECRET_METADATA_PATH when your metadata prefix doesn't follow this /data/ ↔ /metadata/ convention.
Vault Authentication
Archestra supports three authentication methods for connecting to HashiCorp Vault.
Token Authentication
| Variable | Required | Description |
|---|---|---|
ARCHESTRA_HASHICORP_VAULT_TOKEN | Yes | Vault authentication token |
Kubernetes Authentication
| Variable | Required | Description |
|---|---|---|
ARCHESTRA_HASHICORP_VAULT_K8S_ROLE | Yes | Vault role bound to the Kubernetes service account |
ARCHESTRA_HASHICORP_VAULT_K8S_TOKEN_PATH | No | Path to SA token (default: /var/run/secrets/kubernetes.io/serviceaccount/token) |
ARCHESTRA_HASHICORP_VAULT_K8S_MOUNT_POINT | No | Vault K8S auth mount point (default: kubernetes) |
The K8S auth method requires a Vault role configured with a bound service account.
AWS IAM Authentication
| Variable | Required | Description |
|---|---|---|
ARCHESTRA_HASHICORP_VAULT_AWS_ROLE | Yes | Vault role bound to the AWS IAM principal |
ARCHESTRA_HASHICORP_VAULT_AWS_MOUNT_POINT | No | Vault AWS auth mount point (default: aws) |
ARCHESTRA_HASHICORP_VAULT_AWS_REGION | No | AWS region for STS signing (default: us-east-1) |
ARCHESTRA_HASHICORP_VAULT_AWS_STS_ENDPOINT | No | STS endpoint URL (default: https://sts.amazonaws.com) |
ARCHESTRA_HASHICORP_VAULT_AWS_IAM_SERVER_ID | No | Value for X-Vault-AWS-IAM-Server-ID header (additional security) |
