Consignment API data

This project is part of Transfer Digital Records. It provides tools for working with the consignment database:

  • Database migrations
  • Scala code generation

Database Migrations

Adding a migration script

  • Add a sql file to lambda/src/main/resources/db/migration with a prefix of V\d__something.sql

The name of the migration should use snake_case, e.g. V123__add_date_column_to_series_table, because Flyway expects this format when it generates the migration name.

To see the list of migrations detected and ensure that your migration will be run, run sbt flywayInfo.

To ensure that nothing has been changed accidentally, run sbt flywayValidate.

To run migrations locally, run sbt flywayMigrate.

To undo what was done by the migrations, run sbt flywayClean.

Running locally from Jar

Running locally from the jar reproduces how the lambda functions on AWS.

This can be useful for testing changes and debugging issues.

To do this:

  1. Set up locally running Postgres DB:
   docker run --name postgres -p 5432:5432 -e POSTGRES_USER=tdr -e POSTGRES_PASSWORD=password -e POSTGRES_DB=consignmentapi -d postgres:{version}
  1. Adjust the lambda code to point to the locally running DB:
  • In the Main.scala change the code to:
      ...
        val url = s"jdbc:postgresql://localhost:5432/consignmentapi"
        val flyway = Flyway.configure()
          .dataSource(url, "tdr", "password")
          .load()
    
        flyway.migrate()        
      }
    }
    ...
    object Main extends App {
      val lambda: Unit = new Main().runMigration()
    }
    
  • Add the host value to the application.conf to allow the build to run: host = "localhost"
  1. Build the jar locally:
  sbt lambda/assembly
  1. Then run the jar either:
  • From the command line: java -jar db-migrations.jar; or
  • In Intellij. Running in Intellij allows for debugging of the jar code.

Deployment

Run the following GitHub actions:

  • TDR Deploy Data Migration Lambda: this builds the migration code and deploys it to the Lambda which will run the migrations.
  • Run DB Migrations: this runs the latest version of the migrations lambda.

Migrations that have been merged to master will be deployed automatically on the Integration environment, and can be deployed manually on other environments with the TDR Deploy Data Migration Lambda GitHub action. The action will:

  • Run a lambda which updates the database within that environment.
  • Use slick codegen to generate slick files based on the database schema.
  • Deploy this code to the S3 release bucket.

Code generation

The project uses slick-codegen to generate Slick classes based on the database structure.

Publish generated code

  • Run the TDR Publish Slick Classes GitHub action. This publishes a new version of the consignment-api-db library.

Using updated schema locally

To use updated schema locally for development, run the following commands:

sbt slickCodegen sbt publishLocal

This will place a snapshot version of the built project jar in the local .ivy cache folder: $HOME/.ivy2/local/uk.gov.nationalarchives/consignment-api-db_2.13/[version number]-SNAPSHOT

Other sbt projects that have this project as a dependency can access the local snapshot version by changing the version number in their build.sbt file, for example:

... other dependencies...
"uk.gov.nationalarchives" %% "consignment-api-db" % "[version number]-SNAPSHOT"
... other dependences...