Webapp.io
This guide will show you how to use Doppler to provide secrets to CI jobs in Webapp.io.
Prerequisites
- You have created a project in Doppler
- You have a Webapp.io project and have access to set Webapp.io Secrets
Webapp.io Environment
As Webapp.io doesn't exactly fit into Development, Staging, or Production, we'll create a custom environment. Head to the Project page, then click Options. Now click Create Environment.
data:image/s3,"s3://crabby-images/01af0/01af0ae044de20d17af080f0dffde6887988e34d" alt="01-options.png 2000"
Give the environment a name, e.g. Webapp.io and a short name, then click Save.
data:image/s3,"s3://crabby-images/67143/671437a4621db8d0ddc9e9588b30ae7687f9b6b0" alt="02-create-environment.png 2000"
Next, you can drag-and-drop the Webapp.io environment to alter its position, e.g. before Staging.
data:image/s3,"s3://crabby-images/35fa9/35fa9e9262d8098085b272f280681f1a95f49961" alt="04-reorder-environment.png 2000"
Service Tokens
Create a Doppler Service Token that the Doppler CLI will use to access your secrets by selecting the Access tab, then click the Generate button.
data:image/s3,"s3://crabby-images/7e482/7e4822a4d68dc3935624e591a91c8345b42f8a1c" alt="05-create-service-token.png 2000"
Give the token a name like "Webapp.io", then copy the Service Token value which we will then use to create a new Webapp.io Secret.
data:image/s3,"s3://crabby-images/6ba2b/6ba2b5571f7b1b6cf5572ef3475f671c33e86d1c" alt="06-copy-service-token.png 2000"
Now in Webapp.io, go to Secrets and add a new secret named DOPPLER_TOKEN using the token content copied to the clipboard. You can choose to expose this token to specific projects or all of them.
Usage
Now, let's create a simple Webapp.io Layerfile to show you how to access secrets from Doppler.
First, install the Doppler CLI, then load the DOPPLER_TOKEN variable from your Webapp.io secrets, and finally use doppler run
to fetch the config secrets
FROM vm/ubuntu:18.04
# Install Doppler
RUN (curl -Ls --tlsv1.2 --proto "=https" --retry 3 https://cli.doppler.com/install.sh || wget -t 3 -qO- https://cli.doppler.com/install.sh) | sh
COPY . .
# Load DOPPLER_TOKEN secret from Webapp.io
SECRET ENV DOPPLER_TOKEN
# Test Doppler secrets access
RUN doppler run -- printenv | grep DOPPLER # Testing purposes only
A successful run log should produce output similar to the following:
Multiple Environments
If your jobs require specific variables for different environments, e.g. preview vs. production builds, then you'll need a different approach than using a single DOPPLER_TOKEN
environment variable.
The solution is to use Doppler branch configs to create environment-specific configs.
data:image/s3,"s3://crabby-images/8e21e/8e21eb5825a96abe5d165ca5416719961c633a20" alt="09-multi-env.png 2000"
Then create a Doppler Service Token and Webapp.io Secret for each config.
Then the doppler run
command will need to use the --token
flag as the DOPPLER_TOKEN
environment variable does not exist. An example of a build that uses both our Preview and Production service tokens could look like the following:
FROM vm/ubuntu:18.04
# Install Doppler
RUN (curl -Ls --tlsv1.2 --proto "=https" --retry 3 https://cli.doppler.com/install.sh || wget -t 3 -qO- https://cli.doppler.com/install.sh) | sh -s -- --verify-signature
COPY . .
# Load several Doppler tokens from Webapp.io
SECRET ENV DOPPLER_TOKEN_PREVIEW
SECRET ENV DOPPLER_TOKEN_PRODUCTION
# Test Doppler secrets access for both
RUN doppler -t $DOPPLER_TOKEN_PREVIEW run -- printenv | grep DOPPLER # Testing purposes only
RUN doppler -t $DOPPLER_TOKEN_PRODUCTION run -- printenv | grep DOPPLER # Testing purposes only
Well Done!
Now you are all set up using the Doppler CLI to provide secrets to your Webapp.io builds in both single, and multi-environment workflows.
Updated 9 days ago