So I have the simplest example on a node machine running with a react-redux app with webpack (Though I don't think any of this matters for the issue expect it being on nodejs).
Specific calls get a value pack:
console.log(process.env.NODE_ENV); // output: 'development'
General calls get nothing back:
console.log(process.env); // output: {}
What am I missing here?
Addition info the might be relevant:
dotenv
for the test
environment.dotenv-webpack
for the development environment.production
environment deployed to Herokuenv variable being empty in browser is because browser doesn't have real access to the process of the node. js . It's run inside the browser though.
The process.env property is an inbuilt application programming interface of the process module which is used to get the user environment. Syntax: process.env. Return Value: This property returns an object containing the user environment.
No, you can't store objects in process. env because it stores environment variables like PATH, SHELL, TMPDIR and others, which are represented by String values.
The issue with process.env
variable being empty in browser is because browser doesn't have real access to the process
of the node.js
. It's run inside the browser though.
Usage of process.env.ANYTHING
is usually achieved by plugins like https://webpack.js.org/plugins/define-plugin/ which just simply replace
any occurrence of process.env.ANYTINHG
with env variable during BUILD time. It really does just simple str.replace(/process.env.ANYTING/value/)
this needs to be done during build time as once you output dist bundle.js
you don't have access to the ENV
variables.
Therefore you need to be sure that when you are producing production build e.g with yarn build
you are using webpack.DefinePlugin
and replacing those process.env
calls with current ENV values. They can't be injected in runtime.
When you need to access env variables in runtime it's basically impossible in JavaScript in browser. There are some sort of hacks for example for NGINX which can serialize current env variables to the window.ENV
variable and in your app you will not use process.env
but window.ENV
. So you need to either have ENV variables available while you are building the application or build mechanism which will dynamically output current ENV as json to window and access with react. If you are using docker
it can be done with ENTRYPOINT
otherwise you need some bash script which will always output current ENV variables as JSON
to the index.html
of your app
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With