All Downloads are FREE. Search and download functionalities are using the official Maven repository.

uk.gov.nationalarchives.BackendCheckUtils.scala Maven / Gradle / Ivy

package uk.gov.nationalarchives

import io.circe.generic.auto._
import io.circe.parser.decode
import software.amazon.awssdk.core.sync.RequestBody
import software.amazon.awssdk.http.SdkHttpClient
import software.amazon.awssdk.http.apache.ApacheHttpClient
import software.amazon.awssdk.regions.Region
import software.amazon.awssdk.services.s3.S3Client
import software.amazon.awssdk.services.s3.model.{GetObjectRequest, PutObjectRequest}
import uk.gov.nationalarchives.BackendCheckUtils.{Input, S3Input}

import java.net.URI
import java.util.UUID
import scala.util.Try

class BackendCheckUtils(s3Client: S3Client) {

  def getResultJson(key: String, bucket: String): Either[Throwable, Input] = {
    for {
      s3Response <- Try(s3Client.getObject(GetObjectRequest.builder.bucket(bucket).key(key).build)).toEither
      decoded <- decode[Input](s3Response.readAllBytes().map(_.toChar).mkString)
    } yield decoded
  }

  def writeResultJson(key: String, bucket: String, result: String): Either[Throwable, S3Input] = {
    val responseBody = RequestBody.fromString(result)
    Try(s3Client.putObject(PutObjectRequest.builder.bucket(bucket).key(key).build(), responseBody)).toEither
      .map(_ => S3Input(key, bucket))
  }
}

object BackendCheckUtils {
  private def s3Client(endpoint: String) = {
    val httpClient: SdkHttpClient = ApacheHttpClient.builder.build
    S3Client.builder
      .region(Region.EU_WEST_2)
      .endpointOverride(URI.create(endpoint))
      .httpClient(httpClient)
      .build()
  }

  def apply(endpoint: String) = new BackendCheckUtils(s3Client(endpoint))

  trait RedactedResult

  case class StatusResult(statuses: List[Status])

  case class Status(id: UUID, statusType: String, statusName: String, statusValue: String, overwrite: Boolean = false)

  case class ChecksumResult(sha256Checksum: String, fileId: UUID)

  case class FFIDMetadataInputMatches(extension: Option[String], identificationBasis: String, puid: Option[String], fileExtensionMismatch: Option[Boolean],
                                      formatName: Option[String])

  case class FFID(fileId: java.util.UUID, software: String, softwareVersion: String, binarySignatureFileVersion: String, containerSignatureFileVersion: String, method: String, matches: List[FFIDMetadataInputMatches])

  case class Antivirus(fileId: UUID, software: String, softwareVersion: String, databaseVersion: String, result: String, datetime: Long)

  case class FileCheckResults(antivirus: List[Antivirus], checksum: List[ChecksumResult], fileFormat: List[FFID])

  case class File(
                   consignmentId: UUID,
                   fileId: UUID,
                   userId: UUID,
                   consignmentType: String,
                   fileSize: String,
                   clientChecksum: String,
                   originalPath: String,
                   fileCheckResults: FileCheckResults
                 )

  case class RedactedResults(redactedFiles: List[RedactedFilePairs], errors: List[RedactedErrors])

  case class RedactedErrors(fileId: UUID, cause: String) extends RedactedResult

  case class RedactedFilePairs(originalFileId: UUID, originalFilePath: String, redactedFileId: UUID, redactedFilePath: String) extends RedactedResult

  case class Input(results: List[File], redactedResults: RedactedResults, statuses: StatusResult)

  case class S3Input(key: String, bucket: String)
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy