Skip to content

dmno-dev/varlock

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

239 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Varlock banner


npm package license node compatibility build status discord chat


Varlock

add declarative schema to your .env files using @env-spec decorator comments

  • πŸ›‘οΈ validation, coercion, type safety w/ IntelliSense
  • πŸ” protection for sensitive config values (log redaction, leak prevention)
  • 🌐 flexible multi-environment management - auto .env.* loading and explicit import
  • πŸ’« flexible composition and toggling using functions() and $references
  • πŸ”Œ plugin system for secure secret loading from various sources

Unlike .env.example, your .env.schema is a single source of truth, built for collaboration, that will never be out of sync.

# @defaultSensitive=false @defaultRequired=infer @currentEnv=$APP_ENV
# ---
# our environment flag, will control automatic loading of `.env.xxx` files
# @type=enum(development, preview, production, test
APP_ENV=development # default value, can override

# @type=port
API_PORT=8080 # non-sensitive values can be set directly

# API url including _expansion_ referencing another env var
# @type=url
API_URL=http://localhost:${API_PORT}

# sensitive api key, with extra validation
# @required @sensitive @type=string(startsWith=sk-)
OPENAI_API_KEY=

Flexible plugin system: adds new decorators, functions, types - enables secure declarative secret loading.

# @plugin(@varlock/1password-plugin)
# @initOp(token=$OP_TOKEN, allowAppAuth=forEnv(dev), account=acmeco)
# ---

# @type=opServiceAccountToken @sensitive
OP_TOKEN=

# Fetch secrets using 1Password secret references
DB_PASS=op(op://my-vault/database-password/password)
API_KEY=op(op://api-vault/stripe/api-key)

Installation

You can get started with varlock by installing the CLI:

# Run the installation wizard, which will install as a dependency in a JavaScript project
npx varlock init

# Or install as standalone binary
brew install dmno-dev/tap/varlock # via homebrew
curl -sSfL https://varlock.dev/install.sh | sh -s # via cURL

# Or use the official Docker image
docker pull ghcr.io/dmno-dev/varlock:latest

See the full installation docs or the Docker guide for more information.

Workflow

Validate your .env.schema and pretty print your environment variables with:

varlock load

If you need to pass resolved env vars into another process, you can run:

varlock run -- python script.py

In many cases you can use our drop-in integrations for seamless experience - with additional security guardrails, like log redaction and leak prevention.

@env-spec

Varlock is built on top of @env-spec, a new DSL for attaching a schema and additional functionality to .env files using JSDoc style comments. The @env-spec package contains a parser and info about the spec itself.

Published Packages

Core

Package Published listing page
varlock npm version
@env-spec/parser npm version
@env-spec VSCode extension VSCode Marketplace, Open VSX Registry
varlock Docker image GitHub Container Registry

Plugins

Package Published listing page
@varlock/1password-plugin npm version
@varlock/aws-secrets-plugin npm version
@varlock/azure-key-vault-plugin npm version
@varlock/bitwarden-plugin npm version
@varlock/google-secret-manager-plugin npm version
@varlock/infisical-plugin npm version

Framework Integrations

Package Published listing page
@varlock/astro-integration npm version
@varlock/nextjs-integration npm version
@varlock/vite-integration npm version

MCP Servers

MCP Server Link URL
Varlock Docs (HTTP) Installation https://docs.mcp.varlock.dev/mcp
Varlock Docs (SSE) Installation https://docs.mcp.varlock.dev/sse

Examples

Examples of integrating varlock in various frameworks and situations can be found in the Varlock examples repo

Development & Contribution

See CONTRIBUTING.md for more information.