- Understand how to create custom targets via the "run-commands" workspace executor
- Explore real-world usages of "run-commands" by creating a frontend "deploy" executor
- Learn how to expose custom ENV variables to Nx
-
Make sure you are on the
master
branch -
We'll use a CLI tool called Surge to statically deploy the frontend:
```bash yarn add surge # or npm i -S surge ```
-
Get the surge token (you'll need to create an account with an email and password):
``` npx surge token ``` ☝️ Copy the token you get
-
Let's use the Surge CLI to deploy our project:
```bash
nx build store
npx surge dist/apps/store https://.surge.sh --token
⚠️ Make sure you chose a **unique value** for your domain above, otherwise it will fail as you won't have permission to deploy to an existing one. ⚠️ You should see surge deploying to your URL - if you click you'll see just the header though, because it doesn't have a server yet to get the games from. <br />
-
Let's now abstract away the above command into an Nx target. Generate a new "deploy" target using the
@nx/workspace:run-commands
generator:- under the
store
project - the "command" will be the same as the one you typed in the previous step
🐳 Hint
Consult the run-commands generator docs here
- under the
-
Use Git to inspect the changes in
project.json
and try to deploy the store using Nx! -
We're now storing the surge token in
project.json
. We don't want to check-in this file and risk exposing this secret token. Also, we might want to deploy to different domains depending on the environment. Let's move these out:📁 Create a new file
apps/store/.local.env
🔒 And let's add your secrets to it
SURGE_TOKEN=<your-surge-token> SURGE_DOMAIN_STORE=https://<some-unique-url-123>.surge.sh
✅ Finally, update your "deploy" command, so that it loads the values from the ENV, using the
${ENV_VAR}
syntax.🐳 Hint
surge dist/apps/store ${SURGE_DOMAIN_STORE} --token ${SURGE_TOKEN}
-
Now invoke the deploy target again, and check if it all still works.
⚠️ Note for Windows users: the command might fail, as we're trying to access env variables the Linux-way. To make it pass, you can generate a separatewindows-deploy
executor (make sure you keep the existingdeploy
target intact - it will be used by GitHub Actions):```bash nx generate run-commands windows-deploy --project=store --command="surge dist/apps/store %SURGE_DOMAIN_STORE% --token %SURGE_TOKEN%" nx windows-deploy store ```
❓ We did not load those environment variables into the deploy process anywhere.
We just added a .local.env
file. How does that work?
Nx automatically picks up any .env
or .local.env
files in your workspace,
and loads them into processes invoked for that specific app.
🎓 If you get stuck, check out the solution
➡️ For the Next task, head over to our chapter list to chose your path ➡️