Skip to content

communitiesuk/eip-ero-notifications-api

Repository files navigation

eip-ero-notifications-api

Spring Boot microservice that :

  • Provides an API for sending notifications using the Government Notify service.
  • This is referred to as both Notifications and Communications

See section on GOV.UK Notify Templates for details on creating and editing templates.

Developer Setup

Kotlin API Developers

Linting IDE configuration

Configure your IDE with the code formatter (ktlint):

$ ./gradlew ktlintApplyToIdea

This only needs doing once to set up your IDE with the code styles.

Press ctrl-alt-l to reformat your current file to match the styles, or set them to apply automatically when you save a file.

If you prefer, you can run ./gradlew addKtlintFormatPreCommitHook to add a pre-commit hook to format your code on commit.

AWS CodeArtifact Access Set Up

To access libraries stored in the AWS CodeArtifact repository an access token is required that the build script fetches in the background using the credentials for the code-artifact profile. To create this profile on your developer machine follow these instructions:

aws configure --profile code-artifact

At the prompts configure the code-artifact profile as follows:

  • Your AWS Access Key ID
  • Your AWS Secret Access Key
  • Default region name, eu-west-2
  • Default output format, json

Note: AWS CLI must be installed on the developer workstation as a pre-requisite.

Running Tests

In order to run the tests successfully, you will first need to set the LOCALSTACK_API_KEY environment variable (i.e. within your .bash_profile or similar). Then run:

$ ./gradlew check

This will run the tests and ktlint. (Be warned, ktlint will hurt your feelings!)

Building docker images

$ ./gradlew check bootBuildImage

This will build a docker image for the Spring Boot application.

Running the application

Either ./gradlew bootRun or run the class VoterCardApplicationsApiApplication

External Environment Variables

