Skip to content

NHSDigital/eps-storage-resources

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

78 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

EPS Datastore

Build
Release

Versions and deployments

Version release history can be found ot https://github.com/NHSDigital/eps-storage-resources/releases.
Deployment history can be found at https://nhsdigital.github.io/eps-storage-resources/

Introduction

This defines the storage infrastructure for EPS. It uses dynamodb (in place of Riak) as the datastore for the Spine EPS interaction.

  • scripts/ Utilities helpful to developers.
  • packages/cdk Contains the CDK code used to define the stacks.
  • .devcontainer Contains a dockerfile and vscode devcontainer definition.
  • .github Contains github workflows that are used for building and deploying from pull requests and releases.
  • .vscode Contains vscode workspace file.

Contributing

Contributions to this project are welcome from anyone. Please refer to the guidelines for contribution and the community code of conduct.

Licensing

This code is dual licensed under the MIT license and the OGL (Open Government License). Any new work added to this repository must conform to the conditions of these licenses. In particular this means that this project may not depend on GPL-licensed or AGPL-licensed libraries, as these would violate the terms of those libraries' licenses.

The contents of this repository are protected by Crown Copyright (C).

Development

It is recommended that you use Visual Studio Code in a Linux environment with a dev container, as this will install all necessary components and correct versions of tools and languages.

WSL

If you are using a Windows machine, you will need to install WSL v2+ as detailed here.

Docker

You will need Docker. This is straightforward enough in a Linux environment, but if you are using WSL then you'll need to install Docker Desktop for Windows as detailed here and then do the following:

  • Go to Docker Desktop
  • Click the Settings cog icon at the top
  • Click Resources, then WSL integration
  • Enable WSL integration for your WSL distribution by enabling the slider

Restart your machine and run sudo docker ps command in WSL to check that the setup is complete.

You will need to install the Dev Containers extension for VS Code. The extension will then prompt you to Reopen in Container. Do this.

Commit signing

All commits must be made using signed commits.

Once the steps at the link above have been completed. Add to your ~/.gnupg/gpg.conf as below:

use-agent
pinentry-mode loopback

and to your ~/.gnupg/gpg-agent.conf as below:

allow-loopback-pinentry

As described here

You will need to create the files, if they do not already exist. This will ensure that your VSCode bash terminal prompts you for your GPG key password.

You can cache the gpg key passphrase by following instructions at https://superuser.com/questions/624343/keep-gnupg-credentials-cached-for-entire-user-session

AWS

It is intended that the DynamoDB table (and any other resources) created via the workflows defined in this repository are interacted with via the Spine codebase. There is a long-running feature branch in the Spine repo (feature/eps-dynamodb-poc) to hold our code changes. Follow the steps defined below on your Spine VM to allow connection to the DynamoDB table:

Authenticate

Navigate to the AWS SSO portal in your browser (and authenticate if necessary). Obtain the Access Keys for the NHS England EPS Development account and add them to a /home/spineii-user/.aws/credentials file as below:

[default]
AWS_ACCESS_KEY_ID=<aws_access_key_id>
AWS_SECRET_ACCESS_KEY=<aws_secret_access_key>
AWS_SESSION_TOKEN=<aws_session_token>

These will remain active for a set period, so will need to be refreshed occasionally throughout the day. The services making use of the DynamoDB datastore will need to be restarted when the credentials are refreshed.

You also need to add the following line to your .vscode/.env file:

AWS_SHARED_CREDENTIALS_FILE=/home/spineii-user/.aws/credentials

Pre-commit hooks

Some pre-commit hooks are installed as part of the install above, to run basic lint checks and ensure you can't accidentally commit invalid changes. The pre-commit hook uses python package pre-commit and is configured in the file .pre-commit-config.yaml. A combination of these checks are also run in CI.

Make commands

There are make commands that are run as part of the CI pipeline and help alias some functionality during development.

Install targets

  • install-python Installs python dependencies.
  • install-hooks Installs git pre-commit hooks.
  • install Runs all install targets.

CDK targets

These are used to do common commands related to cdk

  • cdk-synth Converts the CDK code to cloudformation templates
  • cdk-diff Runs cdk diff comparing the deployed stack with local CDK code to see differences
  • cdk-watch Syncs the code and CDK templates to AWS. This keeps running and automatically uploads changes to AWS

Clean and deep-clean targets

  • clean Clears up any files that have been generated by building or testing locally.
  • deep-clean Runs clean target and removes any python libraries installed locally.

Linting and testing

  • lint Runs lint for all code.
  • lint-github-actions Runs lint for github actions workflows.
  • lint-github-action-scripts Runs shellcheck for github actions scripts.
  • lint-python Runs lint for python code.
  • lint-sam-templates Runs lint for SAM templates.
  • test Runs unit tests for all code.

Check licenses

  • check-licenses Checks licenses for all python code.

CLI Login to AWS

  • aws-configure Configures a connection to AWS.
  • aws-login Reconnects to AWS from a previously configured connection.

Github folder

This .github folder contains workflows and templates related to GitHub, along with actions and scripts pertaining to Jira.

  • pull_request_template.md Template for pull requests.
  • dependabot.yml Dependabot definition file.

Scripts are in the .github/scripts folder:

  • call_mark_jira_released.sh Calls a Lambda function to mark Jira issues as released.
  • create_env_release_notes.sh Generates release notes for a specific environment using a Lambda function.
  • create_int_rc_release_notes.sh Creates release notes for integration environment using a Lambda function.
  • delete_stacks.sh Checks and deletes active CloudFormation stacks associated with closed pull requests.
  • get_current_dev_tag.sh Retrieves the current development tag and sets it as an environment variable.
  • get_target_deployed_tag.sh Retrieves the currently deployed tag and sets it as an environment variable.

Workflows are in the .github/workflows folder:

  • cdk_package_code.yml Packages code into a docker image and uploads to a github artifact for later deployment.
  • cdk_release_code.yml Release code built by cdk_package_code.yml to an environment.
  • ci.yml Workflow run when code merged to main. Deploys to dev and qa environments.
  • combine_dependabot_prs.yml Workflow for combining dependabot pull requests. Runs on demand.
  • create_release_notes.yml Workflow for creating release notes on confluence
  • delete_old_cloudformation_stacks.yml Workflow for deleting old cloud formation stacks. Runs daily.
  • dependabot_auto_approve_and_merge.yml Workflow to auto merge dependabot updates.
  • pr_title_check.yaml Checks title of pull request is valid.
  • pull_request.yml Called when pull request is opened or updated. Calls package_code and release_code to build and deploy the code. Deploys to dev AWS account. The main stack deployed adopts the naming convention storage-resources-pr-<PULL_REQUEST_ID>
  • release.yml Runs on demand to create a release and deploy to all environments.

About

No description, website, or topics provided.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •