Skip to content

Running the Dev Containers

William B edited this page Dec 29, 2023 · 35 revisions

Prerequisites

This guide assumes you have completed the following prerequisite tasks.

  • Setup 1Password and have access to the Notify folders
  • Have access to your own AWS accounts for both the Staging and Production environments
  • Docker Desktop is installed on your machine
  • Visual Studio Code is installed on your machine
  • Cloned the API , Admin, and notification-document-download-api repos

How to work with dev containers in VSCode

  1. If it is not already installed, add the Dev Containers extension to VSCode
  2. Open the Command Palette with ⌘ + shift + p
  3. Type Dev Containers and select the Open folder in container option
  4. Navigate to and open the Admin project
  5. The Dev Container should begin building. You should notice output in the terminal.

Screenshot 2023-12-28 at 12 00 17 PM

What sorcery is this?

If you're familiar with Docker and Dev Containers already, feel free to skip this section.

Since you're waiting for the dev container and project to build, now is a good time to learn about the basics of the dev container setup.

In each project you'll notice a .devcontainer folder structured similarly to the one pictured below.

Screenshot 2023-12-28 at 12 05 43 PM

Let's briefly go over how these files relate to one another.

A set of instructions used by Docker to build an image that serves as the basis for the our Dev Container environment. OS and root level operations are defined here.

Install OS level dependencies and packages (git, npm, nodejs, vim etc.), perform root-level operations (chown, chmod, set env vars etc)

Scripts

These shell scripts execute within the the container after it is built. They are geared toward user space actions and general project setup.

Set up terminal aliases and autocompletions, install python/JS dependencies, build the project

This file brings everything together. It instructs VSCode how to handle creation of, and access to a dev container as well as automatically configuring VSCode extensions.

Which Dockerfile is used to build the container, will we use bash or zsh, what VSCode extensions are should be installed, which scripts should run after the container is built

Configure the projects

.env configs

Each project relies on a .env Flask configuration file that should be placed in the root of the project. You can find one for each respective project in 1Password: Canadian Digital Service > CDS Platform - Notify Local (NEW).

  1. Create a file named .env at the root of each project
  2. Copy the contents from 1Password into each respective .env file.

launch.json configs

The last piece needed is a launch configuration to instruct VSCode how to launch the apps. The configs can be found in 1Password.

  1. Add the following directory structure in each project: `<project_root>/.vscode
  2. In the .vscode directory, create a file called launch.json
  3. Copy the contents from 1Password into each respective launch.json file

Launching the apps

With the configurations in place and the dev containers built, running the application is as simple as:

  1. Navigate to Run and Debug
  2. Select Python: Flask from the drop down
  3. Press the green arrow

Screenshot 2023-12-29 at 12 55 02 PM

Admin

  1. Run the Admin project.
  2. Once the app has started, you should see configuration output in your terminal.
  3. Navigate to http://localhost:6012, you should see the following page:

Screenshot 2023-12-29 at 1 02 05 PM

You're seeing this message because we also need to run the API app to provide Admin with a means to interact with the data.

API

Start API the same way you started Admin, running both the Python: Flask and Python: Celery apps, then refresh the page in your browser. If you see the following, congrats! You've successfully setup GCNotify locally!

Screenshot 2023-12-29 at 1 05 54 PM

Explore the app:

  1. Create an account
  2. log in
  3. Create a service and template
  4. Perform a send

If all goes well, you're ready to start developing. If you ran into issues check out the troubleshooting section or hit up one of your fellow devs and we'll help you out.

Document Download API

In general, Admin and API suffice for most day to day work. However if you need to send notifications with attached files, the Document Download API app needs to be running.

Verify it's working

Once you built and ran the DD-API container and app you'll need to change a few service settings, add a new template, and create an API key to send an email notification with an attachment.

  1. Log in and navigate to your service settings
  2. Under the Emails settings enable the Send files by email setting
  3. Navigate to your Dashboard and create a new email template

Make sure to include a variable in the template body, ((var)) will do.

  1. Navigate to API Integration > API keys and create a Live API key

Take note of the API key as it is needed in the next steps

  1. Use a tool like Postman to send the following request to: http://localhost:6011/v2/notifications/email

Make sure you set the following headers:

  • Authorization : The API key you created in step 4
  • Content-Type : application/json
{
  "email_address": "<YOUR EMAIL ADDRESS>",
  "template_id": "<TEMPLATE ID>",
  "personalisation": {
    "var": "var",
    "application_file": {
      "file": "aGkgdGhlcmU=",
      "filename": "test_file.txt",
      "sending_method": "attach"
    }
  }
}
  1. Check your email and make sure you can open the attached or linked file.

Alternatively you can use a curl command:

curl -i -X POST \
   -H "Authorization:ApiKey-v1 <YOUR API KEY>" \
   -H "Content-Type:application/json" \
   -d \
'{
  "email_address": "<YOUR EMAIL ADDRESS>",
  "template_id": "<TEMPLATE ID>",
  "personalisation": {
    "var": "var",
    "application_file": {
      "file": "aGkgdGhlcmU=",
      "filename": "test_file.txt",
      "sending_method": "attach"
    }
  }
}' \
 'http://localhost:6011/v2/notifications/email'

Troubleshooting & FAQs

I see the error: "Sorry, we’re experiencing technical difficulties" when I navigate to the home page

  • Have you built and ran the the API app?
  • In the admin project, check that theAPI_HOST_NAME in your .env file is pointing to the correct address: http://host.docker.internal:6011.

In simple terms, host.docker.internal is like the Docker version of localhost, except with a little extra DNS magic. It is scoped to a virtual network in Docker In this case the bridge network.

If the above is in order, it's time to inspect the bridge network in Docker, to ensure that both the Admin and API containers are both present. Open a terminal and:

  1. Identify the ADMIN and API containers: docker container ls
  2. Check the bridge network: docker network inspect bridge
  3. Add any missing containers to the bridge network: docker network connect bridge <container-id>

I selected a Python interpreter but the app still won't launch

We use a tool called Poetry to create and automagically manage the Python virtual environments that the apps run in. Occasionally VSCode doesn't pick up this virtual environment and must be pointed to manually.

  1. Open a Python source file in VSCode
  2. Check the bottom status bar and ensure the selected Python interpreter indicates Poetry:

Screenshot 2023-12-29 at 1 14 00 PM

If this isn't present, right click the status bar and check the Selected Python Interpreter option.

  1. To change the selected Interpreter click current interpreter on the status bar and select the Poetry environment in the Command Palette window that opens.

If the Poetry environment isn't listed

  1. Select Enter interpreter path...
  2. Navigate to /home/vscode/.cache/pypoetry/virtualenvs/<project-name-some_id-py3.10>/bin/python3.10