The following environment variables must be set in order to run the application:

  • AWS_ACCESS_KEY_ID - the AWS access key ID
  • AWS_SECRET_ACCESS_KEY - the AWS secret access key
  • AWS_REGION - the AWS region
  • SPRING_SECURITY_OAUTH2_RESOURCESERVER_JWT_ISSUER_URI - the uri of the cognito ERO user pool JWT issuer.
  • DYNAMODB_ENDPOINT - the localstack endpoint
  • SQS_SEND_UK_GOV_NOTIFY_PHOTO_RESUBMISSION_QUEUE_NAME - the queue name for sending communications to request a new photo.
  • SQS_SEND_UK_GOV_NOTIFY_ID_DOCUMENT_RESUBMISSION_QUEUE_NAME - the queue name for sending communications to request a new ID document.
  • SQS_SEND_UK_GOV_NOTIFY_ID_DOCUMENT_REQUIRED_QUEUE_NAME - the queue name for sending communications to request a new ID document based on the elector not being IDV'ed by NINo.
  • SQS_SEND_UK_GOV_NOTIFY_APPLICATION_RECEIVED_QUEUE_NAME - the queue name for sending communications for a received application.
  • SQS_SEND_UK_GOV_NOTIFY_APPLICATION_APPROVED_QUEUE_NAME - the queue name for sending communications for an approved application.
  • SQS_SEND_UK_GOV_NOTIFY_APPLICATION_REJECTED_QUEUE_NAME - the queue name for sending communications for a rejected application.
  • SQS_SEND_UK_GOV_NOTIFY_REJECTED_SIGNATURE_QUEUE_NAME - the queue name for sending communications for a rejected signature.
  • SQS_SEND_UK_GOV_NOTIFY_REQUESTED_SIGNATURE_QUEUE_NAME - the queue name for sending communications for a requested signature.
  • SQS_REMOVE_APPLICATION_NOTIFICATIONS_QUEUE_NAME - the queue name for removing an applicant's notification data.
  • TEMPLATE_PHOTO_RESUBMISSION_EMAIL_ENGLISH - Notify service email template ID for requesting a new photo in English
  • TEMPLATE_PHOTO_RESUBMISSION_EMAIL_WELSH - Notify service email template ID for requesting a new photo in Welsh
  • TEMPLATE_PHOTO_RESUBMISSION_WITH_REASONS_EMAIL_ENGLISH - Notify service email template ID for requesting a new photo (with reasons) in English
  • TEMPLATE_PHOTO_RESUBMISSION_WITH_REASONS_EMAIL_WELSH - Notify service email template ID for requesting a new photo (with reasons) in Welsh
  • TEMPLATE_ID_DOCUMENT_RESUBMISSION_EMAIL_ENGLISH - Notify service email template ID for requesting a new identification document in English
  • TEMPLATE_ID_DOCUMENT_RESUBMISSION_EMAIL_WELSH - Notify service email template ID for requesting a new identification document in Welsh
  • TEMPLATE_ID_DOCUMENT_RESUBMISSION_WITH_REASONS_EMAIL_ENGLISH - Notify service email template ID for requesting a new identification document (with reasons) in English
  • TEMPLATE_ID_DOCUMENT_RESUBMISSION_WITH_REASONS_EMAIL_WELSH - Notify service email template ID for requesting a new identification document (with reasons) in Welsh
  • TEMPLATE_PHOTO_RESUBMISSION_LETTER_ENGLISH - Notify service letter template ID for requesting a new photo in English
  • TEMPLATE_PHOTO_RESUBMISSION_LETTER_WELSH - Notify service letter template ID for requesting a new photo in Welsh
  • TEMPLATE_PHOTO_RESUBMISSION_WITH_REASONS_LETTER_ENGLISH - Notify service letter template ID for requesting a new photo (with reasons) in English
  • TEMPLATE_PHOTO_RESUBMISSION_WITH_REASONS_LETTER_WELSH - Notify service letter template ID for requesting a new photo (with reasons) in Welsh
  • TEMPLATE_ID_DOCUMENT_RESUBMISSION_LETTER_ENGLISH - Notify service letter template ID for requesting a new identification document in English
  • TEMPLATE_ID_DOCUMENT_RESUBMISSION_LETTER_WELSH - Notify service letter template ID for requesting a new identification document in Welsh
  • TEMPLATE_ID_DOCUMENT_RESUBMISSION_WITH_REASONS_LETTER_ENGLISH - Notify service letter template ID for requesting a new identification document (with reasons) in English
  • TEMPLATE_ID_DOCUMENT_RESUBMISSION_WITH_REASONS_LETTER_WELSH - Notify service letter template ID for requesting a new identification document (with reasons) in Welsh
  • TEMPLATE_ID_DOCUMENT_REQUIRED_EMAIL_ENGLISH - Notify service email template ID for id document required in English
  • TEMPLATE_ID_DOCUMENT_REQUIRED_EMAIL_WELSH - Notify service email template ID for id document required in Welsh
  • TEMPLATE_ID_DOCUMENT_REQUIRED_LETTER_ENGLISH - Notify service letter template ID for id document required in English
  • TEMPLATE_ID_DOCUMENT_REQUIRED_LETTER_WELSH - Notify service letter template ID for id document required in Welsh
  • TEMPLATE_POSTAL_APPLICATION_RECEIVED_EMAIL_ENGLISH - Notify service email template ID for informing postal application is received in English
  • TEMPLATE_POSTAL_APPLICATION_RECEIVED_EMAIL_WELSH - Notify service email template ID for informing postal application is received in Welsh
  • TEMPLATE_PROXY_APPLICATION_RECEIVED_EMAIL_ENGLISH - Notify service email template ID for informing proxy application is received in English
  • TEMPLATE_PROXY_APPLICATION_RECEIVED_EMAIL_WELSH - Notify service email template ID for informing proxy application is received in Welsh
  • TEMPLATE_OVERSEAS_APPLICATION_RECEIVED_EMAIL_ENGLISH - Notify service email template ID for informing overseas application is received in English
  • TEMPLATE_OVERSEAS_APPLICATION_RECEIVED_EMAIL_WELSH - Notify service email template ID for informing overseas application is received in Welsh
  • TEMPLATE_APPLICATION_APPROVED_EMAIL_ENGLISH - Notify service email template ID for informing application is approved in English
  • TEMPLATE_APPLICATION_APPROVED_EMAIL_WELSH - Notify service email template ID for informing application is approved in Welsh
  • TEMPLATE_APPLICATION_REJECTED_LETTER_ENGLISH - Notify service letter template ID for informing application is rejected in English
  • TEMPLATE_APPLICATION_REJECTED_LETTER_WELSH - Notify service letter template ID for informing application is rejected in Welsh
  • TEMPLATE_PROXY_REJECTED_SIGNATURE_EMAIL_ENGLISH - Notify service email template ID for informing proxy vote application signature rejected in English
  • TEMPLATE_PROXY_REJECTED_SIGNATURE_WITH_REASONS_EMAIL_ENGLISH - Notify service email template ID for informing proxy vote application signature rejected with reasons in English
  • TEMPLATE_PROXY_REJECTED_SIGNATURE_LETTER_ENGLISH - Notify service letter template ID for informing proxy vote application signature rejected in English
  • TEMPLATE_PROXY_REJECTED_SIGNATURE_WITH_REASONS_LETTER_ENGLISH - Notify service letter template ID for informing proxy vote application signature rejected with reasons in English
  • TEMPLATE_PROXY_REJECTED_SIGNATURE_EMAIL_WELSH - Notify service email template ID for informing proxy vote application signature rejected in Welsh
  • TEMPLATE_PROXY_REJECTED_SIGNATURE_WITH_REASONS_EMAIL_WELSH - Notify service email template ID for informing proxy vote application signature rejected with reasons in Welsh
  • TEMPLATE_PROXY_REJECTED_SIGNATURE_LETTER_WELSH - Notify service letter template ID for informing proxy vote application signature rejected in Welsh
  • TEMPLATE_PROXY_REJECTED_SIGNATURE_WITH_REASONS_LETTER_WELSH - Notify service letter template ID for informing proxy vote application signature rejected with reasons in Welsh
  • TEMPLATE_PROXY_REQUESTED_SIGNATURE_EMAIL_ENGLISH - Notify service email template ID for informing proxy vote application signature requested in English
  • TEMPLATE_PROXY_REQUESTED_SIGNATURE_LETTER_ENGLISH - Notify service letter template ID for informing proxy vote application signature requested in English
  • TEMPLATE_PROXY_REQUESTED_SIGNATURE_EMAIL_WELSH - Notify service email template ID for informing proxy vote application signature requested in Welsh
  • TEMPLATE_PROXY_REQUESTED_SIGNATURE_LETTER_WELSH - Notify service letter template ID for informing proxy vote application signature requested in Welsh
  • TEMPLATE_POSTAL_NINO_NOT_MATCHED_EMAIL_ENGLISH - Notify service email template ID for informing postal vote application Nino not matched in English
  • TEMPLATE_POSTAL_NINO_NOT_MATCHED_EMAIL_WELSH - Notify service email template ID for informing postal vote application Nino not matched in Welsh
  • TEMPLATE_POSTAL_NINO_NOT_MATCHED_LETTER_ENGLISH - Notify service letter template ID for informing postal vote application Nino not matched in English
  • TEMPLATE_POSTAL_NINO_NOT_MATCHED_LETTER_WELSH - Notify service letter template ID for informing postal vote application Nino not matched in Welsh
  • TEMPLATE_POSTAL_REJECTED_SIGNATURE_EMAIL_ENGLISH - Notify service email template ID for informing postal vote application signature rejected in English
  • TEMPLATE_POSTAL_REJECTED_SIGNATURE_WITH_REASONS_EMAIL_ENGLISH - Notify service email template ID for informing postal vote application signature rejected with reasons in English
  • TEMPLATE_POSTAL_REJECTED_SIGNATURE_LETTER_ENGLISH - Notify service letter template ID for informing postal vote application signature rejected in English
  • TEMPLATE_POSTAL_REJECTED_SIGNATURE_WITH_REASONS_LETTER_ENGLISH - Notify service letter template ID for informing postal vote application signature rejected with reasons in English
  • TEMPLATE_POSTAL_REJECTED_SIGNATURE_EMAIL_WELSH - Notify service email template ID for informing postal vote application signature rejected in Welsh
  • TEMPLATE_POSTAL_REJECTED_SIGNATURE_WITH_REASONS_EMAIL_WELSH - Notify service email template ID for informing postal vote application signature rejected with reasons in Welsh
  • TEMPLATE_POSTAL_REJECTED_SIGNATURE_LETTER_WELSH - Notify service letter template ID for informing postal vote application signature rejected in Welsh
  • TEMPLATE_POSTAL_REJECTED_SIGNATURE_WITH_REASONS_LETTER_WELSH - Notify service letter template ID for informing postal vote application signature rejected with reasons in Welsh
  • TEMPLATE_POSTAL_REQUESTED_SIGNATURE_EMAIL_ENGLISH - Notify service email template ID for informing postal vote application signature requested in English
  • TEMPLATE_POSTAL_REQUESTED_SIGNATURE_LETTER_ENGLISH - Notify service letter template ID for informing postal vote application signature requested in English
  • TEMPLATE_POSTAL_REQUESTED_SIGNATURE_EMAIL_WELSH - Notify service email template ID for informing postal vote application signature requested in Welsh
  • TEMPLATE_POSTAL_REQUESTED_SIGNATURE_LETTER_WELSH - Notify service letter template ID for informing postal vote application signature requested in Welsh
  • API_ERO_MANAGEMENT_URL - the base URL of the ERO Management REST API service.
  • DYNAMODB_NOTIFICATION_TABLE_NAME - the Dynamo DB table name containing Notifications
  • DYNAMODB_COMMUNICATION_CONFIRMATIONS_TABLE_NAME - the Dynamo DB table name containing Communication Confirmations

