Skip to content

Latest commit

 

History

History
59 lines (35 loc) · 2.17 KB

README.md

File metadata and controls

59 lines (35 loc) · 2.17 KB

wangler

Evil wrangler. A place for experiments by Sunil. Use at your own caution.

A wrapper around wrangler. For the lolz.

As of now, this adds just one feature: it automatically loads environment variables from .env files and populates process.env in your Cloudflare Workers.

Why

This is a feature that wrangler will eventually ship, but I wanted it now for my own stuff.

Installation

npm install wangler wrangler

Usage

  1. Create a .env file in your project root:
API_KEY=your-api-key
DATABASE_URL=your-database-url
  1. Use the wangler command instead of wrangler:
npx wangler dev # or wangler deploy
  1. Reference process.env/import.meta.env in your code:
console.log(process.env.API_KEY); // your-api-key
console.log(import.meta.env.DATABASE_URL); // your-database-url

Additional features:

  • These values are also injected into a request handler's env object.

  • You can pass a path to a custom .env file via --env-file <path>.

  • You can also have environment specific .env files. For example, you can have a .env.dev file for development and a .env.prod file for production. To use, pass --env <env> where <env> is the name of the environment you want to use. (This works with wrangler's own --env flag, where it'll pick bindings and values defined under [env.<env>] in wrangler.toml)

  • You can pass values in the cli via --penv <key>:<value>. This is useful for passing in arguments defined in your actual environment (like in CI, you can do npx wangler dev --penv DATABASE_URL:$SUPABASE_URL to pass in a value for DATABASE_URL).

  • You can pass values in the cli via --penv <key> to have the value be read from the environment. This is useful for passing in arguments defined in your actual environment (like in CI, you can do npx wangler dev --penv DATABASE_URL to have the value for process.env.DATABASE_URL be read from the environment).

How it works

This tool wraps the standard Wrangler CLI and automatically converts your .env file variables into --define arguments that Wrangler understands. It's a drop-in replacement for Wrangler that adds .env file support.

License

MIT