-
-
Notifications
You must be signed in to change notification settings - Fork 634
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
References to variables which are not set are left expanded #468
Comments
This seems to be the intended behaviour, and we even have tests for it.
I even back-ported these test to the 2.3 branch, locally, to see if the passed there too, and they do, so it seems this has always been the behaviour. I think if we want to change this behaviour, we need to consider it to be breaking a change, and not a bug fix, and thus be making the change for the next major release. |
NB Neither we, nor the Python dotenv package claim to have parity with the bash implementation. We both are just "similar". |
Thanks for the quick response, @GrahamCampbell. I was initially looking for confirmation that this was either a bug or the intended behavior. I can't really think of any use case where the current behavior would be desired or useful, but I definitely understand the desire for backwards compatibility and avoiding breaking changes. Another route would be an optional argument that controls the expansion behavior ("POSIX mode" one might call it). There are other constructs that the shell language supports, too. I'm just a user of an open source project facing this limitation due to that project's use of Laravel and it's implementation of Docker image. (See referenced issue.) I'm attempting to work around this using (set -a; source .env; envsubst < .env > .envnew && mv .envnew .env) It took a fair amount of effort to track this down (through Snipe-it, through Laravel, finally to phpdotenv) and realize it was the intended behavior. Perhaps the simplest solution here would be just a README change clarifying the behavior when expanding variables? |
I am not averse to changing the behaviour in the next major version, but just need to be sure there won't be any other unintended side effects. One thing that immediately comes to mind is the nested processing of interpolation. |
I think, possibly the original reason for this behaviour was because there was no way to write a literal dollar, say, as part of a password, without it being processed as a variable, however, we now have single quote syntax for dealing with this. |
Note: Typing from mobile Ok lets imagine we agreed on empty string approach. now how we handle such things ? APP_ENV=‘${SOME_VARIABLE}-app’ APP_ENV=“SOME_VARIABLE-app” how to identify and replace it with empty string ? |
I'll just throw this here, in case it raises any interest.
A default empty string would then be |
Summary
If
.env
references a variable (e.g.${FOO}
) which is not already set (either via the external environment, or in the.env
file, it is left unexpanded.This is in contrast to the following other languages / implementations which will expand the variable to an empty string:
source
)Demo
Consider this
.env
file:When loaded by bash,
EXT_UNSET
will get the value""
(that is, the empty string).When loaded by
phpdotenv v5.2.0
,EXT_UNSET
will get the value"${ENV_EXT_UNSET}"
(literally).See this gist for a full reproducible example:
References
The text was updated successfully, but these errors were encountered: