Skip to content

Latest commit

 

History

History
187 lines (122 loc) · 6.4 KB

README.md

File metadata and controls

187 lines (122 loc) · 6.4 KB

repo standards badge

Network Access Control Admin

This is the web frontend for managing Network Access Control

Getting Started

Authenticating with DockerHub

Local development shouldn't go over the download limits of Dockerhub. https://docs.docker.com/docker-hub/download-rate-limit/

If these limits are encountered, authentication with Docker is required:

export DOCKER_USERNAME=your-docker-hub-username
export DOCKER_PASSWORD=your-docker-hub-password

make authenticate-docker

Prepare the Variables

  1. Clone the repository to a local directory
  2. Create a .env file in the root directory and populate with the required values for the environment

Build the Containers

  1. Build the base images on your local docker
make build-dev

Setup Database

  1. Start the database image and run setup
make db-setup

Run the Application

  1. Start the application on your local docker
$ make serve

Running Tests Locally

  1. Setup the test database
ENV=test make db-setup
  1. Run the entire test suite
ENV=test make test

To run individual tests:

  1. Shell onto a test container
ENV=test make shell
  1. Run the test file or folder
bundle exec rspec path/to/spec/file

Scripts

There are two utility scripts in the ./scripts directory to:

  1. Migrate the database schema
  2. Deploy new tasks into the service

Deployment

The deploy command is wrapped in a Makefile. It calls ./scripts/deploy which schedules a zero downtime phased deployment in ECS.

It doubles the currently running tasks and briefly serves traffic from the new and existing tasks in the service. The older tasks are eventually decommissioned, and production traffic is gradually shifted over to only the new running tasks.

On CI this command is executed from the buildspec.yml file after migrations and publishing the new image to ECR has been completed.

Targetting the ECS Cluster and Service to Deploy

The ECS infrastructure is managed by Terraform. The name of the cluster and service are outputs from the Terraform apply. These values are published to SSM Parameter Store, when this container is deployed it pulls those values from Parameter Store and sets them as environment variables.

The deploy script references these environment variables to target the ECS Admin service and cluster. This is to avoid depending on the hardcoded strings.

The build pipeline assumes a role to access the target AWS account.

Publishing Image from Local Machine

  1. Export the following configurations as an environment variable.
  export NAC_TERRAFORM_OUTPUTS='{
    "admin": {
      "ecs": {
        "cluster_name": "[TARGET_CLUSTER_NAME]",
        "service_name": "[TARGET_SERVICE_NAME]"
      }
    }
  }'

This mimics what happens on CI where this environment variable is already set.

When run locally, you need to target the AWS account directly with AWS Vault.

  1. Schedule the deployment
  aws-vault exec [target_aws_account_profile] -- make deploy

Certificate management

There are 3 types of certificates required to allow authentications:

  • End-User trust certificates
  • Infrastructure certificates
  • Server certificates

End-User trust certificates

These are the certificate authorities (CAs) of the end user device certificates installed on the NACS server to establish trust and only allow authorised devices to connect. This can contain root and any intermediate certificates, uploaded as separate PEM files. No encrypted private key is required.

Infrastructure certificates

These are the certificate authorities (CAs) of the network authenticator vendors, installed on the NACS server and used to establish trust between authenticators and the server. These used for RADSEC connections exclusively. No encrypted private key is required.

Server certificates

There are 2 types of server certificates uploaded to NACS. The first is used for RADSEC, and sent to the authenticators. The second is used for authentication and sent to the end user devices. This is to establish trust and ensure that the devices / authenticators are communicating with the actual Network Access Control Service. These certificates are uploaded as PEM files.

To upload a new server certificate, follow these steps:

  1. Ensure the encrypted private key is included in the PEM file.
  2. Ensure the passphrase for the key is up to date in AWS Systems Manager Parameter Store in the Shared Services AWS account.
    • If the passphrase has changed, a deployment of the infrastructure pipeline followed by a deployment of the admin pipeline is required.
    • Validations are in place to only allow uploading certificates with encrypted private keys that match the current passphrase.
  3. Ensure the "Server Certificate" checkbox is selected when uploading these certificates.

CI/CD

Updating Gems

Developer tools (alpine-sdk, ruby-dev) have been added to the container to facilitate Gem version updates. To update a Gem version:

  • Build and run tests to make sure you have a baseline of the application running well.

  • Build the dev container

  make build-dev
  • Run the application with an interactive shell
  make shell-dev
  • Change the version in the Gemfile
  • In the interactive shell run a bundle update for the Gem being updated, e.g.
  bundle update rails
  • Check that the Gemfile.lock has the new version

  • Destroy container, re-build and run tests.