MYSQL Configuration

For local setup refer to src/main/resources/db/readme.

  • MYSQL_HOST
  • MYSQL_PORT
  • MYSQL_USER
  • MYSQL_PASSWORD - only used locally or when running tests

Infrastructure overrides

The following are overridden by the task definition in AWS:

  • SPRING_DATASOURCE_URL - This is set to the deployed RDS' URL.
  • SPRING_DATASOURCE_DRIVERCLASSNAME - This is overridden to use the AWS Aurora MySQL JDBC Driver.
  • SPRING_LIQUIBASE_DRIVERCLASSNAME - This is overridden to use the AWS Aurora MySQL JDBC Driver.

Liquibase Configuration

  • LIQUIBASE_CONTEXT Contexts for liquibase scripts. For local setup use ddl.

Authentication and authorisation

Requests are authenticated by the presence of a signed cognito JWT as a bearer token in the HTTP request authorization header.
EG: Authorization: Bearer xxxxxyyyyyyzzzzz.....
Requests are authorised by their membership of groups and roles carried on the JWT token.
The UI application is expected to handle the authentication with cognito and pass the JWT token in the authorization header.

Test Liquibase Rollbacks

To test liquibase rollbacks try the following steps.

  1. build a docker image based on the previous git commit.
  2. remove docker containers and the docker_mysql-data docker volume
  3. run start-docker to create the database and apply all previous changesets
  4. having defined your new databaseChangeLog file, edit db.changelog-master.xml to comment out all references to other databaseChangeLog files
  5. cd to your src/main/resources/db/changelog directory
  6. define a liquibase.properties file, as shown below
  7. to apply your latest DB changes execute $LIQUIBASE_HOME/liquibase --log-level debug --contexts=ddl update
  8. verify your DB changes are as expected
  9. to rollback your latest DB changes execute $LIQUIBASE_HOME/liquibase --log-level debug --contexts="ddl" rollback-to-date '2022-08-23 15:17:13' filling in the appropriate date from the DATABASECHANGELOG.DATEEXECUTED column
  10. verify your DB changes are again as expected

A sample liquibase.properties file

changelog-file: db.changelog-master.xml
driver: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/voter_card_application
username: root
password: rootPassword
classpath: /home/valtech/IdeaProjects/eip/eip-ero-voter-card-applications-api/src/main/resources/db/changelog/mysql-connector-java-8.0.29.jar
context=ddl

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages