Doppler
Integrate with Doppler to retrieve secrets from your Doppler projects and configs.
Quick Start
bash
# 1. Install Doppler CLI
brew install dopplerhq/cli/doppler
# 2. Login to Doppler
doppler login
# 3. Configure Doppler provider
cat >> fnox.toml << 'EOF'
[providers]
doppler = { type = "doppler", project = "my-project", config = "prd" }
[secrets]
DATABASE_URL = { provider = "doppler", value = "DATABASE_URL" }
EOF
# 4. Use it
fnox get DATABASE_URLPrerequisites
Installation
bash
# macOS
brew install dopplerhq/cli/doppler
# Linux
curl -sLf --retry 3 --tlsv1.2 --proto "=https" 'https://packages.doppler.com/public/cli/gpg.DE2A7741A397C129.key' | sudo gpg --dearmor -o /usr/share/keyrings/doppler-archive-keyring.gpg
echo "deb [signed-by=/usr/share/keyrings/doppler-archive-keyring.gpg] https://packages.doppler.com/public/cli/deb/debian any-version main" | sudo tee /etc/apt/sources.list.d/doppler-cli.list
sudo apt-get update && sudo apt-get install -y doppler
# Or install via mise
mise use -g "github:DopplerHQ/cli"Setup
1. Login to Doppler
bash
doppler login2. Authentication
Option A: Interactive Login (Local Development)
bash
doppler loginOption B: Service Token (CI/CD)
Create a service token in the Doppler dashboard scoped to a specific project and config:
bash
export DOPPLER_TOKEN="dp.st.prd.xxxx"3. Configure Doppler Provider
toml
[providers]
doppler = { type = "doppler", project = "my-project", config = "prd" }Configuration Options:
All fields are optional. If not specified, the Doppler CLI will use its own defaults (from doppler setup or environment variables):
project- Doppler project name. If omitted, uses the project configured viadoppler setup.config- Doppler config (environment) name (e.g., "dev", "stg", "prd"). If omitted, uses the config configured viadoppler setup.token- Service token for authentication. If omitted, usesDOPPLER_TOKENorFNOX_DOPPLER_TOKENenvironment variable, or interactive login session.
Referencing Secrets
toml
[secrets]
DATABASE_URL = { provider = "doppler", value = "DATABASE_URL" }
API_KEY = { provider = "doppler", value = "API_KEY" }The value is the secret key name in Doppler. The provider configuration determines the project and config scope.
Usage
bash
# Get a single secret
fnox get DATABASE_URL
# Run commands with secrets injected
fnox exec -- npm startMulti-Environment Example
Use named provider instances to pull secrets from different Doppler projects or configs:
toml
[providers]
app-prod = { type = "doppler", project = "my-app", config = "prd" }
app-dev = { type = "doppler", project = "my-app", config = "dev" }
infra = { type = "doppler", project = "infra", config = "prd" }
[secrets]
PROD_DB_URL = { provider = "app-prod", value = "DATABASE_URL" }
DEV_DB_URL = { provider = "app-dev", value = "DATABASE_URL" }
AWS_KEY = { provider = "infra", value = "AWS_ACCESS_KEY_ID" }Or use fnox profiles:
toml
[providers]
doppler = { type = "doppler", project = "my-app", config = "dev" }
[secrets]
DATABASE_URL = { provider = "doppler", value = "DATABASE_URL" }
[profiles.staging.providers]
doppler = { type = "doppler", project = "my-app", config = "stg" }
[profiles.production.providers]
doppler = { type = "doppler", project = "my-app", config = "prd" }Usage:
bash
# Development (default)
fnox exec -- npm start
# Staging
fnox exec --profile staging -- npm start
# Production
fnox exec --profile production -- ./deploy.shCI/CD Example
GitHub Actions
yaml
name: Deploy
on: [push]
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: jdx/mise-action@v3
- name: Deploy
env:
DOPPLER_TOKEN: ${{ secrets.DOPPLER_TOKEN }}
run: |
fnox exec -- ./deploy.shSetup:
- Create a service token in the Doppler dashboard for the target project/config
- Add the token to GitHub Secrets as
DOPPLER_TOKEN
Token Management
Environment Variables
fnox checks for tokens in this order:
- Provider config
tokenfield FNOX_DOPPLER_TOKENenvironment variableDOPPLER_TOKENenvironment variable- Interactive login session (from
doppler login)
Bootstrap Pattern
Store the Doppler token encrypted for easy bootstrap:
bash
# Store token encrypted with age
fnox set DOPPLER_TOKEN "dp.st.prd.xxxx" --provider age
# Bootstrap from fnox
export DOPPLER_TOKEN=$(fnox get DOPPLER_TOKEN)
fnox exec -- npm startPros
- ✅ Developer-friendly dashboard and CLI
- ✅ Simple project/config/environment model
- ✅ Automatic secret syncing across environments
- ✅ Good integrations (GitHub, Vercel, AWS, etc.)
- ✅ Secret referencing and inheritance between configs
- ✅ Audit logs and access controls
- ✅ Free tier available
Cons
- ❌ Requires network access (cloud-only, no self-hosted option)
- ❌ No open source option
Troubleshooting
"Unauthorized" or "Invalid service token"
bash
# Re-login interactively
doppler login
# Or check your service token
echo $DOPPLER_TOKEN"Could not find project" or "Could not find config"
Verify your project and config exist:
bash
doppler projects
doppler configs --project my-project"Secret not found"
Check the secret exists in the correct project/config:
bash
doppler secrets --project my-project --config prdNext Steps
- Infisical - Alternative cloud secrets manager
- HashiCorp Vault - Self-hosted alternative
- Real-World Example - Complete setup