#environment #dotenv #cli

app envy-cli

A magical little tool that takes care of your environment settings

3 releases (breaking)

✓ Uses Rust 2018 edition

0.3.0 Aug 22, 2019
0.2.0 Aug 13, 2019
0.1.0 Mar 9, 2019

#31 in Configuration

Apache-2.0/MIT

14KB
165 lines

envy

...sets environment variables when you enter a directory that matches a regular expression.

Example

At work, I have to set some environment variables every time I'm working on certain projects.
For example, these can be Google Cloud settings, the Consul host or Docker configs.

It's tedious to do that myself every time.

direnv automatically loads .env files, but I don't want to clutter my system
with .env files. Also I need the same environment variables in a few unrelated
projects and I don't want to keep the .env files in sync.

Thus, the idea for envy was born.

It uses a config file that defines what environment variables to set for each folder. The first regular expression that matches a path wins.

Run envy edit to open the config file. (On macOS, this file is located at /Users/<user>/Library/Application Support/Envy/Config.toml.)

[[paths]]
pattern = ".*project1.*"
env = [
  "CONSUL_HTTP_ADDR=http://consul:8500"
]

[[paths]]
pattern = ".*project2.*"
env = [
  "DOCKER_HOST=tcp://127.0.0.1:2376",
  "foo=bar"
]

Installation

cargo install envy-cli

Add the following line at the end of the ~/.zshrc file:

eval "$(envy hook zsh)"

Once you open a new shell, envy will start matching directories and set the specified environment variables from the config file.

Limitations

  • Only supports zsh for now.
  • Only tested on macOS. Should also work on Linux and Windows, though.
  • Does not unset variables when you leave a directory.
  • Developing this for myself. Thus, this project won't be worked on very actively.

Dependencies

~5MB
~109K SLoC