forked from extern/ohmyzsh
dotenv: add never option to confirmation prompt (#9102)
This commit is contained in:
parent
7deaff71a2
commit
9cdc276496
@ -53,24 +53,30 @@ Set `ZSH_DOTENV_PROMPT=false` in your zshrc file if you don't want the confirmat
|
|||||||
You can also choose the `Always` option when prompted to always allow sourcing the .env file
|
You can also choose the `Always` option when prompted to always allow sourcing the .env file
|
||||||
in that directory. See the next section for more details.
|
in that directory. See the next section for more details.
|
||||||
|
|
||||||
### ZSH_DOTENV_ALLOWED_LIST
|
### ZSH_DOTENV_ALLOWED_LIST, ZSH_DOTENV_DISALLOWED_LIST
|
||||||
|
|
||||||
The default behavior of the plugin is to always ask whether to source a dotenv file. There's
|
The default behavior of the plugin is to always ask whether to source a dotenv file. There's
|
||||||
a **Y**es, **N**o, and **A**lways option. If you choose Always, the directory of the .env file
|
a **Y**es, **N**o, **A**lways and N**e**ver option. If you choose Always, the directory of the .env file
|
||||||
will be added to an allowed list. If a directory is found in this list, the plugin won't ask
|
will be added to an allowed list; if you choose Never, it will be added to a disallowed list.
|
||||||
for confirmation and will instead source the .env file directly.
|
If a directory is found in either of those lists, the plugin won't ask for confirmation and will
|
||||||
|
instead either source the .env file or proceed without action respectively.
|
||||||
|
|
||||||
This allowed list is saved by default in `$ZSH_CACHE_DIR/dotenv-allowed.list`. If you want
|
The allowed and disallowed lists are saved by default in `$ZSH_CACHE_DIR/dotenv-allowed.list` and
|
||||||
to change that location, change the `$ZSH_DOTENV_ALLOWED_LIST` variable, like so:
|
`$ZSH_CACHE_DIR/dotenv-disallowed.list` respectively. If you want to change that location,
|
||||||
|
change the `$ZSH_DOTENV_ALLOWED_LIST` and `$ZSH_DOTENV_DISALLOWED_LIST` variables, like so:
|
||||||
|
|
||||||
```zsh
|
```zsh
|
||||||
# in ~/.zshrc, before Oh My Zsh is sourced:
|
# in ~/.zshrc, before Oh My Zsh is sourced:
|
||||||
ZSH_DOTENV_ALLOWED_LIST=/path/to/dotenv/allowed/list
|
ZSH_DOTENV_ALLOWED_LIST=/path/to/dotenv/allowed/list
|
||||||
|
ZSH_DOTENV_DISALLOWED_LIST=/path/to/dotenv/disallowed/list
|
||||||
```
|
```
|
||||||
|
|
||||||
This file is just a list of directories allowed, separated by a newline character. If you want
|
The file is just a list of directories, separated by a newline character. If you want
|
||||||
to disallow a directory, just edit this file and remove the line for the directory you want to
|
to change your decision, just edit the file and remove the line for the directory you want to
|
||||||
disallow.
|
change.
|
||||||
|
|
||||||
|
NOTE: if a directory is found in both the allowed and disallowed lists, the disallowed list
|
||||||
|
takes preference, _i.e._ the .env file will never be sourced.
|
||||||
|
|
||||||
## Version Control
|
## Version Control
|
||||||
|
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
|
|
||||||
# Path to the file containing allowed paths
|
# Path to the file containing allowed paths
|
||||||
: ${ZSH_DOTENV_ALLOWED_LIST:="${ZSH_CACHE_DIR:-$ZSH/cache}/dotenv-allowed.list"}
|
: ${ZSH_DOTENV_ALLOWED_LIST:="${ZSH_CACHE_DIR:-$ZSH/cache}/dotenv-allowed.list"}
|
||||||
|
: ${ZSH_DOTENV_DISALLOWED_LIST:="${ZSH_CACHE_DIR:-$ZSH/cache}/dotenv-disallowed.list"}
|
||||||
|
|
||||||
|
|
||||||
## Functions
|
## Functions
|
||||||
@ -14,19 +15,26 @@ source_env() {
|
|||||||
if [[ "$ZSH_DOTENV_PROMPT" != false ]]; then
|
if [[ "$ZSH_DOTENV_PROMPT" != false ]]; then
|
||||||
local confirmation dirpath="${PWD:A}"
|
local confirmation dirpath="${PWD:A}"
|
||||||
|
|
||||||
# make sure there is an allowed file
|
# make sure there is an (dis-)allowed file
|
||||||
touch "$ZSH_DOTENV_ALLOWED_LIST"
|
touch "$ZSH_DOTENV_ALLOWED_LIST"
|
||||||
|
touch "$ZSH_DOTENV_DISALLOWED_LIST"
|
||||||
|
|
||||||
|
# early return if disallowed
|
||||||
|
if grep -q "$dirpath" "$ZSH_DOTENV_DISALLOWED_LIST" &>/dev/null; then
|
||||||
|
return;
|
||||||
|
fi
|
||||||
|
|
||||||
# check if current directory's .env file is allowed or ask for confirmation
|
# check if current directory's .env file is allowed or ask for confirmation
|
||||||
if ! grep -q "$dirpath" "$ZSH_DOTENV_ALLOWED_LIST" &>/dev/null; then
|
if ! grep -q "$dirpath" "$ZSH_DOTENV_ALLOWED_LIST" &>/dev/null; then
|
||||||
# print same-line prompt and output newline character if necessary
|
# print same-line prompt and output newline character if necessary
|
||||||
echo -n "dotenv: found '$ZSH_DOTENV_FILE' file. Source it? ([Y]es/[n]o/[a]lways) "
|
echo -n "dotenv: found '$ZSH_DOTENV_FILE' file. Source it? ([Y]es/[n]o/[a]lways/n[e]ver) "
|
||||||
read -k 1 confirmation; [[ "$confirmation" != $'\n' ]] && echo
|
read -k 1 confirmation; [[ "$confirmation" != $'\n' ]] && echo
|
||||||
|
|
||||||
# check input
|
# check input
|
||||||
case "$confirmation" in
|
case "$confirmation" in
|
||||||
[nN]) return ;;
|
[nN]) return ;;
|
||||||
[aA]) echo "$dirpath" >> "$ZSH_DOTENV_ALLOWED_LIST" ;;
|
[aA]) echo "$dirpath" >> "$ZSH_DOTENV_ALLOWED_LIST" ;;
|
||||||
|
[eE]) echo "$dirpath" >> "$ZSH_DOTENV_DISALLOWED_LIST"; return ;;
|
||||||
*) ;; # interpret anything else as a yes
|
*) ;; # interpret anything else as a yes
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
Loading…
Reference in New Issue
Block a user