Environment variables
Learn how to configure environment variables.
Environment variables are defined in the .env
file in the root of the repository and in the root of the apps/extension
package.
- Shared environment variables: Defined in the root
.env
file. These are shared between environments (e.g., development, staging, production) and apps (e.g., web, extension). - Environment-specific variables: Defined in
.env.development
and.env.production
files. These are specific to the development and production environments. - App-specific variables: Defined in the app-specific directory (e.g.,
apps/extension
). These are specific to the app and are not shared between apps. - Bundle-specific variables: Specific to the bundle target (e.g.
.env.safari
,.env.firefox
) or bundle tag (e.g..env.testing
) - Build environment variables: Not stored in the
.env
file. Instead, they are stored in the environment variables of the CI/CD system. - Secret keys: They're not stored on the extension side, instead they're defined on the web side.
Shared variables
Here you can add all the environment variables that are shared across all the apps.
To override these variables in a specific environment, please add them to the specific environment file (e.g. .env.development
, .env.production
).
App-specific variables
Here you can add all the environment variables that are specific to the app (e.g. apps/extension
).
You can also override the shared variables defined in the root .env
file.
VITE_ prefix
To make environment variables available in the browser extension code, you need to prefix them with VITE_
. They will be injected to the code during the build process.
Only environment variables prefixed with VITE_
will be injected.
Bundle-specific variables
WXT also provides environment variables specific to a certain build target or build tag when creating the final bundle. Given the following build command:
The following env files will be considered, ordered by priority:
.env.firefox
.env.testing
.env
You shouldn't worry much about this, as TurboStarter comes with already configured build processes for all the major browsers.
Build environment variables
To allow your extension to build properly on CI you need to define your environment variables on your CI/CD system (e.g. Github Actions).
TurboStarter comes with predefined Github Actions workflow used to build and submit your extension to the stores. It's located in .github/workflows/publish-extension.yml
file.
To correctly set up the build environment variables, you need to define them under env
section and then add them as a secrets to your repository.
We'll go through the whole process of building and publishing the extension in the publishing guide.
Secret keys
Secret keys and sensitive information are to be never stored on the extension app code.
What does this mean?
It means that you will need to add the secret keys to the web app, where the API is deployed.
The browser extension should only communicate with the backend API, which is typically part of the web app. The web app is responsible for handling sensitive operations and storing secret keys securely.
See web documentation for more details.
This is not a TurboStarter-specific requirement, but a best practice for security for any application. Ultimately, it's your choice.
Last updated on