Skip to content

Latest commit

 

History

History
228 lines (146 loc) · 10.7 KB

README.md

File metadata and controls

228 lines (146 loc) · 10.7 KB

OCIO HSB Dashboard

Ministry of Citizens' Services

The Office of the Chief Information Officer’s Enterprise Services Division enables Government to deliver services to citizens by providing high quality, secure and cost-effective information management, and technology services. In Enterprise Services Division, Hosting Services enables B.C. government and broader public sector (BPS) to access sustainable hosting infrastructure and services to support the evolving needs of government clients and citizens.

The OCIO’s storage infrastructure offers redundancy, configuration flexibility, support services and management software capabilities for supporting different data types, applications, and processing platforms. Client ministries can choose one or more of three tiers of storage, in 50 GB increments, that align with government business data requirements.

This dashboard aims to allow users to visualize their storage allocation and consumption through different views and perspectives to help them understand their current consumption. It will provide dynamic access to server storage consumption and allocation data for client use and HSB use. The goal is to allow users to make data-backed decisions on how to best reduce or optimize their storage utilization.

Script Help

There are several scripts and commands to help local development and the CI/CD pipeline.

# Show all the help commands
bash do help

Get Started Developing

Prerequisites

You'll need to install the following.

Dependency Link
Docker Desktop, or equivalent that supports docker and docker-compose download
Windows Bash (if you're using Windows OS) download
Node Version Manager - NVM download
.NET SDK 8.0 (only if you want to run .NET locally) download

Docker Desktop on Windows defaults to WSL mode. This may work, but has known issues. You may need to turn WSL off.

When you install Node Version Manager (nvm) on Windows you will need to open a new command window as an administrator. Run nvm install 20.8.1 to install the version of Node required for this project. Once it is installed run nvm use 20.8.w1. If it installed correctly you can run node -v and it will display the correct version.

Mac requirements

You will need to install coreutils, gnu-getopt, and gsed using Homebrew:

brew install coreutils gnu-getopt gsed

If you run into other errors during the steps below, it is most likely a script needs execute permission.

Container initialization

Execute the following command to initialize your local environment.

# Generate a local Keycloak admin username and password.
# Generate .env files.
# Start the database and run the migration.
# Spin up all other required containers.
#
bash do init

The script will initialize the database and various Docker containers.

Update .env files and restart environment

For the app to be fully functional, we will need to update the values of some .env file secrets.

Obtain the local Keycloak Client Secret

  1. With the application running (check in Docker), navigate to the local Keycloak admin interface: http://localhost:30001.
  2. Enter the username and password you created for the local Keycloak admin in the previous step.
  3. From the dropdown (select) menu in the upper-right (currently showing "Keycloak"), choose "Host Services Branch Dashboard".
  4. From the sidebar on the left, click Clients.
  5. In the table, click hsb-app.
  6. Click the Credentials tab.
  7. In the Client Secret section of the page, click the clipboard icon to copy the Client Secret to your clipboard. This is the Client Secret. Take note of it, because it will be entered in several places below. (In the examples below, we will use the pretend key Abc123.)

Update API env file

In /src/api/.env:

Update the line Keycloak__Secret={GET FROM KEYCLOAK} with the Client Secret, e.g.

Keycloak__Secret=Abc123

Update API-CSS env file

In /src/api-css/.env, update two lines with hsb-app and the Client Secret respectively:

Keycloak__ClientId=hsb-app
Keycloak__Secret=Abc123

Update Dashboard env file

In /src/dashboard/.env:

Update the line KEYCLOAK_SECRET={GET FROM KEYCLOAK} with the Client Secret, e.g.:

KEYCLOAK_SECRET=Abc123

Note that you can also uncomment the following lines to skip Keycloak authentication altogether:

# NEXT_PUBLIC_AUTH_STATUS=authenticated
# NEXT_PUBLIC_AUTH_ROLES=hsb

This should only be done for development purposes when testing authentication is not necessary.

Restart environment

The following command will rebuild the Docker containers to pick up all the .env file changes you've made above:

bash do up

Run the web application

Now we can start the web application:

# Open the web application in your default browser
bash do go

The Dashboard web application is setup for hot-reload within a Docker container.

Tips

Find all .env files

When recreating the environment, .env files are left behind by default. But this can cause issues when attempting a fresh install. To find .env files:

find . -name '*.env'

Helpful Documentation

Database Migrations

Database migrations are built with Entity Framework. Dotnet tooling provides a Code-First approach to database migration, which enables the generation of migrations that apply new versions and perform rollbacks to prior versions. These tools provide a simple repeatable and testable Infrastructure as Code implementation.

To create a new database migration it is as simple as executing the following command bash do db-add {version}. This will generate a migration that will apply any changes you have made to the database entities and structure, and also includes a way to run SQL scripts. Scripts must be placed in appropriate folders which are convention based ./src/libs/dal/Migrations/{version}/Up/PreUp, ./src/libs/dal/Migrations/{version}/Up/PostUp, ./src/libs/dal/Migrations/{version}/Down/PreDown, ./src/libs/dal/Migrations/{version}/Down/PostDown. It is also possible to execute scripts at any point in the migration through code.

To run the migration execute the following command bash do db-migration. This will build an image and run a container to perform the database migration. If you have the Dotnet SDK and Entity Framework tools installed locally you can execute the following command instead bash do db-update, this is more performant for machines with little RAM.

There are a few other helpful database migration commands that can help with development.

Command Description
db-list Displays all migration version available
db-add Generates a new migration
db-migration Builds and run container to perform migration
db-update Builds and runs migration locally
db-rollback Roles back to the specified version
db-remove Removes the files associated with the most recent migration
db-drop Drops the database
db-refresh Drops the database and runs all the migrations
db-redo Rollback and reapply the migration

If you get an error on a Mac with an M chip, try running:

dotnet tool uninstall dotnet-ef --global
dotnet tool install dotnet-ef --global -a arm64

CI/CD Pipelines

When a Pull Request is created Github Actions will build and test the images to provide feedback on issues.

When a Pull Request is merged into the main branch Github Actions will build and publish the images to the default Github Packages image registry. There are four packages built for this project.

Artifactory which is hosted by the Exchange Lab will pull in these packages every 15 minutes. All of these images are tagged with latest (all attempts to also tag them with other values have not been successful for some reason).

There are Tekton pipelines created to assist in deployments of the db-migration and data-service. Note that the data-service takes more than an hour to run, as such you will need to create a PipelineRun object (example is in source) to configure a longer run time. These pipelines provide a simple parameter based way to run theses containers in the appropriate environment.

Options

Argument Values Required Default
component api,db,app,data-service *
tag latest
env dev, test, prod dev

Build Images

If you would like to build an image locally and push it to Openshift you can use the following commands. Replace the curly brackets with an appropriate value.

bash do oc-build {component} {tag=latest}

Push Images

To push a local image to Openshift registry use the following command.

bash do oc-push {component}

Deploy Images

To deploy an image to an environment in Openshift use the following command. This makes the images available to those environments and they will be automatically deployed.

bash do oc-deploy {component} {tag=latest} {env=dev}

Run a Container Remotely

There are two components that are run as part of backend services, or deployments. The first is the db-migration which applies database migrations. The second is the data-service which syncs data with Service Now.

Run the database migration.

bash do oc-run db {tag=latest} {env=dev}

Run the Data Service.

bash do oc-run data-service {env=dev}