-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
19 changed files
with
239 additions
and
63 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
4 changes: 2 additions & 2 deletions
4
...rchives/tdr/transfer/service/Config.scala → .../transfer/service/ApplicationConfig.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
9 changes: 0 additions & 9 deletions
9
src/main/scala/uk/gov/nationalarchives/tdr/transfer/service/api/model/Consignment.scala
This file was deleted.
Oops, something went wrong.
11 changes: 11 additions & 0 deletions
11
src/main/scala/uk/gov/nationalarchives/tdr/transfer/service/api/model/LoadModel.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
package uk.gov.nationalarchives.tdr.transfer.service.api.model | ||
|
||
import java.util.UUID | ||
|
||
sealed trait LoadModel | ||
sealed trait LoadDestinationModel | ||
|
||
object LoadModel { | ||
case class AWSS3LoadDestination(bucketName: String, bucketKey: String) extends LoadDestinationModel | ||
case class LoadDetails(consignmentId: UUID, recordsLoadDestination: AWSS3LoadDestination, metadataLoadDestination: AWSS3LoadDestination) extends LoadModel | ||
} |
19 changes: 0 additions & 19 deletions
19
...main/scala/uk/gov/nationalarchives/tdr/transfer/service/services/ConsignmentService.scala
This file was deleted.
Oops, something went wrong.
39 changes: 39 additions & 0 deletions
39
src/main/scala/uk/gov/nationalarchives/tdr/transfer/service/services/GraphQlApiService.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
package uk.gov.nationalarchives.tdr.transfer.service.services | ||
|
||
import cats.effect.IO | ||
import cats.implicits.{catsSyntaxApplicativeId, catsSyntaxOptionId} | ||
import com.typesafe.scalalogging.Logger | ||
import graphql.codegen.AddConsignment | ||
import sttp.client3.{Identity, SttpBackend} | ||
import uk.gov.nationalarchives.tdr.GraphQLClient | ||
import graphql.codegen.AddConsignment.{addConsignment => ac} | ||
import graphql.codegen.types.AddConsignmentInput | ||
import uk.gov.nationalarchives.tdr.keycloak.{TdrKeycloakDeployment, Token} | ||
import uk.gov.nationalarchives.tdr.transfer.service.api.model.LoadModel.LoadDetails | ||
|
||
import java.util.UUID | ||
import scala.concurrent.ExecutionContext.Implicits.global | ||
import scala.concurrent.Future | ||
|
||
class GraphQlApiService()(implicit keycloakDeployment: TdrKeycloakDeployment, backend: SttpBackend[Identity, Any]) { | ||
|
||
implicit class FutureUtils[T](f: Future[T]) { | ||
def toIO: IO[T] = IO.fromFuture(IO(f)) | ||
} | ||
|
||
private val addConsignmentClient = new GraphQLClient[ac.Data, ac.Variables]("apiUrl") | ||
|
||
def createConsignment(token: Token): IO[AddConsignment.addConsignment.AddConsignment] = { | ||
for { | ||
result <- addConsignmentClient.getResult(token.bearerAccessToken, ac.document, ac.Variables(AddConsignmentInput(None, "standard")).some).toIO | ||
data = result.data.get | ||
} yield data.addConsignment | ||
} | ||
} | ||
|
||
object GraphQlApiService { | ||
def apply()(implicit | ||
backend: SttpBackend[Identity, Any], | ||
keycloakDeployment: TdrKeycloakDeployment | ||
) = new GraphQlApiService | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,6 @@ | ||
api { | ||
port = "8080" | ||
url = "http://localhost:9001/graphql" | ||
} | ||
|
||
auth { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
{ | ||
"data": { | ||
"addConsignment": { | ||
"consignmentid": "6e3b76c4-1745-4467-8ac5-b4dd736e1b3e", | ||
"userid": "4ab14990-ed63-4615-8336-56fbb9960300", | ||
"consignmentType": "standard" | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
19 changes: 0 additions & 19 deletions
19
.../scala/uk/gov/nationalarchives/tdr/transfer/service/services/ConsignmentServiceSpec.scala
This file was deleted.
Oops, something went wrong.
91 changes: 91 additions & 0 deletions
91
...st/scala/uk/gov/nationalarchives/tdr/transfer/service/services/ExternalServicesSpec.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
package uk.gov.nationalarchives.tdr.transfer.service.services | ||
|
||
import com.github.tomakehurst.wiremock.WireMockServer | ||
import com.github.tomakehurst.wiremock.client.WireMock._ | ||
import com.github.tomakehurst.wiremock.stubbing.StubMapping | ||
import org.scalatest.concurrent.ScalaFutures | ||
import org.scalatest.flatspec.AnyFlatSpec | ||
import org.scalatest.matchers.should.Matchers | ||
import org.scalatest.time.{Millis, Seconds, Span} | ||
import org.scalatest.{BeforeAndAfterAll, BeforeAndAfterEach} | ||
|
||
import java.io.File | ||
import scala.io.Source.fromResource | ||
import scala.reflect.io.Directory | ||
|
||
class ExternalServicesSpec extends AnyFlatSpec with BeforeAndAfterEach with BeforeAndAfterAll with ScalaFutures { | ||
override implicit def patienceConfig: PatienceConfig = PatienceConfig(timeout = scaled(Span(5, Seconds)), interval = scaled(Span(100, Millis))) | ||
|
||
val wiremockGraphqlServer = new WireMockServer(9001) | ||
val wiremockAuthServer = new WireMockServer(9002) | ||
// val wiremockSsmServer = new WireMockServer(9004) | ||
// val wiremockS3 = new WireMockServer(8003) | ||
|
||
// def setupSsmServer(): Unit = { | ||
// wiremockSsmServer | ||
// .stubFor( | ||
// post(urlEqualTo("/")) | ||
// .willReturn(okJson("{\"Parameter\":{\"Name\":\"string\",\"Value\":\"string\"}}")) | ||
// ) | ||
// } | ||
|
||
val graphQlPath = "/graphql" | ||
val authPath = "/auth/realms/tdr/protocol/openid-connect/token" | ||
|
||
def graphQlUrl: String = wiremockGraphqlServer.url(graphQlPath) | ||
|
||
def graphqlOkJson(saveMetadata: Boolean = false): Unit = { | ||
wiremockGraphqlServer.stubFor( | ||
post(urlEqualTo(graphQlPath)) | ||
.withRequestBody(containing("addConsignment")) | ||
.willReturn(okJson(fromResource(s"json/add_consignment_response.json").mkString)) | ||
) | ||
|
||
wiremockGraphqlServer.stubFor( | ||
post(urlEqualTo(graphQlPath)) | ||
.withRequestBody(containing("displayProperties")) | ||
.willReturn(okJson(fromResource(s"json/display_properties.json").mkString)) | ||
) | ||
|
||
wiremockGraphqlServer.stubFor( | ||
post(urlEqualTo(graphQlPath)) | ||
.withRequestBody(containing("updateConsignmentStatus")) | ||
.willReturn(ok("""{"data": {"updateConsignmentStatus": 1}}""".stripMargin)) | ||
) | ||
if (saveMetadata) { | ||
wiremockGraphqlServer.stubFor( | ||
post(urlEqualTo(graphQlPath)) | ||
.withRequestBody(containing("addOrUpdateBulkFileMetadata")) | ||
.willReturn(ok("""{"data": {"addOrUpdateBulkFileMetadata": []}}""".stripMargin)) | ||
) | ||
} | ||
} | ||
|
||
def authOkJson(): StubMapping = wiremockAuthServer.stubFor( | ||
post(urlEqualTo(authPath)) | ||
.willReturn(okJson("""{"access_token": "abcde"}""")) | ||
) | ||
|
||
def authUnavailable: StubMapping = wiremockAuthServer.stubFor(post(urlEqualTo(authPath)).willReturn(serverError())) | ||
|
||
def graphqlUnavailable: StubMapping = wiremockGraphqlServer.stubFor(post(urlEqualTo(graphQlPath)).willReturn(serverError())) | ||
|
||
override def beforeAll(): Unit = { | ||
wiremockGraphqlServer.start() | ||
wiremockAuthServer.start() | ||
} | ||
|
||
override def afterAll(): Unit = { | ||
wiremockGraphqlServer.stop() | ||
wiremockAuthServer.stop() | ||
} | ||
|
||
override def afterEach(): Unit = { | ||
wiremockAuthServer.resetAll() | ||
wiremockGraphqlServer.resetAll() | ||
val runningFiles = new File(s"./src/test/resources/testfiles/running-files/") | ||
if (runningFiles.exists()) { | ||
new Directory(runningFiles).deleteRecursively() | ||
} | ||
} | ||
} |
Oops, something went wrong.