Skip to content

Commit

Permalink
docs: Add mermaid diagrams explaining .env file setup (#3994)
Browse files Browse the repository at this point in the history
  • Loading branch information
DafyddLlyr authored Nov 21, 2024
1 parent 1784294 commit 5c87e30
Showing 1 changed file with 50 additions and 1 deletion.
51 changes: 50 additions & 1 deletion doc/how-to/how-to-add-a-secret.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ This guide will demonstrate how to -
2. Add to your local `.env` file for local development
- Note: This file is never checked into our public repository and is listed in our `.gitignore` config
3. Document the secret in `.env.example`
4. If a secret is required for a unit test, add dummy values to corresponding `.env.test` files e.g `YOUR_NEW_SECRET=test`

### Docker Environments (Local development + Pizza environments)
To pass a secret into our Docker Compose setup you will need to map it into the relevant container in `docker-compose.yml`. For example -
Expand All @@ -35,6 +36,39 @@ When building Pizza environments for testing, GitHub actions access secrets via
> Please be aware that if you are rotating secrets this may affect existing Pizzas which will need to be rebuilt. This can be done manually in GitHub by re-running the latest action associated with affected PRs.


## Diagram - Docker environments
```mermaid
flowchart LR
subgraph "Local Environment"
localEnv[".env file(s)"] --> Docker["Docker Compose"]
Docker --> API
Docker --> Hasura
Docker --> Frontend
end
subgraph Staging AWS S3 bucket
S3
end
subgraph GitHub actions
pizzaEnv[".env file"]
end
subgraph "Pizza Environment"
pizzaEnv[".env file"] --> PizzaDocker["Docker Compose"]
PizzaDocker --> PizzaAPI["API"]
PizzaDocker --> PizzaHasura["Hasura"]
PizzaDocker --> PizzaFrontend["Frontend"]
end
%% Scripts reading and writing
S3 --"Pull/Push scripts"--> localEnv
%% CI
S3 --> pizzaEnv
```


### AWS / Pulumi Environments (Staging + Production environments)
Secrets for Staging and Production environment are not handled in `.env` files, and are set directly in Pulumi, our Infrastruture as Code (IaC) platform.

Expand Down Expand Up @@ -68,4 +102,19 @@ const apiService = new awsx.ecs.FargateService("api", {
});
```

> Pulumi uses our Docker images to construct Fargate services. This means that the "name" value above must match that used in Docker.
> Pulumi uses our Docker images to construct Fargate services. This means that the "name" value above must match that used in Docker.

## Diagram - AWS / Pulumi Environments
```mermaid
flowchart LR
subgraph "Staging & Production"
direction LR
PulumiService["Pulumi Service"] --"Private key"--> Pulumi
PulumiFile["pulumi.staging.yaml"] --"Public key"--> Pulumi
Pulumi["Pulumi IaC code"] --Decrypted--> Fargate
Fargate --> FargateAPI["API"]
Fargate --> FargateHasura["Hasura"]
Fargate --> FargateFrontend["Frontend"]
end
```

0 comments on commit 5c87e30

Please sign in to comment.