From f0a1f2c1aaafb636cabcb84c599d9deaa90fd373 Mon Sep 17 00:00:00 2001
From: Bassam
Date: Tue, 23 Apr 2024 23:59:28 -0400
Subject: [PATCH 01/12] feat: Vc Verification Api (#975)
Signed-off-by: Bassam Riman
Signed-off-by: Benjamin Voiturier
Co-authored-by: Benjamin Voiturier
---
.../core/model/schema/CredentialSchema.scala | 19 +-
.../core/service/CredentialServiceImpl.scala | 2 +-
.../service/verification/VcVerification.scala | 31 +
.../verification/VcVerificationService.scala | 18 +
.../VcVerificationServiceError.scala | 9 +
.../VcVerificationServiceImpl.scala | 260 ++++++++
.../VcVerificationServiceImplSpec.scala | 604 ++++++++++++++++++
.../VcVerificationServiceSpecHelper.scala | 50 ++
.../atala/pollux/vc/jwt/JWTVerification.scala | 87 ++-
.../vc/jwt/VerifiableCredentialPayload.scala | 48 +-
.../io/iohk/atala/agent/server/Main.scala | 4 +
.../atala/agent/server/PrismAgentApp.scala | 14 +-
.../controller/VcVerificationController.scala | 21 +
.../VcVerificationControllerImpl.scala | 33 +
.../controller/VcVerificationEndpoints.scala | 34 +
.../VcVerificationServerEndpoints.scala | 50 ++
.../http/ParameterizableVcVerification.scala | 18 +
.../controller/http/VcVerification.scala | 79 +++
.../http/VcVerificationParameter.scala | 42 ++
.../http/VcVerificationRequest.scala | 70 ++
.../http/VcVerificationResponse.scala | 113 ++++
.../http/VcVerificationResult.scala | 26 +
.../iohk/atala/api/util/Tapir2StaticOAS.scala | 2 +
.../VcVerificationControllerImplSpec.scala | 129 ++++
.../VcVerificationControllerTestTools.scala | 90 +++
25 files changed, 1817 insertions(+), 36 deletions(-)
create mode 100644 pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerification.scala
create mode 100644 pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationService.scala
create mode 100644 pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceError.scala
create mode 100644 pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImpl.scala
create mode 100644 pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImplSpec.scala
create mode 100644 pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationController.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationControllerImpl.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationEndpoints.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationServerEndpoints.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/ParameterizableVcVerification.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerification.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationParameter.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationRequest.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResponse.scala
create mode 100644 prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResult.scala
create mode 100644 prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerImplSpec.scala
create mode 100644 prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerTestTools.scala
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchema.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchema.scala
index 6c05b941cb..8c12ad125a 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchema.scala
+++ b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchema.scala
@@ -8,7 +8,7 @@ import io.iohk.atala.pollux.core.model.schema.`type`.{
CredentialJsonSchemaType,
CredentialSchemaType
}
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaValidatorImpl
+import io.iohk.atala.pollux.core.model.schema.validator.{JsonSchemaValidator, JsonSchemaValidatorImpl}
import io.iohk.atala.pollux.core.service.URIDereferencer
import zio.*
import zio.json.*
@@ -116,11 +116,10 @@ object CredentialSchema {
given JsonEncoder[CredentialSchema] = DeriveJsonEncoder.gen[CredentialSchema]
given JsonDecoder[CredentialSchema] = DeriveJsonDecoder.gen[CredentialSchema]
- def validateJWTClaims(
+ def validSchemaValidator(
schemaId: String,
- claims: String,
uriDereferencer: URIDereferencer
- ): IO[CredentialSchemaError, Unit] = {
+ ): IO[CredentialSchemaError, JsonSchemaValidator] = {
for {
uri <- ZIO.attempt(new URI(schemaId)).mapError(t => URISyntaxError(t.getMessage))
content <- uriDereferencer.dereference(uri).mapError(err => UnexpectedError(err.toString))
@@ -137,7 +136,17 @@ object CredentialSchema {
.mapError(error => CredentialSchemaParsingError(s"Failed to parse schema content as Json or OEA: $error"))
.flatMap(cs => JsonSchemaValidatorImpl.from(cs.schema).mapError(SchemaError.apply))
)
- _ <- schemaValidator.validate(claims).mapError(SchemaError.apply)
+ } yield schemaValidator
+ }
+
+ def validateJWTCredentialSubject(
+ schemaId: String,
+ credentialSubject: String,
+ uriDereferencer: URIDereferencer
+ ): IO[CredentialSchemaError, Unit] = {
+ for {
+ schemaValidator <- validSchemaValidator(schemaId, uriDereferencer)
+ _ <- schemaValidator.validate(credentialSubject).mapError(SchemaError.apply)
} yield ()
}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceImpl.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceImpl.scala
index 06b2af96df..9b4e5fe06e 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceImpl.scala
+++ b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceImpl.scala
@@ -139,7 +139,7 @@ private class CredentialServiceImpl(
_ <- maybeSchemaId match
case Some(schemaId) =>
CredentialSchema
- .validateJWTClaims(schemaId, claims.noSpaces, uriDereferencer)
+ .validateJWTCredentialSubject(schemaId, claims.noSpaces, uriDereferencer)
.mapError(e => CredentialSchemaError(e))
case None =>
ZIO.unit
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerification.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerification.scala
new file mode 100644
index 0000000000..670849bd89
--- /dev/null
+++ b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerification.scala
@@ -0,0 +1,31 @@
+package io.iohk.atala.pollux.core.service.verification
+
+import java.time.OffsetDateTime
+
+sealed trait VcVerification
+
+object VcVerification {
+ case object SignatureVerification extends VcVerification
+
+ case class IssuerIdentification(iss: String) extends VcVerification
+
+ case class ExpirationCheck(dateTime: OffsetDateTime) extends VcVerification
+
+ case class NotBeforeCheck(dateTime: OffsetDateTime) extends VcVerification
+
+ case class AudienceCheck(aud: String) extends VcVerification
+
+ case object SubjectVerification extends VcVerification
+
+ case object IntegrityOfClaims extends VcVerification
+
+ case object ComplianceWithStandards extends VcVerification
+
+ case object RevocationCheck extends VcVerification
+
+ case object AlgorithmVerification extends VcVerification
+
+ case object SchemaCheck extends VcVerification
+
+ case object SemanticCheckOfClaims extends VcVerification
+}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationService.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationService.scala
new file mode 100644
index 0000000000..915bd6e10b
--- /dev/null
+++ b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationService.scala
@@ -0,0 +1,18 @@
+package io.iohk.atala.pollux.core.service.verification
+
+import zio.*
+
+trait VcVerificationService {
+ def verify(request: List[VcVerificationRequest]): IO[VcVerificationServiceError, List[VcVerificationResult]]
+}
+
+final case class VcVerificationRequest(
+ credential: String,
+ verification: VcVerification,
+)
+
+final case class VcVerificationResult(
+ credential: String,
+ verification: VcVerification,
+ success: Boolean
+)
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceError.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceError.scala
new file mode 100644
index 0000000000..500fdcb052
--- /dev/null
+++ b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceError.scala
@@ -0,0 +1,9 @@
+package io.iohk.atala.pollux.core.service.verification
+
+sealed trait VcVerificationServiceError {
+ def error: String
+}
+
+object VcVerificationServiceError {
+ final case class UnexpectedError(error: String) extends VcVerificationServiceError
+}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImpl.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImpl.scala
new file mode 100644
index 0000000000..3a3665f9ab
--- /dev/null
+++ b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImpl.scala
@@ -0,0 +1,260 @@
+package io.iohk.atala.pollux.core.service.verification
+
+import io.iohk.atala.pollux.core.model.schema.CredentialSchema
+import io.iohk.atala.pollux.core.service.URIDereferencer
+import io.iohk.atala.pollux.vc.jwt.{DidResolver, JWT, JWTVerification, JwtCredential}
+import zio.{IO, *}
+
+import java.time.OffsetDateTime
+
+class VcVerificationServiceImpl(didResolver: DidResolver, uriDereferencer: URIDereferencer)
+ extends VcVerificationService {
+ override def verify(
+ vcVerificationRequests: List[VcVerificationRequest]
+ ): IO[VcVerificationServiceError, List[VcVerificationResult]] = {
+ ZIO.collectAll(
+ vcVerificationRequests.map(vcVerificationRequest =>
+ verify(vcVerificationRequest.credential, vcVerificationRequest.verification)
+ )
+ )
+ }
+
+ private def verify(
+ credential: String,
+ verification: VcVerification,
+ ): IO[VcVerificationServiceError, VcVerificationResult] = {
+ verification match {
+ case VcVerification.SchemaCheck => verifySchema(credential)
+ case VcVerification.SignatureVerification => verifySignature(credential)
+ case VcVerification.ExpirationCheck(dateTime) => verifyExpiration(credential, dateTime)
+ case VcVerification.NotBeforeCheck(dateTime) => verifyNotBefore(credential, dateTime)
+ case VcVerification.AlgorithmVerification => verifyAlgorithm(credential)
+ case VcVerification.IssuerIdentification(iss) => verifyIssuerIdentification(credential, iss)
+ case VcVerification.SubjectVerification => verifySubjectVerification(credential)
+ case VcVerification.SemanticCheckOfClaims => verifySemanticCheckOfClaims(credential)
+ case VcVerification.AudienceCheck(aud) => verifyAudienceCheck(credential, aud)
+ case _ =>
+ ZIO.fail(
+ VcVerificationServiceError.UnexpectedError(
+ s"Unsupported Verification:$verification"
+ )
+ )
+ }
+ }
+
+ private def verifySchema(credential: String): IO[VcVerificationServiceError, VcVerificationResult] = {
+ val result =
+ for {
+ decodedJwt <-
+ JwtCredential
+ .decodeJwt(JWT(credential))
+ .mapError(error => VcVerificationServiceError.UnexpectedError(s"Unable decode JWT: $error"))
+ credentialSchema <-
+ ZIO
+ .fromOption(decodedJwt.maybeCredentialSchema)
+ .mapError(error => VcVerificationServiceError.UnexpectedError(s"Missing Credential Schema: $error"))
+ result <- CredentialSchema
+ .validSchemaValidator(
+ credentialSchema.id,
+ uriDereferencer
+ )
+ .mapError(error => VcVerificationServiceError.UnexpectedError(s"Schema Validator Failed: $error"))
+ } yield result
+
+ result
+ .as(
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.SchemaCheck,
+ success = true
+ )
+ )
+ .catchAll(_ =>
+ ZIO.succeed(
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.SchemaCheck,
+ success = false
+ )
+ )
+ )
+ }
+
+ private def verifySubjectVerification(credential: String): IO[VcVerificationServiceError, VcVerificationResult] = {
+ val result =
+ for {
+ decodedJwt <-
+ JwtCredential
+ .decodeJwt(JWT(credential))
+ .mapError(error => VcVerificationServiceError.UnexpectedError(s"Unable decode JWT: $error"))
+ credentialSchema <-
+ ZIO
+ .fromOption(decodedJwt.maybeCredentialSchema)
+ .mapError(error => VcVerificationServiceError.UnexpectedError(s"Missing Credential Schema: $error"))
+ result <- CredentialSchema
+ .validateJWTCredentialSubject(
+ credentialSchema.id,
+ decodedJwt.credentialSubject.noSpaces,
+ uriDereferencer
+ )
+ .mapError(error =>
+ VcVerificationServiceError.UnexpectedError(s"JWT Credential Subject Validation Failed: $error")
+ )
+ } yield result
+
+ result
+ .as(
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.SubjectVerification,
+ success = true
+ )
+ )
+ .catchAll(_ =>
+ ZIO.succeed(
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.SubjectVerification,
+ success = false
+ )
+ )
+ )
+ }
+
+ private def verifySignature(credential: String): IO[VcVerificationServiceError, VcVerificationResult] = {
+ JwtCredential
+ .validateEncodedJWT(JWT(credential))(didResolver)
+ .mapError(error => VcVerificationServiceError.UnexpectedError(error))
+ .map(validation =>
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.SignatureVerification,
+ success = validation
+ .map(_ => true)
+ .getOrElse(false)
+ )
+ )
+ }
+
+ private def verifyExpiration(
+ credential: String,
+ dateTime: OffsetDateTime
+ ): IO[VcVerificationServiceError, VcVerificationResult] = {
+ ZIO.succeed(
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.ExpirationCheck(dateTime),
+ success = JwtCredential
+ .validateExpiration(JWT(credential), dateTime)
+ .map(_ => true)
+ .getOrElse(false)
+ )
+ )
+ }
+
+ private def verifyNotBefore(
+ credential: String,
+ dateTime: OffsetDateTime
+ ): IO[VcVerificationServiceError, VcVerificationResult] = {
+ ZIO.succeed(
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.NotBeforeCheck(dateTime),
+ success = JwtCredential
+ .validateNotBefore(JWT(credential), dateTime)
+ .map(_ => true)
+ .getOrElse(false)
+ )
+ )
+ }
+
+ private def verifyAlgorithm(credential: String): IO[VcVerificationServiceError, VcVerificationResult] = {
+ ZIO.succeed(
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.AlgorithmVerification,
+ success = JWTVerification
+ .validateAlgorithm(JWT(credential))
+ .map(_ => true)
+ .getOrElse(false)
+ )
+ )
+ }
+
+ private def verifyIssuerIdentification(
+ credential: String,
+ iss: String
+ ): IO[VcVerificationServiceError, VcVerificationResult] = {
+ val result =
+ for {
+ decodedJwt <-
+ JwtCredential
+ .decodeJwt(JWT(credential))
+ .mapError(error => VcVerificationServiceError.UnexpectedError(s"Unable decode JWT: $error"))
+ } yield decodedJwt.iss.contains(iss)
+
+ result
+ .map(success =>
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.IssuerIdentification(iss),
+ success = success
+ )
+ )
+ }
+
+ private def verifySemanticCheckOfClaims(credential: String): IO[VcVerificationServiceError, VcVerificationResult] = {
+ val result =
+ for {
+ decodedJwt <-
+ JwtCredential
+ .decodeJwt(JWT(credential))
+ .mapError(error => VcVerificationServiceError.UnexpectedError(s"Unable decode JWT: $error"))
+ } yield decodedJwt
+
+ result
+ .as(
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.SubjectVerification,
+ success = true
+ )
+ )
+ .catchAll(_ =>
+ ZIO.succeed(
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.SubjectVerification,
+ success = false
+ )
+ )
+ )
+ }
+
+ private def verifyAudienceCheck(
+ credential: String,
+ aud: String
+ ): IO[VcVerificationServiceError, VcVerificationResult] = {
+ val result =
+ for {
+ decodedJwt <-
+ JwtCredential
+ .decodeJwt(JWT(credential))
+ .mapError(error => VcVerificationServiceError.UnexpectedError(s"Unable decode JWT: $error"))
+ } yield decodedJwt.aud.contains(aud)
+
+ result
+ .map(success =>
+ VcVerificationResult(
+ credential = credential,
+ verification = VcVerification.AudienceCheck(aud),
+ success = success
+ )
+ )
+ }
+}
+
+object VcVerificationServiceImpl {
+ val layer: URLayer[DidResolver & URIDereferencer, VcVerificationService] =
+ ZLayer.fromFunction(VcVerificationServiceImpl(_, _))
+}
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImplSpec.scala b/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImplSpec.scala
new file mode 100644
index 0000000000..c621819224
--- /dev/null
+++ b/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImplSpec.scala
@@ -0,0 +1,604 @@
+package io.iohk.atala.pollux.core.service.verification
+
+import io.circe.*
+import io.circe.syntax.*
+import io.iohk.atala.agent.walletapi.service.MockManagedDIDService
+import io.iohk.atala.castor.core.service.MockDIDService
+import io.iohk.atala.pollux.core.service.ResourceURIDereferencerImpl
+import io.iohk.atala.pollux.vc.jwt.*
+import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
+import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import zio.*
+import zio.Config.OffsetDateTime
+import zio.test.*
+
+import java.time.Instant
+
+object VcVerificationServiceImplSpec extends ZIOSpecDefault with VcVerificationServiceSpecHelper {
+
+ override def spec = {
+ suite("VcVerificationServiceImpl")(
+ test("verify aud given valid") {
+ for {
+ svc <- ZIO.service[VcVerificationService]
+ verifier = DID("did:prism:verifier")
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` =
+ Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ result <-
+ svc.verify(
+ List(
+ VcVerificationRequest(signedJwtCredential.value, VcVerification.AudienceCheck(verifier.value))
+ )
+ )
+ } yield {
+ assertTrue(
+ result.contains(
+ VcVerificationResult(signedJwtCredential.value, VcVerification.AudienceCheck(verifier.value), true)
+ )
+ )
+ }
+ }.provideSomeLayer(
+ MockDIDService.empty ++
+ MockManagedDIDService.empty ++
+ ResourceURIDereferencerImpl.layer >+>
+ someVcVerificationServiceLayer ++
+ ZLayer.succeed(WalletAccessContext(WalletId.random))
+ ),
+ test("verify aud given invalid") {
+ for {
+ svc <- ZIO.service[VcVerificationService]
+ issuerDid = DID(issuerDidData.id.toString)
+ verifier = DID("did:prism:verifier")
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` =
+ Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ result <-
+ svc.verify(
+ List(
+ VcVerificationRequest(signedJwtCredential.value, VcVerification.AudienceCheck(issuer.did.value))
+ )
+ )
+ } yield {
+ assertTrue(
+ result.contains(
+ VcVerificationResult(signedJwtCredential.value, VcVerification.AudienceCheck(issuer.did.value), false)
+ )
+ )
+ }
+ }.provideSomeLayer(
+ MockDIDService.empty ++
+ MockManagedDIDService.empty ++
+ ResourceURIDereferencerImpl.layer >+>
+ someVcVerificationServiceLayer ++
+ ZLayer.succeed(WalletAccessContext(WalletId.random))
+ ),
+ test("verify signature given valid") {
+ for {
+ svc <- ZIO.service[VcVerificationService]
+ verifier = DID("did:prism:verifier")
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` =
+ Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ result <-
+ svc.verify(
+ List(
+ VcVerificationRequest(signedJwtCredential.value, VcVerification.SignatureVerification)
+ )
+ )
+ } yield {
+ assertTrue(
+ result.contains(
+ VcVerificationResult(signedJwtCredential.value, VcVerification.SignatureVerification, true)
+ )
+ )
+ }
+ }.provideSomeLayer(
+ issuerDidServiceExpectations.toLayer ++
+ MockManagedDIDService.empty ++
+ ResourceURIDereferencerImpl.layer >+>
+ someVcVerificationServiceLayer ++
+ ZLayer.succeed(WalletAccessContext(WalletId.random))
+ ),
+ test("verify issuer given valid") {
+ for {
+ svc <- ZIO.service[VcVerificationService]
+ verifier = DID("did:prism:verifier")
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` =
+ Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ result <-
+ svc.verify(
+ List(
+ VcVerificationRequest(signedJwtCredential.value, VcVerification.IssuerIdentification(issuer.did.value))
+ )
+ )
+ } yield {
+ assertTrue(
+ result.contains(
+ VcVerificationResult(
+ signedJwtCredential.value,
+ VcVerification.IssuerIdentification(issuer.did.value),
+ true
+ )
+ )
+ )
+ }
+ }.provideSomeLayer(
+ MockDIDService.empty ++
+ MockManagedDIDService.empty ++
+ ResourceURIDereferencerImpl.layer >+>
+ someVcVerificationServiceLayer ++
+ ZLayer.succeed(WalletAccessContext(WalletId.random))
+ ),
+ test("verify issuer given invalid") {
+ for {
+ svc <- ZIO.service[VcVerificationService]
+ issuerDid = DID(issuerDidData.id.toString)
+ verifier = DID("did:prism:verifier")
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` =
+ Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ result <-
+ svc.verify(
+ List(
+ VcVerificationRequest(signedJwtCredential.value, VcVerification.IssuerIdentification(verifier.value))
+ )
+ )
+ } yield {
+ assertTrue(
+ result.contains(
+ VcVerificationResult(
+ signedJwtCredential.value,
+ VcVerification.IssuerIdentification(verifier.value),
+ false
+ )
+ )
+ )
+ }
+ }.provideSomeLayer(
+ MockDIDService.empty ++
+ MockManagedDIDService.empty ++
+ ResourceURIDereferencerImpl.layer >+>
+ someVcVerificationServiceLayer ++
+ ZLayer.succeed(WalletAccessContext(WalletId.random))
+ ),
+ test("verify nbf given valid") {
+ for {
+ svc <- ZIO.service[VcVerificationService]
+ verifier = DID("did:prism:verifier")
+ currentTime = OffsetDateTime.parse("2010-01-01T00:00:00Z").toOption.get
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` =
+ Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ result <-
+ svc.verify(
+ List(
+ VcVerificationRequest(signedJwtCredential.value, VcVerification.NotBeforeCheck(currentTime))
+ )
+ )
+ } yield {
+ assertTrue(
+ result.contains(
+ VcVerificationResult(signedJwtCredential.value, VcVerification.NotBeforeCheck(currentTime), true)
+ )
+ )
+ }
+ }.provideSomeLayer(
+ MockDIDService.empty ++
+ MockManagedDIDService.empty ++
+ ResourceURIDereferencerImpl.layer >+>
+ someVcVerificationServiceLayer ++
+ ZLayer.succeed(WalletAccessContext(WalletId.random))
+ ),
+ test("verify nbf given invalid") {
+ for {
+ svc <- ZIO.service[VcVerificationService]
+ verifier = DID("did:prism:verifier")
+ currentTime = OffsetDateTime.parse("2010-01-01T00:00:00Z").toOption.get.minusDays(2)
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` =
+ Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ result <-
+ svc.verify(
+ List(
+ VcVerificationRequest(signedJwtCredential.value, VcVerification.NotBeforeCheck(currentTime))
+ )
+ )
+ } yield {
+ assertTrue(
+ result.contains(
+ VcVerificationResult(signedJwtCredential.value, VcVerification.NotBeforeCheck(currentTime), false)
+ )
+ )
+ }
+ }.provideSomeLayer(
+ MockDIDService.empty ++
+ MockManagedDIDService.empty ++
+ ResourceURIDereferencerImpl.layer >+>
+ someVcVerificationServiceLayer ++
+ ZLayer.succeed(WalletAccessContext(WalletId.random))
+ ),
+ test("verify exp given valid") {
+ for {
+ svc <- ZIO.service[VcVerificationService]
+ verifier = DID("did:prism:verifier")
+ currentTime = OffsetDateTime.parse("2010-01-01T00:00:00Z").toOption.get
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` =
+ Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ result <-
+ svc.verify(
+ List(
+ VcVerificationRequest(signedJwtCredential.value, VcVerification.ExpirationCheck(currentTime))
+ )
+ )
+ } yield {
+ assertTrue(
+ result.contains(
+ VcVerificationResult(signedJwtCredential.value, VcVerification.ExpirationCheck(currentTime), true)
+ )
+ )
+ }
+ }.provideSomeLayer(
+ MockDIDService.empty ++
+ MockManagedDIDService.empty ++
+ ResourceURIDereferencerImpl.layer >+>
+ someVcVerificationServiceLayer ++
+ ZLayer.succeed(WalletAccessContext(WalletId.random))
+ ),
+ test("verify exp given invalid") {
+ for {
+ svc <- ZIO.service[VcVerificationService]
+ verifier = DID("did:prism:verifier")
+ currentTime = OffsetDateTime.parse("2010-01-12T00:00:00Z").toOption.get
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` =
+ Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ result <-
+ svc.verify(
+ List(
+ VcVerificationRequest(signedJwtCredential.value, VcVerification.ExpirationCheck(currentTime))
+ )
+ )
+ } yield {
+ assertTrue(
+ result.contains(
+ VcVerificationResult(signedJwtCredential.value, VcVerification.ExpirationCheck(currentTime), false)
+ )
+ )
+ }
+ }.provideSomeLayer(
+ MockDIDService.empty ++
+ MockManagedDIDService.empty ++
+ ResourceURIDereferencerImpl.layer >+>
+ someVcVerificationServiceLayer ++
+ ZLayer.succeed(WalletAccessContext(WalletId.random))
+ )
+ )
+ }
+}
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala b/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala
new file mode 100644
index 0000000000..a4778a9072
--- /dev/null
+++ b/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala
@@ -0,0 +1,50 @@
+package io.iohk.atala.pollux.core.service.verification
+
+import io.iohk.atala.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
+import io.iohk.atala.castor.core.model.did.VerificationRelationship
+import io.iohk.atala.castor.core.service.{DIDService, MockDIDService}
+import io.iohk.atala.pollux.core.service.{ResourceURIDereferencerImpl, URIDereferencer}
+import io.iohk.atala.pollux.vc.jwt.*
+import io.iohk.atala.shared.models.WalletId.*
+import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import zio.*
+import zio.mock.Expectation
+
+trait VcVerificationServiceSpecHelper {
+ protected val defaultWalletLayer: ULayer[WalletAccessContext] = ZLayer.succeed(WalletAccessContext(WalletId.default))
+
+ protected val (issuerOp, issuerKp, issuerDidMetadata, issuerDidData) =
+ MockDIDService.createDID(VerificationRelationship.AssertionMethod)
+
+ protected val issuer =
+ Issuer(
+ did = io.iohk.atala.pollux.vc.jwt.DID(issuerDidData.id.did.toString),
+ signer = ES256KSigner(issuerKp.privateKey.toJavaPrivateKey),
+ publicKey = issuerKp.publicKey.toJavaPublicKey
+ )
+
+ protected val issuerDidServiceExpectations: Expectation[DIDService] =
+ MockDIDService.resolveDIDExpectation(issuerDidMetadata, issuerDidData)
+
+ protected val issuerManagedDIDServiceExpectations: Expectation[ManagedDIDService] =
+ MockManagedDIDService.getManagedDIDStateExpectation(issuerOp)
+ ++ MockManagedDIDService.javaKeyPairWithDIDExpectation(issuerKp)
+
+ protected val issuerDidResolverLayer: ZLayer[Any, Nothing, PrismDidResolver] = (issuerDidServiceExpectations ++
+ issuerManagedDIDServiceExpectations).toLayer >>> ZLayer.fromFunction(PrismDidResolver(_))
+
+ protected val emptyDidResolverLayer: ZLayer[Any, Nothing, PrismDidResolver] = MockDIDService.empty ++
+ MockManagedDIDService.empty >>> ZLayer.fromFunction(PrismDidResolver(_))
+
+ protected val vcVerificationServiceLayer: ZLayer[Any, Nothing, VcVerificationService with WalletAccessContext] =
+ emptyDidResolverLayer ++ ResourceURIDereferencerImpl.layer >>>
+ VcVerificationServiceImpl.layer ++ defaultWalletLayer
+
+ protected val someVcVerificationServiceLayer
+ : URLayer[DIDService & ManagedDIDService & URIDereferencer, VcVerificationService] =
+ ZLayer.makeSome[DIDService & ManagedDIDService & URIDereferencer, VcVerificationService](
+ ZLayer.fromFunction(PrismDidResolver(_)),
+ VcVerificationServiceImpl.layer
+ )
+
+}
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala b/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala
index 873be46f23..4b2a21d43c 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala
+++ b/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala
@@ -1,19 +1,20 @@
package io.iohk.atala.pollux.vc.jwt
+
+import com.nimbusds.jose.JWSVerifier
import com.nimbusds.jose.crypto.ECDSAVerifier
+import com.nimbusds.jose.crypto.bc.BouncyCastleProviderSingleton
import com.nimbusds.jose.jwk.*
import com.nimbusds.jose.util.Base64URL
-import com.nimbusds.jose.JWSVerifier
-import com.nimbusds.jose.crypto.bc.BouncyCastleProviderSingleton
import com.nimbusds.jwt.SignedJWT
import io.circe
import io.circe.generic.auto.*
import io.iohk.atala.castor.core.model.did.VerificationRelationship
import pdi.jwt.*
-import zio.prelude.*
import zio.*
+import zio.prelude.*
-import java.security.interfaces.ECPublicKey
import java.security.PublicKey
+import java.security.interfaces.ECPublicKey
import scala.util.{Failure, Success, Try}
object JWTVerification {
@@ -24,25 +25,49 @@ object JWTVerification {
"ES256" -> Set("ES256") // TODO: Only use valid type (added just for compatibility in the Demo code)
)
- def validateEncodedJwt[T](jwt: JWT, proofPurpose: Option[VerificationRelationship] = None)(
- didResolver: DidResolver
- )(decoder: String => Validation[String, T])(issuerDidExtractor: T => String): IO[String, Validation[String, Unit]] = {
- val decodeJWT = Validation
- .fromTry(JwtCirce.decodeRawAll(jwt.value, JwtOptions(false, false, false)))
- .mapError(_.getMessage)
+ def validateAlgorithm(jwt: JWT): Validation[String, Unit] = {
+ val decodedJWT =
+ Validation
+ .fromTry(JwtCirce.decodeRawAll(jwt.value, JwtOptions(false, false, false)))
+ .mapError(_.getMessage)
+ for {
+ decodedJwtTask <- decodedJWT
+ (header, _, _) = decodedJwtTask
+ algorithm <- Validation
+ .fromOptionWith("An algorithm must be specified in the header")(JwtCirce.parseHeader(header).algorithm)
+ result <-
+ Validation
+ .fromPredicateWith("Algorithm Not Supported")(
+ SUPPORT_PUBLIC_KEY_TYPES.getOrElse(algorithm.name, Set.empty)
+ )(_.nonEmpty)
+ .flatMap(_ => Validation.unit)
- val extractAlgorithm: Validation[String, JwtAlgorithm] =
+ } yield result
+ }
+
+ def validateIssuer[T](jwt: JWT)(didResolver: DidResolver)(
+ decoder: String => Validation[String, T]
+ )(issuerDidExtractor: T => String): IO[String, Validation[String, DIDDocument]] = {
+ val decodedJWT =
+ Validation
+ .fromTry(JwtCirce.decodeRawAll(jwt.value, JwtOptions(false, false, false)))
+ .mapError(_.getMessage)
+
+ val claim: Validation[String, String] =
for {
- decodedJwtTask <- decodeJWT
- (header, _, _) = decodedJwtTask
- algorithm <- Validation
- .fromOptionWith("An algorithm must be specified in the header")(JwtCirce.parseHeader(header).algorithm)
- } yield algorithm
+ decodedJwtTask <- decodedJWT
+ (_, claim, _) = decodedJwtTask
+ } yield claim
+ validateIssuerFromClaim(claim)(didResolver)(decoder)(issuerDidExtractor)
+ }
+
+ def validateIssuerFromClaim[T](validatedClaim: Validation[String, String])(didResolver: DidResolver)(
+ decoder: String => Validation[String, T]
+ )(issuerDidExtractor: T => String): IO[String, Validation[String, DIDDocument]] = {
val validatedIssuerDid: Validation[String, String] =
for {
- decodedJwtTask <- decodeJWT
- (_, claim, _) = decodedJwtTask
+ claim <- validatedClaim
decodedClaim <- decoder(claim)
extractIssuerDid = issuerDidExtractor(decodedClaim)
} yield extractIssuerDid
@@ -55,6 +80,32 @@ object JWTVerification {
)(identity)
.map(b => b.flatten)
+ loadDidDocument
+ }
+
+ def validateEncodedJwt[T](jwt: JWT, proofPurpose: Option[VerificationRelationship] = None)(
+ didResolver: DidResolver
+ )(decoder: String => Validation[String, T])(issuerDidExtractor: T => String): IO[String, Validation[String, Unit]] = {
+ val decodedJWT = Validation
+ .fromTry(JwtCirce.decodeRawAll(jwt.value, JwtOptions(false, false, false)))
+ .mapError(_.getMessage)
+
+ val extractAlgorithm: Validation[String, JwtAlgorithm] =
+ for {
+ decodedJwtTask <- decodedJWT
+ (header, _, _) = decodedJwtTask
+ algorithm <- Validation
+ .fromOptionWith("An algorithm must be specified in the header")(JwtCirce.parseHeader(header).algorithm)
+ } yield algorithm
+
+ val claim: Validation[String, String] =
+ for {
+ decodedJwtTask <- decodedJWT
+ (_, claim, _) = decodedJwtTask
+ } yield claim
+
+ val loadDidDocument = validateIssuerFromClaim(claim)(didResolver)(decoder)(issuerDidExtractor)
+
loadDidDocument
.map(validatedDidDocument => {
for {
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala b/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala
index c37183b110..aba96e8f76 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala
+++ b/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala
@@ -1,21 +1,21 @@
package io.iohk.atala.pollux.vc.jwt
import io.circe
+import io.circe.*
import io.circe.generic.auto.*
import io.circe.parser.decode
import io.circe.syntax.*
-import io.circe.{CursorOp, Decoder, DecodingFailure, Encoder, HCursor, Json}
import io.iohk.atala.castor.core.model.did.VerificationRelationship
import io.iohk.atala.pollux.vc.jwt.revocation.BitString
import io.iohk.atala.pollux.vc.jwt.schema.{SchemaResolver, SchemaValidator}
import io.iohk.atala.shared.http.UriResolver
import pdi.jwt.*
-import zio.prelude.*
import zio.*
+import zio.prelude.*
import java.security.PublicKey
import java.time.temporal.TemporalAmount
-import java.time.{Clock, Instant}
+import java.time.{Clock, Instant, OffsetDateTime, ZoneId}
import scala.util.Try
opaque type DID = String
@@ -716,6 +716,20 @@ object JwtCredential {
.flatMap(decode[JwtCredentialPayload](_).toTry)
}
+ def decodeJwt(jwt: JWT): IO[String, JwtCredentialPayload] = {
+ val decodeJWT =
+ ZIO.fromTry(JwtCirce.decodeRawAll(jwt.value, JwtOptions(false, false, false))).mapError(_.getMessage)
+
+ val validatedDecodedClaim: IO[String, JwtCredentialPayload] =
+ for {
+ decodedJwtTask <- decodeJWT
+ (_, claim, _) = decodedJwtTask
+ decodedClaim <- ZIO.fromEither(decode[JwtCredentialPayload](claim).left.map(_.toString))
+ } yield decodedClaim
+
+ validatedDecodedClaim
+ }
+
def validateEncodedJwt(jwt: JWT, publicKey: PublicKey): Boolean =
JwtCirce.isValid(jwt.value, publicKey, JwtOptions(expiration = false, notBefore = false))
@@ -728,6 +742,14 @@ object JwtCredential {
)(_.iss)
}
+ def validateIssuerJWT(
+ jwt: JWT,
+ )(didResolver: DidResolver): IO[String, Validation[String, DIDDocument]] = {
+ JWTVerification.validateIssuer(jwt)(didResolver: DidResolver)(claim =>
+ Validation.fromEither(decode[JwtCredentialPayload](claim).left.map(_.toString))
+ )(_.iss)
+ }
+
def validateJwtSchema(
jwt: JWT
)(schemaResolver: SchemaResolver)(
@@ -750,6 +772,26 @@ object JwtCredential {
)(_.replicateZIODiscard(1))
}
+ def validateExpiration(jwt: JWT, dateTime: OffsetDateTime): Validation[String, Unit] = {
+ Validation
+ .fromTry(
+ JwtCirce(Clock.fixed(dateTime.toInstant, ZoneId.of(dateTime.getOffset.getId)))
+ .decodeRawAll(jwt.value, JwtOptions(false, true, false))
+ )
+ .flatMap(_ => Validation.unit)
+ .mapError(_.getMessage)
+ }
+
+ def validateNotBefore(jwt: JWT, dateTime: OffsetDateTime): Validation[String, Unit] = {
+ Validation
+ .fromTry(
+ JwtCirce(Clock.fixed(dateTime.toInstant, ZoneId.of(dateTime.getOffset.getId)))
+ .decodeRawAll(jwt.value, JwtOptions(false, false, true))
+ )
+ .flatMap(_ => Validation.unit)
+ .mapError(_.getMessage)
+ }
+
def validateSchemaAndSignature(
jwt: JWT
)(didResolver: DidResolver)(schemaResolver: SchemaResolver)(
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Main.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Main.scala
index 5661ded955..b12d7fbdf0 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Main.scala
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Main.scala
@@ -30,6 +30,7 @@ import io.iohk.atala.iam.wallet.http.controller.WalletManagementControllerImpl
import io.iohk.atala.issue.controller.IssueControllerImpl
import io.iohk.atala.mercury.*
import io.iohk.atala.pollux.core.service.*
+import io.iohk.atala.pollux.core.service.verification.VcVerificationServiceImpl
import io.iohk.atala.pollux.credentialdefinition.controller.CredentialDefinitionControllerImpl
import io.iohk.atala.pollux.credentialschema.controller.{
CredentialSchemaController,
@@ -48,6 +49,7 @@ import io.iohk.atala.pollux.sql.repository.{
import io.iohk.atala.presentproof.controller.PresentProofControllerImpl
import io.iohk.atala.resolvers.DIDResolver
import io.iohk.atala.system.controller.SystemControllerImpl
+import io.iohk.atala.verification.controller.VcVerificationControllerImpl
import io.micrometer.prometheus.{PrometheusConfig, PrometheusMeterRegistry}
import zio.*
import zio.metrics.connectors.micrometer
@@ -145,6 +147,7 @@ object MainApp extends ZIOAppDefault {
IssueControllerImpl.layer,
CredentialStatusControllerImpl.layer,
PresentProofControllerImpl.layer,
+ VcVerificationControllerImpl.layer,
VerificationPolicyControllerImpl.layer,
EntityControllerImpl.layer,
WalletManagementControllerImpl.layer,
@@ -167,6 +170,7 @@ object MainApp extends ZIOAppDefault {
LinkSecretServiceImpl.layer >>> PresentationServiceImpl.layer >>> PresentationServiceNotifier.layer,
VerificationPolicyServiceImpl.layer,
WalletManagementServiceImpl.layer,
+ VcVerificationServiceImpl.layer,
// authentication
AppModule.builtInAuthenticatorLayer,
AppModule.keycloakAuthenticatorLayer,
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/PrismAgentApp.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/PrismAgentApp.scala
index 253dc6a645..a8950f0c1b 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/PrismAgentApp.scala
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/PrismAgentApp.scala
@@ -3,13 +3,7 @@ package io.iohk.atala.agent.server
import io.iohk.atala.agent.notification.WebhookPublisher
import io.iohk.atala.agent.server.config.AppConfig
import io.iohk.atala.agent.server.http.{ZHttp4sBlazeServer, ZHttpEndpoints}
-import io.iohk.atala.agent.server.jobs.{
- ConnectBackgroundJobs,
- DIDStateSyncBackgroundJobs,
- IssueBackgroundJobs,
- PresentBackgroundJobs,
- StatusListJobs
-}
+import io.iohk.atala.agent.server.jobs.*
import io.iohk.atala.agent.walletapi.model.{Entity, Wallet, WalletSeed}
import io.iohk.atala.agent.walletapi.service.{EntityService, ManagedDIDService, WalletManagementService}
import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
@@ -31,10 +25,10 @@ import io.iohk.atala.pollux.credentialschema.{SchemaRegistryServerEndpoints, Ver
import io.iohk.atala.pollux.vc.jwt.DidResolver as JwtDidResolver
import io.iohk.atala.presentproof.controller.PresentProofServerEndpoints
import io.iohk.atala.resolvers.DIDResolver
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.{HexString, WalletAccessContext, WalletId}
+import io.iohk.atala.shared.models.{HexString, WalletAccessContext, WalletAdministrationContext, WalletId}
import io.iohk.atala.shared.utils.DurationOps.toMetricsSeconds
import io.iohk.atala.system.controller.SystemServerEndpoints
+import io.iohk.atala.verification.controller.VcVerificationServerEndpoints
import zio.*
import zio.metrics.*
@@ -133,6 +127,7 @@ object AgentHttpServer {
allDIDEndpoints <- DIDServerEndpoints.all
allDIDRegistrarEndpoints <- DIDRegistrarServerEndpoints.all
allPresentProofEndpoints <- PresentProofServerEndpoints.all
+ allVcVerificationEndpoints <- VcVerificationServerEndpoints.all
allSystemEndpoints <- SystemServerEndpoints.all
allEntityEndpoints <- EntityServerEndpoints.all
allWalletManagementEndpoints <- WalletManagementServerEndpoints.all
@@ -146,6 +141,7 @@ object AgentHttpServer {
allIssueEndpoints ++
allStatusListEndpoints ++
allPresentProofEndpoints ++
+ allVcVerificationEndpoints ++
allSystemEndpoints ++
allEntityEndpoints ++
allWalletManagementEndpoints ++
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationController.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationController.scala
new file mode 100644
index 0000000000..b08e735a77
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationController.scala
@@ -0,0 +1,21 @@
+package io.iohk.atala.verification.controller
+
+import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
+import io.iohk.atala.pollux.core.service.verification.VcVerificationServiceError
+import io.iohk.atala.verification.controller
+import zio.*
+
+trait VcVerificationController {
+
+ def verify(request: List[controller.http.VcVerificationRequest])(implicit
+ rc: RequestContext
+ ): IO[ErrorResponse, List[controller.http.VcVerificationResponse]]
+}
+
+object VcVerificationController {
+ def toHttpError(error: VcVerificationServiceError): ErrorResponse =
+ error match
+ case VcVerificationServiceError.UnexpectedError(error) =>
+ ErrorResponse.badRequest(detail = Some(s"VC Verification Failed: $error"))
+
+}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationControllerImpl.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationControllerImpl.scala
new file mode 100644
index 0000000000..200cb4e421
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationControllerImpl.scala
@@ -0,0 +1,33 @@
+package io.iohk.atala.verification.controller
+
+import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
+import io.iohk.atala.pollux.core.service.verification.VcVerificationService
+import io.iohk.atala.verification.controller
+import zio.*
+
+class VcVerificationControllerImpl(vcVerificationService: VcVerificationService) extends VcVerificationController {
+
+ override def verify(
+ requests: List[controller.http.VcVerificationRequest]
+ )(implicit rc: RequestContext): IO[ErrorResponse, List[controller.http.VcVerificationResponse]] = {
+ ZIO.collectAll(
+ requests.map(request => {
+ for {
+ serviceRequests <- controller.http.VcVerificationRequest.toService(request)
+ results <-
+ vcVerificationService
+ .verify(serviceRequests)
+ .mapError(error => VcVerificationController.toHttpError(error))
+ } yield controller.http.VcVerificationResponse(
+ request.credential,
+ results.map(result => controller.http.VcVerificationResult.toService(result))
+ )
+ })
+ )
+ }
+}
+
+object VcVerificationControllerImpl {
+ val layer: URLayer[VcVerificationService, VcVerificationController] =
+ ZLayer.fromFunction(VcVerificationControllerImpl(_))
+}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationEndpoints.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationEndpoints.scala
new file mode 100644
index 0000000000..f81c951fec
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationEndpoints.scala
@@ -0,0 +1,34 @@
+package io.iohk.atala.verification.controller
+
+import io.iohk.atala.api.http.EndpointOutputs.*
+import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
+import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
+import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import io.iohk.atala.iam.authentication.oidc.JwtCredentials
+import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import sttp.model.StatusCode
+import sttp.tapir.*
+import sttp.tapir.json.zio.jsonBody
+
+object VcVerificationEndpoints {
+ val verify: Endpoint[
+ (ApiKeyCredentials, JwtCredentials),
+ (RequestContext, List[http.VcVerificationRequest]),
+ ErrorResponse,
+ List[http.VcVerificationResponse],
+ Any
+ ] =
+ endpoint.get
+ .tag("Verifiable Credentials Verification")
+ .name("verify")
+ .summary("As a Verifier, verify a set of credentials")
+ .description("As a Verifier, verify a set of credentials")
+ .securityIn(apiKeyHeader)
+ .securityIn(jwtAuthHeader)
+ .in("verification" / "credential")
+ .in(extractFromRequest[RequestContext](RequestContext.apply))
+ .in(jsonBody[List[http.VcVerificationRequest]].description("List of VC to verify"))
+ .out(statusCode(StatusCode.Ok).description("List of VC verification outcome"))
+ .out(jsonBody[List[http.VcVerificationResponse]])
+ .errorOut(basicFailuresAndForbidden)
+}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationServerEndpoints.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationServerEndpoints.scala
new file mode 100644
index 0000000000..2cc01ce215
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationServerEndpoints.scala
@@ -0,0 +1,50 @@
+package io.iohk.atala.verification.controller
+
+import io.iohk.atala.LogUtils.*
+import io.iohk.atala.agent.walletapi.model.BaseEntity
+import io.iohk.atala.api.http.RequestContext
+import io.iohk.atala.iam.authentication.{Authenticator, Authorizer, DefaultAuthenticator, SecurityLogic}
+import io.iohk.atala.shared.models.WalletAccessContext
+import io.iohk.atala.verification.controller
+import io.iohk.atala.verification.controller.VcVerificationEndpoints.verify
+import sttp.tapir.ztapir.*
+import zio.*
+
+class VcVerificationServerEndpoints(
+ vcVerificationController: VcVerificationController,
+ authenticator: Authenticator[BaseEntity],
+ authorizer: Authorizer[BaseEntity]
+) {
+
+ val verifyEndpoint: ZServerEndpoint[Any, Any] =
+ verify
+ .zServerSecurityLogic(SecurityLogic.authorizeWalletAccessWith(_)(authenticator, authorizer))
+ .serverLogic { wac =>
+ { case (ctx: RequestContext, request: List[controller.http.VcVerificationRequest]) =>
+ vcVerificationController
+ .verify(request)(ctx)
+ .provideSomeLayer(ZLayer.succeed(wac))
+ .logTrace(ctx)
+ }
+ }
+
+ val all: List[ZServerEndpoint[Any, Any]] = List(
+ verifyEndpoint
+ )
+
+}
+
+object VcVerificationServerEndpoints {
+ def all: URIO[VcVerificationController & DefaultAuthenticator, List[ZServerEndpoint[Any, Any]]] = {
+ for {
+ authenticator <- ZIO.service[DefaultAuthenticator]
+ vcVerificationController <- ZIO.service[VcVerificationController]
+ vcVerificationProofEndpoints =
+ new VcVerificationServerEndpoints(
+ vcVerificationController,
+ authenticator,
+ authenticator
+ )
+ } yield vcVerificationProofEndpoints.all
+ }
+}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/ParameterizableVcVerification.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/ParameterizableVcVerification.scala
new file mode 100644
index 0000000000..8994cedf77
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/ParameterizableVcVerification.scala
@@ -0,0 +1,18 @@
+package io.iohk.atala.verification.controller.http
+
+import sttp.tapir.Schema
+import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
+
+final case class ParameterizableVcVerification(
+ verification: VcVerification,
+ parameter: Option[VcVerificationParameter]
+)
+object ParameterizableVcVerification {
+ given encoder: JsonEncoder[ParameterizableVcVerification] =
+ DeriveJsonEncoder.gen[ParameterizableVcVerification]
+
+ given decoder: JsonDecoder[ParameterizableVcVerification] =
+ DeriveJsonDecoder.gen[ParameterizableVcVerification]
+
+ given schema: Schema[ParameterizableVcVerification] = Schema.derived
+}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerification.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerification.scala
new file mode 100644
index 0000000000..345e582714
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerification.scala
@@ -0,0 +1,79 @@
+package io.iohk.atala.verification.controller.http
+
+import io.iohk.atala.api.http.ErrorResponse
+import io.iohk.atala.pollux.core.service
+import io.iohk.atala.pollux.core.service.verification.VcVerification as ServiceVcVerification
+import sttp.tapir.Schema
+import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
+import zio.{IO, *}
+
+enum VcVerification {
+ case SignatureVerification
+ case IssuerIdentification
+ case ExpirationCheck
+ case NotBeforeCheck
+ case AudienceCheck
+ case SubjectVerification
+ case IntegrityOfClaims
+ case ComplianceWithStandards
+ case RevocationCheck
+ case AlgorithmVerification
+ case SchemaCheck
+ case SemanticCheckOfClaims
+}
+
+object VcVerification {
+ given encoder: JsonEncoder[VcVerification] =
+ DeriveJsonEncoder.gen[VcVerification]
+
+ given decoder: JsonDecoder[VcVerification] =
+ DeriveJsonDecoder.gen[VcVerification]
+
+ given schema: Schema[VcVerification] = Schema.derivedEnumeration.defaultStringBased
+
+ def convert(
+ verification: VcVerification,
+ maybeParameter: Option[VcVerificationParameter]
+ ): IO[ErrorResponse, ServiceVcVerification] = {
+ (verification, maybeParameter) match {
+ case (SignatureVerification, None) => ZIO.succeed(ServiceVcVerification.SignatureVerification)
+ case (IssuerIdentification, Some(DidParameter(iss))) =>
+ ZIO.succeed(ServiceVcVerification.IssuerIdentification(iss))
+ case (ExpirationCheck, Some(DateTimeParameter(dateTime))) =>
+ ZIO.succeed(ServiceVcVerification.ExpirationCheck(dateTime))
+ case (NotBeforeCheck, Some(DateTimeParameter(dateTime))) =>
+ ZIO.succeed(ServiceVcVerification.NotBeforeCheck(dateTime))
+ case (AudienceCheck, Some(DidParameter(aud))) => ZIO.succeed(ServiceVcVerification.AudienceCheck(aud))
+ case (SubjectVerification, None) => ZIO.succeed(ServiceVcVerification.SubjectVerification)
+ case (IntegrityOfClaims, None) => ZIO.succeed(ServiceVcVerification.IntegrityOfClaims)
+ case (ComplianceWithStandards, None) => ZIO.succeed(ServiceVcVerification.ComplianceWithStandards)
+ case (RevocationCheck, None) => ZIO.succeed(ServiceVcVerification.RevocationCheck)
+ case (AlgorithmVerification, None) => ZIO.succeed(ServiceVcVerification.AlgorithmVerification)
+ case (SchemaCheck, None) => ZIO.succeed(ServiceVcVerification.SchemaCheck)
+ case (SemanticCheckOfClaims, None) => ZIO.succeed(ServiceVcVerification.SemanticCheckOfClaims)
+ case _ =>
+ ZIO.fail(
+ ErrorResponse.badRequest(detail =
+ Some(s"Unsupported Verification:$verification and Parameters:$maybeParameter")
+ )
+ )
+ }
+ }
+
+ def toService(verification: ServiceVcVerification): VcVerification = {
+ verification match {
+ case ServiceVcVerification.SignatureVerification => SignatureVerification
+ case ServiceVcVerification.IssuerIdentification(_) => IssuerIdentification
+ case ServiceVcVerification.ExpirationCheck(_) => ExpirationCheck
+ case ServiceVcVerification.NotBeforeCheck(_) => NotBeforeCheck
+ case ServiceVcVerification.AudienceCheck(_) => AudienceCheck
+ case ServiceVcVerification.SubjectVerification => SubjectVerification
+ case ServiceVcVerification.IntegrityOfClaims => IntegrityOfClaims
+ case ServiceVcVerification.ComplianceWithStandards => ComplianceWithStandards
+ case ServiceVcVerification.RevocationCheck => RevocationCheck
+ case ServiceVcVerification.AlgorithmVerification => AlgorithmVerification
+ case ServiceVcVerification.SchemaCheck => SchemaCheck
+ case ServiceVcVerification.SemanticCheckOfClaims => SemanticCheckOfClaims
+ }
+ }
+}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationParameter.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationParameter.scala
new file mode 100644
index 0000000000..66ca951fcb
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationParameter.scala
@@ -0,0 +1,42 @@
+package io.iohk.atala.verification.controller.http
+
+import sttp.tapir.Schema
+import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
+
+import java.time.OffsetDateTime
+
+sealed trait VcVerificationParameter
+
+object VcVerificationParameter {
+ given encoder: JsonEncoder[VcVerificationParameter] =
+ DeriveJsonEncoder.gen[VcVerificationParameter]
+
+ given decoder: JsonDecoder[VcVerificationParameter] =
+ DeriveJsonDecoder.gen[VcVerificationParameter]
+
+ given schema: Schema[VcVerificationParameter] = Schema.derived
+}
+
+case class DidParameter(aud: String) extends VcVerificationParameter
+
+object DidParameter {
+ given encoder: JsonEncoder[DidParameter] =
+ DeriveJsonEncoder.gen[DidParameter]
+
+ given decoder: JsonDecoder[DidParameter] =
+ DeriveJsonDecoder.gen[DidParameter]
+
+ given schema: Schema[DidParameter] = Schema.derived
+}
+
+case class DateTimeParameter(dateTime: OffsetDateTime) extends VcVerificationParameter
+
+object DateTimeParameter {
+ given encoder: JsonEncoder[DateTimeParameter] =
+ DeriveJsonEncoder.gen[DateTimeParameter]
+
+ given decoder: JsonDecoder[DateTimeParameter] =
+ DeriveJsonDecoder.gen[DateTimeParameter]
+
+ given schema: Schema[DateTimeParameter] = Schema.derived
+}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationRequest.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationRequest.scala
new file mode 100644
index 0000000000..dd7602b3d0
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationRequest.scala
@@ -0,0 +1,70 @@
+package io.iohk.atala.verification.controller.http
+
+import io.iohk.atala.api.http.{Annotation, ErrorResponse}
+import io.iohk.atala.pollux.core.service.verification.VcVerificationRequest as ServiceVcVerificationRequest
+import sttp.tapir.Schema
+import sttp.tapir.Schema.annotations.{description, encodedExample}
+import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
+import zio.{IO, *}
+
+final case class VcVerificationRequest(
+ @description(VcVerificationRequest.annotations.credential.description)
+ @encodedExample(VcVerificationRequest.annotations.credential.example)
+ credential: String,
+ @description(VcVerificationRequest.annotations.vcVerification.description)
+ @encodedExample(VcVerificationRequest.annotations.vcVerification.example)
+ verifications: List[ParameterizableVcVerification]
+)
+
+object VcVerificationRequest {
+ object annotations {
+
+ object credential
+ extends Annotation[String](
+ description = "Encoded Verifiable Credential to verify",
+ example =
+ "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c"
+ )
+
+ object vcVerification
+ extends Annotation[List[VcVerification]](
+ description = "The list of Verifications to verify. All verifications run if Verifications left empty",
+ example = List(
+ VcVerification.SignatureVerification,
+ VcVerification.IssuerIdentification,
+ VcVerification.ExpirationCheck,
+ VcVerification.NotBeforeCheck,
+ VcVerification.AudienceCheck,
+ VcVerification.SubjectVerification,
+ VcVerification.IntegrityOfClaims,
+ VcVerification.ComplianceWithStandards,
+ VcVerification.RevocationCheck,
+ VcVerification.AlgorithmVerification,
+ VcVerification.SchemaCheck,
+ VcVerification.SemanticCheckOfClaims,
+ )
+ )
+ }
+
+ given credentialVerificationRequestEncoder: JsonEncoder[VcVerificationRequest] =
+ DeriveJsonEncoder.gen[VcVerificationRequest]
+
+ given credentialVerificationRequestDecoder: JsonDecoder[VcVerificationRequest] =
+ DeriveJsonDecoder.gen[VcVerificationRequest]
+
+ given credentialVerificationRequestSchema: Schema[VcVerificationRequest] = Schema.derived
+
+ def toService(request: VcVerificationRequest): IO[ErrorResponse, List[ServiceVcVerificationRequest]] = {
+ ZIO.collectAll(
+ request.verifications.map(verification =>
+ for {
+ serviceVerification <- VcVerification.convert(
+ verification.verification,
+ verification.parameter
+ )
+
+ } yield ServiceVcVerificationRequest(credential = request.credential, verification = serviceVerification)
+ )
+ )
+ }
+}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResponse.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResponse.scala
new file mode 100644
index 0000000000..70e4ee35bc
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResponse.scala
@@ -0,0 +1,113 @@
+package io.iohk.atala.verification.controller.http
+
+import io.iohk.atala.api.http.Annotation
+import sttp.tapir.Schema
+import sttp.tapir.Schema.annotations.{description, encodedExample}
+import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
+
+final case class VcVerificationResponse(
+ @description(VcVerificationResponse.annotations.credential.description)
+ @encodedExample(VcVerificationResponse.annotations.credential.example)
+ credential: String,
+ @description(VcVerificationResponse.annotations.checks.description)
+ @encodedExample(VcVerificationResponse.annotations.checks.example)
+ result: List[VcVerificationResult],
+)
+
+object VcVerificationResponse {
+
+ object annotations {
+
+ object credential
+ extends Annotation[String](
+ description = "Encoded Verifiable Credential to verify",
+ example =
+ "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c"
+ )
+
+ object checks
+ extends Annotation[List[VcVerification]](
+ description = "The list executed Verifications",
+ example = List(
+ VcVerification.SignatureVerification,
+ VcVerification.IssuerIdentification,
+ VcVerification.ExpirationCheck,
+ VcVerification.NotBeforeCheck,
+ VcVerification.AudienceCheck,
+ VcVerification.SubjectVerification,
+ VcVerification.IntegrityOfClaims,
+ VcVerification.ComplianceWithStandards,
+ VcVerification.RevocationCheck,
+ VcVerification.AlgorithmVerification,
+ VcVerification.SchemaCheck,
+ VcVerification.SemanticCheckOfClaims,
+ )
+ )
+
+ object successfulChecks
+ extends Annotation[List[VcVerification]](
+ description = "The list of successful Verifications",
+ example = List(
+ VcVerification.SignatureVerification,
+ VcVerification.IssuerIdentification,
+ VcVerification.ExpirationCheck,
+ VcVerification.NotBeforeCheck,
+ VcVerification.AudienceCheck,
+ VcVerification.SubjectVerification,
+ VcVerification.IntegrityOfClaims,
+ VcVerification.ComplianceWithStandards,
+ VcVerification.RevocationCheck,
+ VcVerification.AlgorithmVerification,
+ VcVerification.SchemaCheck,
+ VcVerification.SemanticCheckOfClaims,
+ )
+ )
+
+ object failedChecks
+ extends Annotation[List[VcVerification]](
+ description = "The list of failed Verifications.",
+ example = List(
+ VcVerification.SignatureVerification,
+ VcVerification.IssuerIdentification,
+ VcVerification.ExpirationCheck,
+ VcVerification.NotBeforeCheck,
+ VcVerification.AudienceCheck,
+ VcVerification.SubjectVerification,
+ VcVerification.IntegrityOfClaims,
+ VcVerification.ComplianceWithStandards,
+ VcVerification.RevocationCheck,
+ VcVerification.AlgorithmVerification,
+ VcVerification.SchemaCheck,
+ VcVerification.SemanticCheckOfClaims,
+ )
+ )
+
+ object failedAsWarningChecks
+ extends Annotation[List[VcVerification]](
+ description = "The list of failed Verifications as warning",
+ example = List(
+ VcVerification.SignatureVerification,
+ VcVerification.IssuerIdentification,
+ VcVerification.ExpirationCheck,
+ VcVerification.NotBeforeCheck,
+ VcVerification.AudienceCheck,
+ VcVerification.SubjectVerification,
+ VcVerification.IntegrityOfClaims,
+ VcVerification.ComplianceWithStandards,
+ VcVerification.RevocationCheck,
+ VcVerification.AlgorithmVerification,
+ VcVerification.SchemaCheck,
+ VcVerification.SemanticCheckOfClaims,
+ )
+ )
+ }
+
+ given credentialVerificationRequestEncoder: JsonEncoder[VcVerificationResponse] =
+ DeriveJsonEncoder.gen[VcVerificationResponse]
+
+ given credentialVerificationRequestDecoder: JsonDecoder[VcVerificationResponse] =
+ DeriveJsonDecoder.gen[VcVerificationResponse]
+
+ given credentialVerificationRequestSchema: Schema[VcVerificationResponse] = Schema.derived
+
+}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResult.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResult.scala
new file mode 100644
index 0000000000..99158682da
--- /dev/null
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResult.scala
@@ -0,0 +1,26 @@
+package io.iohk.atala.verification.controller.http
+
+import io.iohk.atala.pollux.core.service.verification.VcVerificationResult as ServiceVcVerificationResult
+import sttp.tapir.Schema
+import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
+
+final case class VcVerificationResult(
+ verification: VcVerification,
+ success: Boolean
+)
+object VcVerificationResult {
+ given encoder: JsonEncoder[VcVerificationResult] =
+ DeriveJsonEncoder.gen[VcVerificationResult]
+
+ given decoder: JsonDecoder[VcVerificationResult] =
+ DeriveJsonDecoder.gen[VcVerificationResult]
+
+ given schema: Schema[VcVerificationResult] = Schema.derived
+
+ def toService(result: ServiceVcVerificationResult): VcVerificationResult = {
+ VcVerificationResult(
+ verification = VcVerification.toService(result.verification),
+ success = result.success
+ )
+ }
+}
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/Tapir2StaticOAS.scala b/prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/Tapir2StaticOAS.scala
index 73593dfd12..68b510f62e 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/Tapir2StaticOAS.scala
+++ b/prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/Tapir2StaticOAS.scala
@@ -14,6 +14,7 @@ import io.iohk.atala.pollux.credentialdefinition.controller.CredentialDefinition
import io.iohk.atala.pollux.credentialschema.controller.{CredentialSchemaController, VerificationPolicyController}
import io.iohk.atala.presentproof.controller.PresentProofController
import io.iohk.atala.system.controller.SystemController
+import io.iohk.atala.verification.controller.VcVerificationController
import org.scalatestplus.mockito.MockitoSugar.*
import sttp.tapir.docs.openapi.OpenAPIDocsInterpreter
import zio.{Scope, ZIO, ZIOAppArgs, ZIOAppDefault, ZLayer}
@@ -44,6 +45,7 @@ object Tapir2StaticOAS extends ZIOAppDefault {
ZLayer.succeed(mock[VerificationPolicyController]) ++
ZLayer.succeed(mock[DIDRegistrarController]) ++
ZLayer.succeed(mock[PresentProofController]) ++
+ ZLayer.succeed(mock[VcVerificationController]) ++
ZLayer.succeed(mock[IssueController]) ++
ZLayer.succeed(mock[DIDController]) ++
ZLayer.succeed(mock[SystemController]) ++
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerImplSpec.scala b/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerImplSpec.scala
new file mode 100644
index 0000000000..4e67ad59bf
--- /dev/null
+++ b/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerImplSpec.scala
@@ -0,0 +1,129 @@
+package io.iohk.atala.verification.controller
+
+import io.circe.*
+import io.circe.syntax.*
+import io.iohk.atala.agent.walletapi.model.BaseEntity
+import io.iohk.atala.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
+import io.iohk.atala.castor.core.service.MockDIDService
+import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
+import io.iohk.atala.pollux.vc.jwt.*
+import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
+import io.iohk.atala.verification.controller.http.*
+import sttp.client3.ziojson.*
+import sttp.client3.{DeserializationException, Response, UriContext, basicRequest}
+import sttp.model.StatusCode
+import zio.*
+import zio.Config.OffsetDateTime
+import zio.json.EncoderOps
+import zio.test.*
+import zio.test.Assertion.*
+
+import java.time.Instant
+
+object VcVerificationControllerImplSpec extends ZIOSpecDefault with VcVerificationControllerTestTools {
+
+ def spec = httpErrorResponses.provideSomeLayerShared(
+ MockDIDService.empty ++ MockManagedDIDService.empty >>> testEnvironmentLayer
+ )
+
+ private val httpErrorResponses = suite("IssueControllerImp http failure cases")(
+ test("provide incorrect recordId to endpoint") {
+ for {
+ vcVerificationController <- ZIO.service[VcVerificationController]
+ verifier = DID("did:prism:verifier")
+ currentTime = OffsetDateTime.parse("2010-01-01T00:00:00Z").toOption.get
+ jwtCredentialPayload = W3cCredentialPayload(
+ `@context` = Set("https://www.w3.org/2018/credentials/v1", "https://www.w3.org/2018/credentials/examples/v1"),
+ maybeId = Some("http://example.edu/credentials/3732"),
+ `type` = Set("VerifiableCredential", "UniversityDegreeCredential"),
+ issuer = issuer.did,
+ issuanceDate = Instant.parse("2010-01-01T00:00:00Z"),
+ maybeExpirationDate = Some(Instant.parse("2010-01-12T00:00:00Z")),
+ maybeCredentialSchema = Some(
+ CredentialSchema(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "JsonSchemaValidator2018"
+ )
+ ),
+ credentialSubject = Json.obj(
+ "userName" -> Json.fromString("Bob"),
+ "age" -> Json.fromInt(42),
+ "email" -> Json.fromString("email")
+ ),
+ maybeCredentialStatus = Some(
+ CredentialStatus(
+ id = "did:work:MDP8AsFhHzhwUvGNuYkX7T;id=06e126d1-fa44-4882-a243-1e326fbe21db;version=1.0",
+ `type` = "StatusList2021Entry",
+ statusPurpose = StatusPurpose.Revocation,
+ statusListIndex = 0,
+ statusListCredential = "https://example.com/credentials/status/3"
+ )
+ ),
+ maybeRefreshService = Some(
+ RefreshService(
+ id = "https://example.edu/refresh/3732",
+ `type` = "ManualRefreshService2018"
+ )
+ ),
+ maybeEvidence = Option.empty,
+ maybeTermsOfUse = Option.empty,
+ aud = Set(verifier.value)
+ ).toJwtCredentialPayload
+ signedJwtCredential = issuer.signer.encode(jwtCredentialPayload.asJson)
+ authenticator <- ZIO.service[AuthenticatorWithAuthZ[BaseEntity]]
+ backend = httpBackend(vcVerificationController, authenticator)
+ response: Response[Either[DeserializationException[String], List[VcVerificationResponse]]] <-
+ basicRequest
+ .get(uri"${vcVerificationUriBase}")
+ .body(
+ List(
+ VcVerificationRequest(
+ signedJwtCredential.value,
+ List(
+ ParameterizableVcVerification(VcVerification.SignatureVerification, None),
+ ParameterizableVcVerification(VcVerification.NotBeforeCheck, Some(DateTimeParameter(currentTime))),
+ ParameterizableVcVerification(VcVerification.ExpirationCheck, Some(DateTimeParameter(currentTime)))
+ )
+ ),
+ VcVerificationRequest(
+ signedJwtCredential.value,
+ List(
+ ParameterizableVcVerification(VcVerification.AudienceCheck, Some(DidParameter(verifier.value))),
+ ParameterizableVcVerification(
+ VcVerification.IssuerIdentification,
+ Some(DidParameter(issuer.did.value))
+ )
+ )
+ )
+ ).toJsonPretty
+ )
+ .response(asJsonAlways[List[VcVerificationResponse]])
+ .send(backend)
+ statusCodeIs200 = assert(response.code)(equalTo(StatusCode.Ok))
+ body <- ZIO.fromEither(response.body)
+ bodyIsOk = assert(body)(
+ equalTo(
+ List(
+ VcVerificationResponse(
+ signedJwtCredential.value,
+ List(
+ VcVerificationResult(VcVerification.SignatureVerification, false),
+ VcVerificationResult(VcVerification.NotBeforeCheck, true),
+ VcVerificationResult(VcVerification.ExpirationCheck, true)
+ )
+ ),
+ VcVerificationResponse(
+ signedJwtCredential.value,
+ List(
+ VcVerificationResult(VcVerification.AudienceCheck, true),
+ VcVerificationResult(VcVerification.IssuerIdentification, true)
+ )
+ )
+ )
+ )
+ )
+ } yield statusCodeIs200 && bodyIsOk
+ }
+ )
+
+}
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerTestTools.scala b/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerTestTools.scala
new file mode 100644
index 0000000000..30bce18ce2
--- /dev/null
+++ b/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerTestTools.scala
@@ -0,0 +1,90 @@
+package io.iohk.atala.verification.controller
+
+import io.iohk.atala.agent.server.http.CustomServerInterceptors
+import io.iohk.atala.agent.walletapi.model.BaseEntity
+import io.iohk.atala.agent.walletapi.service.ManagedDIDService
+import io.iohk.atala.castor.core.model.did.VerificationRelationship
+import io.iohk.atala.castor.core.service.MockDIDService
+import io.iohk.atala.iam.authentication.{AuthenticatorWithAuthZ, DefaultEntityAuthenticator}
+import io.iohk.atala.pollux.core.service.*
+import io.iohk.atala.pollux.core.service.verification.{VcVerificationService, VcVerificationServiceImpl}
+import io.iohk.atala.pollux.vc.jwt.*
+import io.iohk.atala.shared.models.WalletId.*
+import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import sttp.client3.UriContext
+import sttp.client3.testing.SttpBackendStub
+import sttp.monad.MonadError
+import sttp.tapir.server.interceptor.CustomiseInterceptors
+import sttp.tapir.server.stub.TapirStubInterpreter
+import sttp.tapir.ztapir.RIOMonadError
+import zio.*
+import zio.test.*
+
+trait VcVerificationControllerTestTools extends PostgresTestContainerSupport {
+ self: ZIOSpecDefault =>
+
+ protected val (issuerOp, issuerKp, issuerDidMetadata, issuerDidData) =
+ MockDIDService.createDID(VerificationRelationship.AssertionMethod)
+
+ protected val issuer =
+ Issuer(
+ did = io.iohk.atala.pollux.vc.jwt.DID(issuerDidData.id.did.toString),
+ signer = ES256KSigner(issuerKp.privateKey.toJavaPrivateKey),
+ publicKey = issuerKp.publicKey.toJavaPublicKey
+ )
+
+ val didResolverLayer = ZLayer.fromZIO(ZIO.succeed(makeResolver(Map.empty)))
+
+ private[this] def makeResolver(lookup: Map[String, DIDDocument]): DidResolver = (didUrl: String) => {
+ lookup
+ .get(didUrl)
+ .fold(
+ ZIO.succeed(DIDResolutionFailed(NotFound(s"DIDDocument not found for $didUrl")))
+ )((didDocument: DIDDocument) => {
+ ZIO.succeed(
+ DIDResolutionSucceeded(
+ didDocument,
+ DIDDocumentMetadata()
+ )
+ )
+ })
+ }
+
+ protected val defaultWalletLayer = ZLayer.succeed(WalletAccessContext(WalletId.default))
+
+ lazy val testEnvironmentLayer =
+ zio.test.testEnvironment ++ ZLayer.makeSome[
+ ManagedDIDService,
+ VcVerificationController & VcVerificationService & AuthenticatorWithAuthZ[BaseEntity]
+ ](
+ didResolverLayer,
+ ResourceURIDereferencerImpl.layer,
+ VcVerificationControllerImpl.layer,
+ VcVerificationServiceImpl.layer,
+ DefaultEntityAuthenticator.layer
+ )
+
+ val vcVerificationUriBase = uri"http://test.com/verification/credential"
+
+ def bootstrapOptions[F[_]](monadError: MonadError[F]): CustomiseInterceptors[F, Any] = {
+ new CustomiseInterceptors[F, Any](_ => ())
+ .exceptionHandler(CustomServerInterceptors.exceptionHandler)
+ .rejectHandler(CustomServerInterceptors.rejectHandler)
+ .decodeFailureHandler(CustomServerInterceptors.decodeFailureHandler)
+ }
+
+ def httpBackend(controller: VcVerificationController, authenticator: AuthenticatorWithAuthZ[BaseEntity]) = {
+ val vcVerificationEndpoints = VcVerificationServerEndpoints(controller, authenticator, authenticator)
+ val backend =
+ TapirStubInterpreter(
+ bootstrapOptions(new RIOMonadError[Any]),
+ SttpBackendStub(new RIOMonadError[Any])
+ )
+ .whenServerEndpoint(vcVerificationEndpoints.verifyEndpoint)
+ .thenRunLogic()
+ .backend()
+ backend
+ }
+
+}
From f57f9061f1bab63770f944750aa356c2519179ce Mon Sep 17 00:00:00 2001
From: patlo-iog
Date: Wed, 24 Apr 2024 21:00:47 +0700
Subject: [PATCH 02/12] ci: integration test startup fail workaround (#978)
Signed-off-by: Pat Losoponkul
---
.../src/test/kotlin/config/services/Agent.kt | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/tests/integration-tests/src/test/kotlin/config/services/Agent.kt b/tests/integration-tests/src/test/kotlin/config/services/Agent.kt
index 0e4c4c8ca3..edd8edae68 100644
--- a/tests/integration-tests/src/test/kotlin/config/services/Agent.kt
+++ b/tests/integration-tests/src/test/kotlin/config/services/Agent.kt
@@ -31,9 +31,11 @@ data class Agent(
"REST_SERVICE_URL" to (restServiceUrl ?: "http://host.docker.internal:$httpPort"),
"PRISM_NODE_PORT" to (prismNode?.httpPort?.toString() ?: ""),
"SECRET_STORAGE_BACKEND" to if (vault != null) "vault" else "postgres",
- "VAULT_HTTP_PORT" to (vault?.httpPort?.toString() ?: ""),
+ // FIXME: hardcode port 10001 just to avoid invalid URL 'http://host.docker.internal:'
+ "VAULT_HTTP_PORT" to (vault?.httpPort?.toString() ?: "10001"),
"KEYCLOAK_ENABLED" to (keycloak != null).toString(),
- "KEYCLOAK_HTTP_PORT" to (keycloak?.httpPort?.toString() ?: ""),
+ // FIXME: hardcode port 10002 just to avoid invalid URL 'http://host.docker.internal:'
+ "KEYCLOAK_HTTP_PORT" to (keycloak?.httpPort?.toString() ?: "10002"),
"KEYCLOAK_REALM" to (keycloak?.realm ?: ""),
"KEYCLOAK_CLIENT_ID" to (keycloak?.clientId ?: ""),
"KEYCLOAK_CLIENT_SECRET" to (keycloak?.clientSecret ?: ""),
From a0f6819bb80d87c13f903d7dc1b67cb08b4687db Mon Sep 17 00:00:00 2001
From: patlo-iog
Date: Wed, 24 Apr 2024 22:50:45 +0700
Subject: [PATCH 03/12] feat: key management for Ed25519 and X25519 (#966)
Signed-off-by: Pat Losoponkul
---
build.sbt | 8 +-
.../castor/core/model/did/PublicKey.scala | 33 +--
.../core/model/did/w3c/W3CModelHelper.scala | 62 +++---
.../castor/core/model/error/package.scala | 2 +
.../castor/core/service/MockDIDService.scala | 14 +-
.../core/util/DIDOperationValidator.scala | 111 +++++++---
.../core/util/DIDOperationValidatorSpec.scala | 96 +++++++--
.../atala/castor/core/util/GenUtils.scala | 18 +-
.../io/iohk/atala/agent/server/Modules.scala | 13 --
.../atala/agent/server/config/AppConfig.scala | 2 +-
.../castor/controller/http/ManagedDID.scala | 46 ++++-
.../agent/server/config/AppConfigSpec.scala | 2 +-
.../sql/agent/V14__multiple_did_key_types.sql | 52 +++++
.../memory/DIDSecretStorageInMemory.scala | 58 ------
.../agent/walletapi/model/KeyManagement.scala | 59 ++++--
.../agent/walletapi/model/ManagedDID.scala | 2 +-
.../walletapi/model/ManagedDIDTemplate.scala | 12 +-
.../walletapi/service/ManagedDIDService.scala | 9 +
.../service/ManagedDIDServiceImpl.scala | 44 ++--
.../service/MockManagedDIDService.scala | 7 +
.../service/handler/DIDCreateHandler.scala | 25 ++-
.../service/handler/DIDUpdateHandler.scala | 76 ++++---
.../service/handler/PublicationHandler.scala | 10 +-
.../sql/JdbcDIDNonSecretStorage.scala | 92 ++++++---
.../walletapi/sql/JdbcDIDSecretStorage.scala | 65 +++++-
.../atala/agent/walletapi/sql/package.scala | 23 ++-
.../storage/DIDNonSecretStorage.scala | 9 +-
.../walletapi/storage/DIDSecretStorage.scala | 14 ++
.../agent/walletapi/util/KeyResolver.scala | 70 ++++---
.../util/ManagedDIDTemplateValidator.scala | 30 ++-
.../walletapi/util/OperationFactory.scala | 194 +++++++++---------
.../vault/VaultDIDSecretStorage.scala | 49 +++++
.../atala/agent/walletapi/vault/package.scala | 12 ++
.../walletapi/benchmark/KeyDerivation.scala | 2 +-
.../service/ManagedDIDServiceSpec.scala | 24 ++-
.../storage/DIDSecretStorageSpec.scala | 15 --
.../storage/JdbcDIDNonSecretStorageSpec.scala | 23 ++-
.../walletapi/storage/StorageSpecHelper.scala | 24 +--
.../ManagedDIDTemplateValidatorSpec.scala | 10 +-
.../walletapi/util/OperationFactorySpec.scala | 51 +++--
.../io/iohk/atala/shared/crypto/Apollo.scala | 17 +-
.../iohk/atala/shared/crypto/KmpApollo.scala | 106 ++++++++--
.../atala/shared/crypto/Prism14Apollo.scala | 96 +++++++++
.../io/iohk/atala/shared/crypto/jwk/JWK.scala | 61 ++++++
.../iohk/atala/shared/crypto/ApolloSpec.scala | 30 +--
45 files changed, 1214 insertions(+), 564 deletions(-)
create mode 100644 prism-agent/service/wallet-api/src/main/resources/sql/agent/V14__multiple_did_key_types.sql
delete mode 100644 prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/DIDSecretStorageInMemory.scala
create mode 100644 shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Prism14Apollo.scala
create mode 100644 shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/jwk/JWK.scala
diff --git a/build.sbt b/build.sbt
index 065c03df64..141c9734e9 100644
--- a/build.sbt
+++ b/build.sbt
@@ -193,19 +193,18 @@ lazy val D_Shared = new {
D.zioPrelude,
D.jsonCanonicalization,
D.scodecBits,
- D.circeCore,
- D.circeGeneric,
- D.circeParser
)
}
lazy val D_SharedCrypto = new {
lazy val dependencies: Seq[ModuleID] =
Seq(
+ D.zioJson,
D.apollo,
D.bouncyBcpkix,
D.bouncyBcprov,
D.prismCrypto, // TODO: remove after migrated all primitives to apollo
+ D.nimbusJwt,
D.zioTest,
D.zioTestSbt,
D.zioTestMagnolia,
@@ -252,6 +251,9 @@ lazy val D_Castor = new {
D.zioMock,
D.zioTestSbt,
D.zioTestMagnolia,
+ D.circeCore,
+ D.circeGeneric,
+ D.circeParser
)
// Project Dependencies
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PublicKey.scala b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PublicKey.scala
index 55867ce39f..5dd050b589 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PublicKey.scala
+++ b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PublicKey.scala
@@ -1,7 +1,6 @@
package io.iohk.atala.castor.core.model.did
import io.iohk.atala.shared.models.Base64UrlString
-import io.iohk.atala.prism.crypto.EC
final case class PublicKey(
id: String,
@@ -20,33 +19,11 @@ final case class InternalPublicKey(
publicKeyData: PublicKeyData
)
-sealed trait PublicKeyData
+sealed trait PublicKeyData {
+ def crv: EllipticCurve
+}
object PublicKeyData {
- final case class ECKeyData(
- crv: EllipticCurve,
- x: Base64UrlString,
- y: Base64UrlString
- ) extends PublicKeyData
-
- final case class ECCompressedKeyData(
- crv: EllipticCurve,
- data: Base64UrlString
- ) extends PublicKeyData {
- def toUncompressedKeyData: Option[ECKeyData] = {
- crv match {
- case EllipticCurve.SECP256K1 =>
- val prism14PublicKey = EC.INSTANCE.toPublicKeyFromCompressed(data.toByteArray)
- val ecPoint = prism14PublicKey.getCurvePoint()
- Some(
- ECKeyData(
- crv = crv,
- x = Base64UrlString.fromByteArray(ecPoint.getX().bytes()),
- y = Base64UrlString.fromByteArray(ecPoint.getY().bytes())
- )
- )
- case _ => None
- }
- }
- }
+ final case class ECKeyData(crv: EllipticCurve, x: Base64UrlString, y: Base64UrlString) extends PublicKeyData
+ final case class ECCompressedKeyData(crv: EllipticCurve, data: Base64UrlString) extends PublicKeyData
}
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelper.scala b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelper.scala
index 6b74060b4f..45dd3bd47c 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelper.scala
+++ b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelper.scala
@@ -1,23 +1,15 @@
package io.iohk.atala.castor.core.model.did.w3c
-import io.iohk.atala.castor.core.model.did.{
- DIDData,
- DIDMetadata,
- PrismDID,
- PublicKey,
- PublicKeyData,
- Service,
- VerificationRelationship
-}
-import io.iohk.atala.shared.models.HexString
-import io.iohk.atala.castor.core.model.did.ServiceType
import io.circe.Json
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint
+import io.iohk.atala.castor.core.model.did.*
import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
-import io.iohk.atala.castor.core.model.did.EllipticCurve
-import java.time.format.DateTimeFormatter
-import java.time.ZoneOffset
+import io.iohk.atala.shared.crypto.Apollo
+import io.iohk.atala.shared.models.Base64UrlString
+import io.iohk.atala.shared.models.HexString
+
import java.time.Instant
+import java.time.ZoneOffset
+import java.time.format.DateTimeFormatter
object W3CModelHelper extends W3CModelHelper
@@ -118,7 +110,6 @@ private[castor] trait W3CModelHelper {
}
}
- // FIXME: do we need to support uncompress for OKP key types?
extension (publicKey: PublicKey) {
def toW3C(did: PrismDID, controller: PrismDID): PublicKeyRepr = {
val curve = publicKey.publicKeyData match {
@@ -147,32 +138,31 @@ private[castor] trait W3CModelHelper {
x = Some(data.toStringNoPadding),
y = None
)
- case PublicKeyData.ECKeyData(crv, _, _) =>
- throw Exception(s"Uncompressed key for curve ${crv.name} is not supported")
- }
- }
-
- private def secp256k1Repr(pk: PublicKeyData): PublicKeyJwk = {
- pk match {
- case pk: PublicKeyData.ECCompressedKeyData =>
- val uncomporessed = pk.toUncompressedKeyData.getOrElse(
- throw Exception(s"Conversion to uncompress key is not supported for curve ${pk.crv.name}")
- )
+ case PublicKeyData.ECKeyData(crv, x, _) =>
PublicKeyJwk(
- kty = "EC",
- crv = uncomporessed.crv.name,
- x = Some(uncomporessed.x.toStringNoPadding),
- y = Some(uncomporessed.y.toStringNoPadding)
- )
- case PublicKeyData.ECKeyData(crv, x, y) =>
- PublicKeyJwk(
- kty = "EC",
+ kty = "OKP",
crv = crv.name,
x = Some(x.toStringNoPadding),
- y = Some(y.toStringNoPadding)
+ y = None
)
+ }
+ }
+ private def secp256k1Repr(pk: PublicKeyData): PublicKeyJwk = {
+ val (x, y) = pk match {
+ case PublicKeyData.ECKeyData(_, x, y) => (x, y)
+ case PublicKeyData.ECCompressedKeyData(_, data) =>
+ val point = Apollo.default.secp256k1.publicKeyFromEncoded(data.toByteArray).get.getECPoint
+ val x = Base64UrlString.fromByteArray(point.x)
+ val y = Base64UrlString.fromByteArray(point.y)
+ (x, y)
}
+ PublicKeyJwk(
+ kty = "EC",
+ crv = EllipticCurve.SECP256K1.name,
+ x = Some(x.toStringNoPadding),
+ y = Some(y.toStringNoPadding)
+ )
}
}
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/error/package.scala b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/error/package.scala
index bdf1ddfb64..5bd17373f9 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/error/package.scala
+++ b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/error/package.scala
@@ -23,6 +23,8 @@ package object error {
final case class TooManyDidPublicKeyAccess(limit: Int, access: Option[Int]) extends OperationValidationError
final case class TooManyDidServiceAccess(limit: Int, access: Option[Int]) extends OperationValidationError
final case class InvalidArgument(msg: String) extends OperationValidationError
+ final case class InvalidPublicKeyData(ids: Seq[String]) extends OperationValidationError
+ final case class InvalidMasterKeyType(ids: Seq[String]) extends OperationValidationError
}
}
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/MockDIDService.scala b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/MockDIDService.scala
index 14fc883494..1da4d59758 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/MockDIDService.scala
+++ b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/MockDIDService.scala
@@ -7,12 +7,9 @@ import io.iohk.atala.shared.crypto.Secp256k1KeyPair
import io.iohk.atala.shared.models.Base64UrlString
import zio.mock.{Expectation, Mock, Proxy}
import zio.test.Assertion
-import zio.{IO, URLayer, ZIO, ZLayer, mock, Unsafe, Runtime}
+import zio.{IO, URLayer, ZIO, ZLayer, mock}
-import java.util.concurrent.TimeUnit
import scala.collection.immutable.ArraySeq
-import scala.concurrent.Await
-import scala.concurrent.duration.Duration
// FIXME: move this to test code
object MockDIDService extends Mock[DIDService] {
@@ -45,13 +42,8 @@ object MockDIDService extends Mock[DIDService] {
def createDID(
verificationRelationship: VerificationRelationship
): (PrismDIDOperation.Create, Secp256k1KeyPair, DIDMetadata, DIDData) = {
- // FIXME: unsafe bridge just to avoid refactoring the whole test into ZIO[?, ?, KeyPair]
- def unsafeRun(effect: ZIO[Any, Nothing, Secp256k1KeyPair]): Secp256k1KeyPair = {
- val f = Unsafe.unsafe { implicit unsafe => Runtime.default.unsafe.runToFuture(effect) }
- Await.result(f, Duration(10, TimeUnit.SECONDS))
- }
- val masterKeyPair = unsafeRun(Apollo.default.secp256k1.generateKeyPair)
- val keyPair = unsafeRun(Apollo.default.secp256k1.generateKeyPair)
+ val masterKeyPair = Apollo.default.secp256k1.generateKeyPair
+ val keyPair = Apollo.default.secp256k1.generateKeyPair
val createOperation = PrismDIDOperation.Create(
publicKeys = Seq(
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/DIDOperationValidator.scala b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/DIDOperationValidator.scala
index ef496100ac..80b0a6a557 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/DIDOperationValidator.scala
+++ b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/DIDOperationValidator.scala
@@ -1,15 +1,15 @@
package io.iohk.atala.castor.core.util
-import io.iohk.atala.castor.core.model.did.PublicKey
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint
-import io.iohk.atala.castor.core.model.did.ServiceType
-import io.iohk.atala.castor.core.model.did.{InternalKeyPurpose, InternalPublicKey, PrismDIDOperation, UpdateDIDAction}
+import io.iohk.atala.castor.core.model.did.*
import io.iohk.atala.castor.core.model.error.OperationValidationError
import io.iohk.atala.castor.core.util.DIDOperationValidator.Config
import io.iohk.atala.castor.core.util.Prelude.*
-import scala.collection.immutable.ArraySeq
+import io.iohk.atala.shared.crypto.Apollo
import zio.*
+import scala.collection.immutable.ArraySeq
+import scala.util.Failure
+
object DIDOperationValidator {
final case class Config(
publicKeyLimit: Int,
@@ -46,11 +46,12 @@ class DIDOperationValidator(config: Config) extends BaseOperationValidator {
private object CreateOperationValidator extends BaseOperationValidator {
def validate(config: Config)(operation: PrismDIDOperation.Create): Either[OperationValidationError, Unit] = {
for {
- // TODO: validate public key content
_ <- validateMaxPublicKeysAccess(config)(operation, extractKeyIds)
_ <- validateMaxServiceAccess(config)(operation, extractServiceIds)
_ <- validateUniquePublicKeyId(operation, extractKeyIds)
_ <- validateUniqueServiceId(operation, extractServiceIds)
+ _ <- validateMasterKeyIsSecp256k1(operation, extractKeyData)
+ _ <- validateKeyData(operation, extractKeyData)
_ <- validateKeyIdIsUriFragment(operation, extractKeyIds)
_ <- validateKeyIdLength(config)(operation, extractKeyIds)
_ <- validateServiceIdIsUriFragment(operation, extractServiceIds)
@@ -71,10 +72,17 @@ private object CreateOperationValidator extends BaseOperationValidator {
else Left(OperationValidationError.InvalidArgument("create operation must contain at least 1 master key"))
}
- private def extractKeyIds(operation: PrismDIDOperation.Create): Seq[String] =
+ private def extractKeyIds(operation: PrismDIDOperation.Create): Seq[String] = operation.publicKeys.map {
+ case PublicKey(id, _, _) => id
+ case InternalPublicKey(id, _, _) => id
+ }
+
+ private def extractKeyData(
+ operation: PrismDIDOperation.Create
+ ): Seq[(String, VerificationRelationship | InternalKeyPurpose, PublicKeyData)] =
operation.publicKeys.map {
- case PublicKey(id, _, _) => id
- case InternalPublicKey(id, _, _) => id
+ case PublicKey(id, purpose, data) => (id, purpose, data)
+ case InternalPublicKey(id, purpose, data) => (id, purpose, data)
}
private def extractServiceIds(operation: PrismDIDOperation.Create): Seq[String] = operation.services.map(_.id)
@@ -86,7 +94,6 @@ private object CreateOperationValidator extends BaseOperationValidator {
private def extractServiceType(operation: PrismDIDOperation.Create): Seq[(String, ServiceType)] = {
operation.services.map { s => (s.id, s.`type`) }
}
-
}
private object UpdateOperationValidator extends BaseOperationValidator {
@@ -94,6 +101,8 @@ private object UpdateOperationValidator extends BaseOperationValidator {
for {
_ <- validateMaxPublicKeysAccess(config)(operation, extractKeyIds)
_ <- validateMaxServiceAccess(config)(operation, extractServiceIds)
+ _ <- validateMasterKeyIsSecp256k1(operation, extractKeyData)
+ _ <- validateKeyData(operation, extractKeyData)
_ <- validateKeyIdIsUriFragment(operation, extractKeyIds)
_ <- validateKeyIdLength(config)(operation, extractKeyIds)
_ <- validateServiceIdIsUriFragment(operation, extractServiceIds)
@@ -133,24 +142,24 @@ private object UpdateOperationValidator extends BaseOperationValidator {
)
}
- private def extractKeyIds(operation: PrismDIDOperation.Update): Seq[String] = operation.actions.flatMap {
- case UpdateDIDAction.AddKey(publicKey) => Some(publicKey.id)
- case UpdateDIDAction.AddInternalKey(publicKey) => Some(publicKey.id)
- case UpdateDIDAction.RemoveKey(id) => Some(id)
- case _: UpdateDIDAction.AddService => None
- case _: UpdateDIDAction.RemoveService => None
- case _: UpdateDIDAction.UpdateService => None
- case _: UpdateDIDAction.PatchContext => None
+ private def extractKeyIds(operation: PrismDIDOperation.Update): Seq[String] = operation.actions.collect {
+ case UpdateDIDAction.AddKey(pk) => pk.id
+ case UpdateDIDAction.AddInternalKey(pk) => pk.id
+ case UpdateDIDAction.RemoveKey(id) => id
}
- private def extractServiceIds(operation: PrismDIDOperation.Update): Seq[String] = operation.actions.flatMap {
- case _: UpdateDIDAction.AddKey => None
- case _: UpdateDIDAction.AddInternalKey => None
- case _: UpdateDIDAction.RemoveKey => None
- case UpdateDIDAction.AddService(service) => Some(service.id)
- case UpdateDIDAction.RemoveService(id) => Some(id)
- case UpdateDIDAction.UpdateService(id, _, _) => Some(id)
- case _: UpdateDIDAction.PatchContext => None
+ private def extractKeyData(
+ operation: PrismDIDOperation.Update
+ ): Seq[(String, VerificationRelationship | InternalKeyPurpose, PublicKeyData)] =
+ operation.actions.collect {
+ case UpdateDIDAction.AddKey(pk) => (pk.id, pk.purpose, pk.publicKeyData)
+ case UpdateDIDAction.AddInternalKey(pk) => (pk.id, pk.purpose, pk.publicKeyData)
+ }
+
+ private def extractServiceIds(operation: PrismDIDOperation.Update): Seq[String] = operation.actions.collect {
+ case UpdateDIDAction.AddService(service) => service.id
+ case UpdateDIDAction.RemoveService(id) => id
+ case UpdateDIDAction.UpdateService(id, _, _) => id
}
private def extractServiceEndpoint(operation: PrismDIDOperation.Update): Seq[(String, ServiceEndpoint)] =
@@ -165,12 +174,8 @@ private object UpdateOperationValidator extends BaseOperationValidator {
case UpdateDIDAction.UpdateService(id, Some(serviceType), _) => id -> serviceType
}
- private def extractContexts(operation: PrismDIDOperation.Update): Seq[Seq[String]] = {
- operation.actions.flatMap {
- case UpdateDIDAction.PatchContext(context) => Some(context)
- case _ => None
- }
- }
+ private def extractContexts(operation: PrismDIDOperation.Update): Seq[Seq[String]] =
+ operation.actions.collect { case UpdateDIDAction.PatchContext(context) => context }
}
private object DeactivateOperationValidator extends BaseOperationValidator {
@@ -185,6 +190,7 @@ private trait BaseOperationValidator {
type ServiceTypeExtractor[T] = T => Seq[(String, ServiceType)]
type ServiceEndpointExtractor[T] = T => Seq[(String, ServiceEndpoint)]
type ContextExtractor[T] = T => Seq[Seq[String]]
+ type KeyDataExtractor[T] = T => Seq[(String, VerificationRelationship | InternalKeyPurpose, PublicKeyData)]
protected def validateMaxPublicKeysAccess[T <: PrismDIDOperation](
config: Config
@@ -354,4 +360,45 @@ private trait BaseOperationValidator {
UriUtils.normalizeUri(uri).contains(uri)
}
+ protected def validateKeyData[T <: PrismDIDOperation](
+ operation: T,
+ keyDataExtractor: KeyDataExtractor[T]
+ ): Either[OperationValidationError, Unit] = {
+ val keys = keyDataExtractor(operation)
+ val apollo = Apollo.default
+ val parsedKeys = keys.map { case (id, _, keyData) =>
+ val pk = keyData match {
+ case PublicKeyData.ECKeyData(EllipticCurve.SECP256K1, x, y) =>
+ apollo.secp256k1.publicKeyFromCoordinate(x.toByteArray, y.toByteArray)
+ case PublicKeyData.ECKeyData(EllipticCurve.ED25519, x, _) =>
+ apollo.ed25519.publicKeyFromEncoded(x.toByteArray)
+ case PublicKeyData.ECKeyData(EllipticCurve.X25519, x, _) =>
+ apollo.x25519.publicKeyFromEncoded(x.toByteArray)
+ case PublicKeyData.ECCompressedKeyData(EllipticCurve.SECP256K1, data) =>
+ apollo.secp256k1.publicKeyFromEncoded(data.toByteArray)
+ case PublicKeyData.ECCompressedKeyData(EllipticCurve.ED25519, data) =>
+ apollo.ed25519.publicKeyFromEncoded(data.toByteArray)
+ case PublicKeyData.ECCompressedKeyData(EllipticCurve.X25519, data) =>
+ apollo.x25519.publicKeyFromEncoded(data.toByteArray)
+ }
+ id -> pk
+ }
+
+ val invalidKeyDataIds = parsedKeys.collect { case (id, Failure(_)) => id }
+ if (invalidKeyDataIds.isEmpty) Right(())
+ else Left(OperationValidationError.InvalidPublicKeyData(invalidKeyDataIds))
+ }
+
+ protected def validateMasterKeyIsSecp256k1[T <: PrismDIDOperation](
+ operation: T,
+ keyDataExtractor: KeyDataExtractor[T]
+ ): Either[OperationValidationError, Unit] = {
+ val keys = keyDataExtractor(operation)
+ val masterKeys = keys.collect { case (id, InternalKeyPurpose.Master, keyData) => id -> keyData }
+ val invalidKeyIds = masterKeys.filter(_._2.crv != EllipticCurve.SECP256K1).map(_._1)
+
+ if (invalidKeyIds.isEmpty) Right(())
+ else Left(OperationValidationError.InvalidMasterKeyType(invalidKeyIds))
+ }
+
}
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/DIDOperationValidatorSpec.scala b/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/DIDOperationValidatorSpec.scala
index c44be521be..a4477f4df5 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/DIDOperationValidatorSpec.scala
+++ b/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/DIDOperationValidatorSpec.scala
@@ -1,28 +1,16 @@
package io.iohk.atala.castor.core.util
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint
-import io.iohk.atala.castor.core.model.did.{
- EllipticCurve,
- InternalKeyPurpose,
- InternalPublicKey,
- PrismDID,
- PrismDIDOperation,
- PublicKey,
- PublicKeyData,
- Service,
- ServiceType,
- UpdateDIDAction,
- VerificationRelationship
-}
+import io.iohk.atala.castor.core.model.did.*
import io.iohk.atala.castor.core.model.error.OperationValidationError
import io.iohk.atala.castor.core.util.DIDOperationValidator.Config
import io.iohk.atala.shared.models.Base64UrlString
-import scala.collection.immutable.ArraySeq
-import scala.language.implicitConversions
import zio.*
import zio.test.*
import zio.test.Assertion.*
+import scala.collection.immutable.ArraySeq
+import scala.language.implicitConversions
+
object DIDOperationValidatorSpec extends ZIOSpecDefault {
given Conversion[String, ServiceType.Name] = ServiceType.Name.fromStringUnsafe
@@ -38,8 +26,8 @@ object DIDOperationValidatorSpec extends ZIOSpecDefault {
private val publicKeyData = PublicKeyData.ECKeyData(
crv = EllipticCurve.SECP256K1,
- x = Base64UrlString.fromStringUnsafe("00"),
- y = Base64UrlString.fromStringUnsafe("00")
+ x = Base64UrlString.fromStringUnsafe("LlGgkX4eiiodghQ38ZO_9tNRYxZa2ruB-NBRHrwmdSY="),
+ y = Base64UrlString.fromStringUnsafe("gyvCAIE6guYGrBAjufAYl39R08896d2tjQDztWL3yP4=")
)
private def invalidArgumentContainsString(text: String): Assertion[Either[Any, Any]] = isLeft(
@@ -303,12 +291,10 @@ object DIDOperationValidatorSpec extends ZIOSpecDefault {
val op = createPrismDIDOperation(publicKeys = Nil)
assert(DIDOperationValidator(Config.default).validate(op))(isRight)
},
- // Test that the validator accepts a CreateOperation when the services list is not present
test("accept CreateOperation when services is None") {
val op = createPrismDIDOperation(services = Nil)
assert(DIDOperationValidator(Config.default).validate(op))(isRight)
},
- // Test that the validator rejects a CreateOperation when a service has an empty id string.
test("reject CreateOperation when service id is empty") {
val op = createPrismDIDOperation(services =
Seq(
@@ -353,6 +339,42 @@ object DIDOperationValidatorSpec extends ZIOSpecDefault {
assert(DIDOperationValidator(Config.default).validate(op))(
invalidArgumentContainsString("service id is invalid: [Wrong service]")
)
+ },
+ test("reject CreateOperation when publicKeyData is invalid") {
+ val op = createPrismDIDOperation(
+ publicKeys = Seq(
+ PublicKey(
+ id = "key-0",
+ purpose = VerificationRelationship.Authentication,
+ publicKeyData = PublicKeyData.ECKeyData(
+ crv = EllipticCurve.SECP256K1,
+ x = Base64UrlString.fromStringUnsafe("00"),
+ y = Base64UrlString.fromStringUnsafe("00")
+ )
+ )
+ )
+ )
+ assert(DIDOperationValidator(Config.default).validate(op))(
+ isLeft(equalTo(OperationValidationError.InvalidPublicKeyData(Seq("key-0"))))
+ )
+ },
+ test("reject CreateOperation when master key is not a secp256k1 key") {
+ val op = createPrismDIDOperation(
+ internalKeys = Seq(
+ InternalPublicKey(
+ id = "master0",
+ purpose = InternalKeyPurpose.Master,
+ publicKeyData = PublicKeyData.ECKeyData(
+ crv = EllipticCurve.ED25519,
+ x = Base64UrlString.fromStringUnsafe("11qYAYKxCrfVS_7TyWQHOg7hcvPapiMlrwIaaPcHURo"),
+ y = Base64UrlString.fromStringUnsafe("")
+ )
+ )
+ )
+ )
+ assert(DIDOperationValidator(Config.default).validate(op))(
+ isLeft(equalTo(OperationValidationError.InvalidMasterKeyType(Seq("master0"))))
+ )
}
).provideLayer(testLayer)
}
@@ -574,6 +596,40 @@ object DIDOperationValidatorSpec extends ZIOSpecDefault {
assert(DIDOperationValidator(Config.default).validate(op))(
invalidArgumentContainsString("must not have both 'type' and 'serviceEndpoints' empty")
)
+ },
+ test("reject UpdateOperation publicKeyData is invalid") {
+ val action = UpdateDIDAction.AddKey(
+ PublicKey(
+ id = "key0",
+ purpose = VerificationRelationship.Authentication,
+ publicKeyData = PublicKeyData.ECKeyData(
+ crv = EllipticCurve.SECP256K1,
+ x = Base64UrlString.fromStringUnsafe("00"),
+ y = Base64UrlString.fromStringUnsafe("00")
+ )
+ )
+ )
+ val op = updatePrismDIDOperation(Seq(action))
+ assert(DIDOperationValidator(Config.default).validate(op))(
+ isLeft(equalTo(OperationValidationError.InvalidPublicKeyData(Seq("key0"))))
+ )
+ },
+ test("reject UpdateOperation when master key is not a secp256k1 key") {
+ val action = UpdateDIDAction.AddInternalKey(
+ InternalPublicKey(
+ id = "master0",
+ purpose = InternalKeyPurpose.Master,
+ publicKeyData = PublicKeyData.ECKeyData(
+ crv = EllipticCurve.ED25519,
+ x = Base64UrlString.fromStringUnsafe("11qYAYKxCrfVS_7TyWQHOg7hcvPapiMlrwIaaPcHURo"),
+ y = Base64UrlString.fromStringUnsafe("")
+ )
+ )
+ )
+ val op = updatePrismDIDOperation(Seq(action))
+ assert(DIDOperationValidator(Config.default).validate(op))(
+ isLeft(equalTo(OperationValidationError.InvalidMasterKeyType(Seq("master0"))))
+ )
}
)
}
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/GenUtils.scala b/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/GenUtils.scala
index dcdb7adc35..f1e911498b 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/GenUtils.scala
+++ b/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/GenUtils.scala
@@ -1,13 +1,14 @@
package io.iohk.atala.castor.core.util
+import io.circe.Json
import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.prism.crypto.EC
+import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
+import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriValue
+import io.iohk.atala.shared.crypto.Apollo
import io.iohk.atala.shared.models.Base64UrlString
import zio.*
import zio.test.Gen
-import io.circe.Json
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriValue
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
+
import scala.language.implicitConversions
object GenUtils {
@@ -24,12 +25,13 @@ object GenUtils {
uri <- Gen.const(s"$scheme://$host/$path").map(UriUtils.normalizeUri).collect { case Some(uri) => uri }
} yield uri
+ // TODO: generate all key types
val publicKeyData: Gen[Any, PublicKeyData] =
for {
- curve <- Gen.fromIterable(EllipticCurve.values)
- pk <- Gen.fromZIO(ZIO.attempt(EC.INSTANCE.generateKeyPair().getPublicKey).orDie)
- x = Base64UrlString.fromByteArray(pk.getCurvePoint.getX.bytes())
- y = Base64UrlString.fromByteArray(pk.getCurvePoint.getY.bytes())
+ curve <- Gen.const(EllipticCurve.SECP256K1)
+ pk <- Gen.fromZIO(ZIO.succeed(Apollo.default.secp256k1.generateKeyPair.publicKey))
+ x = Base64UrlString.fromByteArray(pk.getECPoint.x)
+ y = Base64UrlString.fromByteArray(pk.getECPoint.y)
uncompressedKey = PublicKeyData.ECKeyData(curve, x, y)
compressedKey = PublicKeyData.ECCompressedKeyData(curve, Base64UrlString.fromByteArray(pk.getEncodedCompressed))
generated <- Gen.fromIterable(Seq(uncompressedKey, compressedKey))
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Modules.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Modules.scala
index 54b087d55f..7896437f49 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Modules.scala
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Modules.scala
@@ -6,11 +6,6 @@ import io.grpc.ManagedChannelBuilder
import io.iohk.atala.agent.server.config.AppConfig
import io.iohk.atala.agent.server.config.SecretStorageBackend
import io.iohk.atala.agent.server.config.ValidatedVaultConfig
-import io.iohk.atala.agent.walletapi.memory.{
- DIDSecretStorageInMemory,
- GenericSecretStorageInMemory,
- WalletSecretStorageInMemory
-}
import io.iohk.atala.agent.walletapi.service.EntityService
import io.iohk.atala.agent.walletapi.service.WalletManagementService
import io.iohk.atala.agent.walletapi.sql.{JdbcDIDSecretStorage, JdbcGenericSecretStorage, JdbcWalletSecretStorage}
@@ -256,14 +251,6 @@ object RepoModule {
agentContextAwareTransactorLayer,
)
)
- case SecretStorageBackend.memory =>
- ZIO.succeed(
- ZLayer.make[DIDSecretStorage & WalletSecretStorage & GenericSecretStorage](
- DIDSecretStorageInMemory.layer,
- GenericSecretStorageInMemory.layer,
- WalletSecretStorageInMemory.layer,
- )
- )
}
}
.provide(SystemModule.configLayer)
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/config/AppConfig.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/config/AppConfig.scala
index 5ba7582211..9f3ab58e52 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/config/AppConfig.scala
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/config/AppConfig.scala
@@ -207,5 +207,5 @@ final case class SecretStorageConfig(
}
enum SecretStorageBackend {
- case vault, postgres, memory
+ case vault, postgres
}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ManagedDID.scala b/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ManagedDID.scala
index 253e75ebfe..781ef3f607 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ManagedDID.scala
+++ b/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ManagedDID.scala
@@ -6,6 +6,7 @@ import io.iohk.atala.agent.walletapi.model.ManagedDIDDetail
import io.iohk.atala.agent.walletapi.model.PublicationState
import io.iohk.atala.api.http.Annotation
import io.iohk.atala.castor.core.model.did as castorDomain
+import io.iohk.atala.castor.core.model.did.EllipticCurve
import io.iohk.atala.castor.core.model.did.PrismDID
import io.iohk.atala.castor.core.model.did.VerificationRelationship
import io.iohk.atala.shared.utils.Traverse.*
@@ -169,6 +170,31 @@ object Purpose {
given schema: Schema[Purpose] = Schema.derivedEnumeration.defaultStringBased
}
+enum Curve {
+ case secp256k1 extends Curve
+ case Ed25519 extends Curve
+ case X25519 extends Curve
+}
+
+object Curve {
+ given Conversion[Curve, EllipticCurve] = {
+ case Curve.secp256k1 => EllipticCurve.SECP256K1
+ case Curve.Ed25519 => EllipticCurve.ED25519
+ case Curve.X25519 => EllipticCurve.X25519
+ }
+
+ given Conversion[EllipticCurve, Curve] = {
+ case EllipticCurve.SECP256K1 => Curve.secp256k1
+ case EllipticCurve.ED25519 => Curve.Ed25519
+ case EllipticCurve.X25519 => Curve.X25519
+ }
+
+ given encoder: JsonEncoder[Curve] = JsonEncoder[String].contramap(_.toString)
+ given decoder: JsonDecoder[Curve] =
+ JsonDecoder[String].mapOrFail(s => Curve.values.find(_.toString == s).toRight(s"Unknown curve: $s"))
+ given schema: Schema[Curve] = Schema.derivedEnumeration.defaultStringBased
+}
+
@description("A key-pair template to add to DID document.")
final case class ManagedDIDKeyTemplate(
@description(ManagedDIDKeyTemplate.annotations.id.description)
@@ -176,8 +202,14 @@ final case class ManagedDIDKeyTemplate(
id: String,
@description(ManagedDIDKeyTemplate.annotations.purpose.description)
@encodedExample(ManagedDIDKeyTemplate.annotations.purpose.example)
- purpose: Purpose
-)
+ purpose: Purpose,
+ // @description(ManagedDIDKeyTemplate.annotations.curve.description)
+ // @encodedExample(ManagedDIDKeyTemplate.annotations.curve.example)
+ // curve: Option[Curve]
+) {
+ // TODO: this curve option is hidden for now, to be added back after integration test with node
+ def curve: Option[Curve] = None
+}
object ManagedDIDKeyTemplate {
object annotations {
@@ -192,6 +224,13 @@ object ManagedDIDKeyTemplate {
description = "Purpose of the verification material in the DID Document",
example = VerificationRelationship.Authentication
)
+
+ object curve
+ extends Annotation[Option[Curve]](
+ description =
+ "The curve name of the verification material in the DID Document. Defaults to `secp256k1` if not specified.",
+ example = Some(Curve.Ed25519)
+ )
}
given encoder: JsonEncoder[ManagedDIDKeyTemplate] = DeriveJsonEncoder.gen[ManagedDIDKeyTemplate]
@@ -201,7 +240,8 @@ object ManagedDIDKeyTemplate {
given Conversion[ManagedDIDKeyTemplate, walletDomain.DIDPublicKeyTemplate] = publicKeyTemplate =>
walletDomain.DIDPublicKeyTemplate(
id = publicKeyTemplate.id,
- purpose = publicKeyTemplate.purpose
+ purpose = publicKeyTemplate.purpose,
+ curve = publicKeyTemplate.curve.getOrElse(Curve.secp256k1)
)
}
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/config/AppConfigSpec.scala b/prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/config/AppConfigSpec.scala
index 76284066a9..f5c4dde185 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/config/AppConfigSpec.scala
+++ b/prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/config/AppConfigSpec.scala
@@ -24,7 +24,7 @@ object AppConfigSpec extends ZIOSpecDefault {
for {
appConfig <- ZIO.serviceWith[AppConfig](
_.focus(_.agent.secretStorage.backend)
- .replace(SecretStorageBackend.memory)
+ .replace(SecretStorageBackend.postgres)
)
} yield assert(appConfig.validate)(isRight(anything))
},
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V14__multiple_did_key_types.sql b/prism-agent/service/wallet-api/src/main/resources/sql/agent/V14__multiple_did_key_types.sql
new file mode 100644
index 0000000000..da5be56e62
--- /dev/null
+++ b/prism-agent/service/wallet-api/src/main/resources/sql/agent/V14__multiple_did_key_types.sql
@@ -0,0 +1,52 @@
+-- generalize prism DID key table to contain any curve and non-deterministic key
+ALTER TABLE public.prism_did_hd_key
+RENAME TO prism_did_key;
+
+CREATE TYPE public.curve_name AS ENUM (
+ 'secp256k1',
+ 'Ed25519',
+ 'X25519'
+);
+
+-- enforce more strict constraints on key table
+UPDATE public.prism_did_key
+SET key_usage = 'MASTER'
+WHERE key_usage IS NULL;
+
+ALTER TABLE public.prism_did_key
+ALTER COLUMN key_usage SET NOT NULL,
+ADD COLUMN key_mode PRISM_DID_KEY_MODE NOT NULL DEFAULT 'HD',
+ADD COLUMN curve_name CURVE_NAME NOT NULL DEFAULT 'secp256k1';
+
+ALTER TABLE public.prism_did_key
+ALTER COLUMN key_mode DROP DEFAULT,
+ALTER COLUMN key_usage DROP DEFAULT,
+ALTER COLUMN curve_name DROP DEFAULT;
+
+ALTER TABLE public.prism_did_wallet_state
+DROP COLUMN key_mode;
+
+-- secretStorage of prism DID key pair
+CREATE TABLE public.prism_did_rand_key (
+ "did" TEXT NOT NULL,
+ "created_at" TIMESTAMPTZ NOT NULL,
+ "key_id" TEXT NOT NULL,
+ "operation_hash" BYTEA NOT NULL,
+ "key_pair" TEXT NOT NULL,
+ PRIMARY KEY ("did", "key_id", "operation_hash")
+);
+
+ALTER TABLE public.prism_did_rand_key
+ENABLE ROW LEVEL SECURITY;
+
+CREATE POLICY prism_did_rand_key_wallet_isolation
+ON public.prism_did_rand_key
+USING (
+ EXISTS (
+ SELECT 1
+ FROM prism_did_wallet_state AS s
+ WHERE
+ s.wallet_id = current_setting('app.current_wallet_id')::UUID
+ AND s.did = public.prism_did_rand_key.did
+ )
+);
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/DIDSecretStorageInMemory.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/DIDSecretStorageInMemory.scala
deleted file mode 100644
index 0f43d8e457..0000000000
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/DIDSecretStorageInMemory.scala
+++ /dev/null
@@ -1,58 +0,0 @@
-package io.iohk.atala.agent.walletapi.memory
-
-import com.nimbusds.jose.jwk.OctetKeyPair
-import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
-import zio.*
-
-class DIDSecretStorageInMemory(walletRefs: Ref[Map[WalletId, Ref[Map[String, OctetKeyPair]]]])
- extends DIDSecretStorage {
-
- private def walletStoreRef: URIO[WalletAccessContext, Ref[Map[String, OctetKeyPair]]] =
- for {
- walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId)
- refs <- walletRefs.get
- maybeWalletRef = refs.get(walletId)
- walletRef <- maybeWalletRef
- .fold {
- for {
- ref <- Ref.make(Map.empty[String, OctetKeyPair])
- _ <- walletRefs.set(refs.updated(walletId, ref))
- } yield ref
- }(ZIO.succeed)
- } yield walletRef
-
- private def constructKey(did: DidId, keyId: String): String = s"${did}_${keyId}"
-
- override def getKey(did: DidId, keyId: String): RIO[WalletAccessContext, Option[OctetKeyPair]] =
- walletStoreRef.flatMap { storeRef =>
- storeRef.get.map(_.get(constructKey(did, keyId)))
- }
-
- override def insertKey(did: DidId, keyId: String, keyPair: OctetKeyPair): RIO[WalletAccessContext, Int] =
- walletStoreRef.flatMap(storeRef =>
- storeRef.modify { store =>
- val key = constructKey(did, keyId)
- if (store.contains(key)) {
- (
- ZIO.fail(Exception(s"Unique constraint violation, key $key already exist.")),
- store
- ) // Already exists, so we're effectively updating it
- } else {
- (ZIO.succeed(1), store.updated(key, keyPair))
- }
- }.flatten
- )
-}
-
-object DIDSecretStorageInMemory {
- val layer: ULayer[DIDSecretStorage] =
- ZLayer.fromZIO(
- Ref
- .make(Map.empty[WalletId, Ref[Map[String, OctetKeyPair]]])
- .map(DIDSecretStorageInMemory(_))
- )
-
-}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/KeyManagement.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/KeyManagement.scala
index 4fce80980f..95c7b6105c 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/KeyManagement.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/KeyManagement.scala
@@ -1,9 +1,12 @@
package io.iohk.atala.agent.walletapi.model
+import io.iohk.atala.castor.core.model.did.EllipticCurve
import io.iohk.atala.castor.core.model.did.InternalKeyPurpose
import io.iohk.atala.castor.core.model.did.VerificationRelationship
import io.iohk.atala.prism.crypto.Sha256
-import io.iohk.atala.shared.crypto.{DerivationPath, Secp256k1KeyPair as ECKeyPair}
+import io.iohk.atala.shared.crypto.DerivationPath
+import io.iohk.atala.shared.crypto.Ed25519KeyPair
+import io.iohk.atala.shared.crypto.X25519KeyPair
import scala.collection.immutable.ArraySeq
import scala.language.implicitConversions
@@ -25,6 +28,7 @@ object WalletSeed {
enum KeyManagementMode {
case HD extends KeyManagementMode
+ case RANDOM extends KeyManagementMode
}
final case class VerificationRelationshipCounter(
@@ -97,6 +101,13 @@ object HdKeyIndexCounter {
HdKeyIndexCounter(didIndex, VerificationRelationshipCounter.zero, InternalKeyCounter.zero)
}
+sealed trait ManagedDIDKeyMeta
+
+object ManagedDIDKeyMeta {
+ final case class HD(path: ManagedDIDHdKeyPath) extends ManagedDIDKeyMeta
+ final case class Rand(meta: ManagedDIDRandKeyMeta) extends ManagedDIDKeyMeta
+}
+
final case class ManagedDIDHdKeyPath(
didIndex: Int,
keyUsage: VerificationRelationship | InternalKeyPurpose,
@@ -106,6 +117,10 @@ final case class ManagedDIDHdKeyPath(
private val WALLET_PURPOSE: Int = 0x1d
private val PRISM_DID_METHOD_PATH: Int = 0x1d
+ def curve: EllipticCurve = EllipticCurve.SECP256K1
+
+ def keyMode: KeyManagementMode = KeyManagementMode.HD
+
def derivationPath: Seq[DerivationPath] =
Seq(
DerivationPath.Hardened(WALLET_PURPOSE),
@@ -130,19 +145,37 @@ final case class ManagedDIDHdKeyPath(
}
}
-private[walletapi] final case class CreateDIDRandKey(
- keyPairs: Map[String, ECKeyPair],
- internalKeyPairs: Map[String, ECKeyPair]
-)
+final case class ManagedDIDRandKeyPair(
+ keyUsage: VerificationRelationship | InternalKeyPurpose,
+ keyPair: Ed25519KeyPair | X25519KeyPair
+) {
+ def meta: ManagedDIDRandKeyMeta = {
+ val curve = keyPair match {
+ case _: Ed25519KeyPair => EllipticCurve.ED25519
+ case _: X25519KeyPair => EllipticCurve.X25519
+ }
+ ManagedDIDRandKeyMeta(keyUsage, curve)
+ }
+}
-private[walletapi] final case class UpdateDIDRandKey(newKeyPairs: Map[String, ECKeyPair])
+final case class ManagedDIDRandKeyMeta(
+ keyUsage: VerificationRelationship | InternalKeyPurpose,
+ curve: EllipticCurve
+) {
+ def keyMode: KeyManagementMode = KeyManagementMode.RANDOM
+}
-private[walletapi] final case class CreateDIDHdKey(
- keyPaths: Map[String, ManagedDIDHdKeyPath],
- internalKeyPaths: Map[String, ManagedDIDHdKeyPath],
-)
+private[walletapi] final case class CreateDIDKey(
+ hdKeys: Map[String, ManagedDIDHdKeyPath],
+ randKeys: Map[String, ManagedDIDRandKeyPair]
+) {
+ def randKeyMeta: Map[String, ManagedDIDRandKeyMeta] = randKeys.map { case (k, v) => k -> v.meta }
+}
-private[walletapi] final case class UpdateDIDHdKey(
- newKeyPaths: Map[String, ManagedDIDHdKeyPath],
+private[walletapi] final case class UpdateDIDKey(
+ hdKeys: Map[String, ManagedDIDHdKeyPath],
+ randKeys: Map[String, ManagedDIDRandKeyPair],
counter: HdKeyIndexCounter
-)
+) {
+ def randKeyMeta: Map[String, ManagedDIDRandKeyMeta] = randKeys.map { case (k, v) => k -> v.meta }
+}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDID.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDID.scala
index f241424c72..582a6d599e 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDID.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDID.scala
@@ -12,7 +12,7 @@ final case class ManagedDIDState(
didIndex: Int,
publicationState: PublicationState
) {
- def keyMode: KeyManagementMode = KeyManagementMode.HD
+ def did: CanonicalPrismDID = createOperation.did
}
sealed trait PublicationState
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDIDTemplate.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDIDTemplate.scala
index 44d1604523..a17d47da65 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDIDTemplate.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDIDTemplate.scala
@@ -1,7 +1,12 @@
package io.iohk.atala.agent.walletapi.model
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint
-import io.iohk.atala.castor.core.model.did.{Service, VerificationRelationship, ServiceType}
+import io.iohk.atala.castor.core.model.did.{
+ EllipticCurve,
+ Service,
+ ServiceEndpoint,
+ ServiceType,
+ VerificationRelationship
+}
final case class ManagedDIDTemplate(
publicKeys: Seq[DIDPublicKeyTemplate],
@@ -11,7 +16,8 @@ final case class ManagedDIDTemplate(
final case class DIDPublicKeyTemplate(
id: String,
- purpose: VerificationRelationship
+ purpose: VerificationRelationship,
+ curve: EllipticCurve
)
sealed trait UpdateManagedDIDAction
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDService.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDService.scala
index 6b9b1f5192..229ea7aafb 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDService.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDService.scala
@@ -6,6 +6,9 @@ import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
import io.iohk.atala.castor.core.model.did.*
import io.iohk.atala.mercury.PeerDID
import io.iohk.atala.mercury.model.DidId
+import io.iohk.atala.shared.crypto.Ed25519KeyPair
+import io.iohk.atala.shared.crypto.Secp256k1KeyPair
+import io.iohk.atala.shared.crypto.X25519KeyPair
import io.iohk.atala.shared.models.WalletAccessContext
import zio.*
@@ -22,11 +25,17 @@ trait ManagedDIDService {
def syncUnconfirmedUpdateOperations: ZIO[WalletAccessContext, GetManagedDIDError, Unit]
+ @deprecated("will be dropped in favor of findDIDKeyPair")
def javaKeyPairWithDID(
did: CanonicalPrismDID,
keyId: String
): ZIO[WalletAccessContext, GetKeyError, Option[(JavaPrivateKey, JavaPublicKey)]]
+ def findDIDKeyPair(
+ did: CanonicalPrismDID,
+ keyId: String
+ ): ZIO[WalletAccessContext, GetKeyError, Option[Secp256k1KeyPair | Ed25519KeyPair | X25519KeyPair]]
+
def getManagedDIDState(did: CanonicalPrismDID): ZIO[WalletAccessContext, GetManagedDIDError, Option[ManagedDIDState]]
/** @return A tuple containing a list of items and a count of total items */
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceImpl.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceImpl.scala
index 0e4b2f7b18..521f6f7a30 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceImpl.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceImpl.scala
@@ -13,6 +13,9 @@ import io.iohk.atala.castor.core.util.DIDOperationValidator
import io.iohk.atala.mercury.PeerDID
import io.iohk.atala.mercury.model.DidId
import io.iohk.atala.shared.crypto.Apollo
+import io.iohk.atala.shared.crypto.Ed25519KeyPair
+import io.iohk.atala.shared.crypto.Secp256k1KeyPair
+import io.iohk.atala.shared.crypto.X25519KeyPair
import io.iohk.atala.shared.models.WalletAccessContext
import zio.*
@@ -36,11 +39,12 @@ class ManagedDIDServiceImpl private[walletapi] (
private val AGREEMENT_KEY_ID = "agreement"
private val AUTHENTICATION_KEY_ID = "authentication"
- // TODO: implement seed caching & TTL in dispatching layer
- private val keyResolver = KeyResolver(apollo, nonSecretStorage, walletSecretStorage)
+ private val keyResolver = KeyResolver(apollo, nonSecretStorage, secretStorage, walletSecretStorage)
private val publicationHandler = PublicationHandler(didService, keyResolver)(DEFAULT_MASTER_KEY_ID)
- private val didCreateHandler = DIDCreateHandler(apollo, nonSecretStorage, walletSecretStorage)(DEFAULT_MASTER_KEY_ID)
- private val didUpdateHandler = DIDUpdateHandler(apollo, nonSecretStorage, walletSecretStorage, publicationHandler)
+ private val didCreateHandler =
+ DIDCreateHandler(apollo, nonSecretStorage, secretStorage, walletSecretStorage)(DEFAULT_MASTER_KEY_ID)
+ private val didUpdateHandler =
+ DIDUpdateHandler(apollo, nonSecretStorage, secretStorage, walletSecretStorage, publicationHandler)
def syncManagedDIDState: ZIO[WalletAccessContext, GetManagedDIDError, Unit] = nonSecretStorage
.listManagedDID(offset = None, limit = None)
@@ -53,29 +57,35 @@ class ManagedDIDServiceImpl private[walletapi] (
def syncUnconfirmedUpdateOperations: ZIO[WalletAccessContext, GetManagedDIDError, Unit] =
syncUnconfirmedUpdateOperationsByDID(did = None)
- // FIXME
- // Instead of returning the privateKey directly, it should provide more secure interface like
- // {{{ def signWithDID(did, keyId, bytes): IO[?, Array[Byte]] }}}.
- // For the time being, the purpose of this method is just to disallow SecretStorage to be
- // used outside of this module.
def javaKeyPairWithDID(
did: CanonicalPrismDID,
keyId: String
): ZIO[WalletAccessContext, GetKeyError, Option[(JavaPrivateKey, JavaPublicKey)]] = {
- nonSecretStorage
- .getManagedDIDState(did)
+ findDIDKeyPair(did, keyId)
.flatMap {
- case None => ZIO.none
- case Some(state) => keyResolver.getKey(state.createOperation.did, state.keyMode, keyId)
+ case None => ZIO.none
+ case Some(keyPair: Secp256k1KeyPair) => ZIO.some(keyPair)
+ case _ => ZIO.dieMessage("Only secp256k1 keypair is supported for Java KeyPair conversion")
}
- .mapBoth(
- GetKeyError.WalletStorageError.apply,
- _.map { ecKeyPair =>
- (ecKeyPair.privateKey.toJavaPrivateKey, ecKeyPair.publicKey.toJavaPublicKey)
+ .map(
+ _.map { keyPair =>
+ (keyPair.privateKey.toJavaPrivateKey, keyPair.publicKey.toJavaPublicKey)
}
)
}
+ override def findDIDKeyPair(
+ did: CanonicalPrismDID,
+ keyId: String
+ ): ZIO[WalletAccessContext, GetKeyError, Option[Secp256k1KeyPair | Ed25519KeyPair | X25519KeyPair]] =
+ nonSecretStorage
+ .getManagedDIDState(did)
+ .flatMap {
+ case None => ZIO.none
+ case Some(state) => keyResolver.getKey(state.createOperation.did, keyId)
+ }
+ .orDie
+
def getManagedDIDState(
did: CanonicalPrismDID
): ZIO[WalletAccessContext, GetManagedDIDError, Option[ManagedDIDState]] =
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/MockManagedDIDService.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/MockManagedDIDService.scala
index d795318eab..ea3128b884 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/MockManagedDIDService.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/MockManagedDIDService.scala
@@ -11,7 +11,9 @@ import io.iohk.atala.castor.core.model.did.{
}
import io.iohk.atala.mercury.PeerDID
import io.iohk.atala.mercury.model.DidId
+import io.iohk.atala.shared.crypto.Ed25519KeyPair
import io.iohk.atala.shared.crypto.Secp256k1KeyPair
+import io.iohk.atala.shared.crypto.X25519KeyPair
import zio.mock.*
import zio.test.Assertion
import zio.{mock, *}
@@ -41,6 +43,11 @@ object MockManagedDIDService extends Mock[ManagedDIDService] {
): IO[GetKeyError, Option[(JavaPrivateKey, JavaPublicKey)]] =
proxy(JavaKeyPairWithDID, did, keyId)
+ override def findDIDKeyPair(
+ did: CanonicalPrismDID,
+ keyId: String
+ ): IO[GetKeyError, Option[Secp256k1KeyPair | Ed25519KeyPair | X25519KeyPair]] = ???
+
override def getManagedDIDState(
did: CanonicalPrismDID
): IO[GetManagedDIDError, Option[ManagedDIDState]] =
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDCreateHandler.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDCreateHandler.scala
index e21f2e02ad..59e3dcc5f7 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDCreateHandler.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDCreateHandler.scala
@@ -1,22 +1,26 @@
package io.iohk.atala.agent.walletapi.service.handler
-import io.iohk.atala.agent.walletapi.model.CreateDIDHdKey
+import io.iohk.atala.agent.walletapi.model.CreateDIDKey
import io.iohk.atala.agent.walletapi.model.ManagedDIDState
import io.iohk.atala.agent.walletapi.model.ManagedDIDTemplate
import io.iohk.atala.agent.walletapi.model.PublicationState
import io.iohk.atala.agent.walletapi.model.WalletSeed
import io.iohk.atala.agent.walletapi.model.error.CreateManagedDIDError
import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
+import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
import io.iohk.atala.agent.walletapi.util.OperationFactory
import io.iohk.atala.castor.core.model.did.PrismDIDOperation
import io.iohk.atala.shared.crypto.Apollo
+import io.iohk.atala.shared.crypto.Ed25519KeyPair
+import io.iohk.atala.shared.crypto.X25519KeyPair
import io.iohk.atala.shared.models.WalletAccessContext
import zio.*
private[walletapi] class DIDCreateHandler(
apollo: Apollo,
nonSecretStorage: DIDNonSecretStorage,
+ secretStorage: DIDSecretStorage,
walletSecretStorage: WalletSecretStorage,
)(
masterKeyId: String
@@ -36,10 +40,10 @@ private[walletapi] class DIDCreateHandler(
CreateManagedDIDError.WalletStorageError.apply,
maybeIdx => maybeIdx.map(_ + 1).getOrElse(0)
)
- generated <- operationFactory.makeCreateOperationHdKey(masterKeyId, seed.toByteArray)(didIndex, didTemplate)
- (createOperation, hdKey) = generated
+ generated <- operationFactory.makeCreateOperation(masterKeyId, seed.toByteArray)(didIndex, didTemplate)
+ (createOperation, keys) = generated
state = ManagedDIDState(createOperation, didIndex, PublicationState.Created())
- } yield DIDCreateMaterialImpl(nonSecretStorage)(createOperation, state, hdKey)
+ } yield DIDCreateMaterialImpl(nonSecretStorage, secretStorage)(createOperation, state, keys)
}
}
@@ -49,17 +53,24 @@ private[walletapi] trait DIDCreateMaterial {
def persist: RIO[WalletAccessContext, Unit]
}
-private[walletapi] class DIDCreateMaterialImpl(nonSecretStorage: DIDNonSecretStorage)(
+private[walletapi] class DIDCreateMaterialImpl(nonSecretStorage: DIDNonSecretStorage, secretStorage: DIDSecretStorage)(
val operation: PrismDIDOperation.Create,
val state: ManagedDIDState,
- hdKey: CreateDIDHdKey
+ keys: CreateDIDKey
) extends DIDCreateMaterial {
def persist: RIO[WalletAccessContext, Unit] = {
val did = operation.did
+ val operationHash = operation.toAtalaOperationHash
for {
_ <- nonSecretStorage
- .insertManagedDID(did, state, hdKey.keyPaths ++ hdKey.internalKeyPaths)
+ .insertManagedDID(did, state, keys.hdKeys, keys.randKeyMeta)
.mapError(CreateManagedDIDError.WalletStorageError.apply)
+ _ <- ZIO.foreach(keys.randKeys.toList) { case (keyId, key) =>
+ key.keyPair match {
+ case kp: Ed25519KeyPair => secretStorage.insertPrismDIDKeyPair(did, keyId, operationHash, kp)
+ case kp: X25519KeyPair => secretStorage.insertPrismDIDKeyPair(did, keyId, operationHash, kp)
+ }
+ }
} yield ()
}
}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDUpdateHandler.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDUpdateHandler.scala
index 93670fd857..f6ae6dfbf3 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDUpdateHandler.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDUpdateHandler.scala
@@ -1,14 +1,15 @@
package io.iohk.atala.agent.walletapi.service.handler
import io.iohk.atala.agent.walletapi.model.DIDUpdateLineage
-import io.iohk.atala.agent.walletapi.model.KeyManagementMode
+import io.iohk.atala.agent.walletapi.model.ManagedDIDKeyMeta
import io.iohk.atala.agent.walletapi.model.ManagedDIDState
-import io.iohk.atala.agent.walletapi.model.UpdateDIDHdKey
+import io.iohk.atala.agent.walletapi.model.UpdateDIDKey
import io.iohk.atala.agent.walletapi.model.UpdateManagedDIDAction
import io.iohk.atala.agent.walletapi.model.WalletSeed
import io.iohk.atala.agent.walletapi.model.error.UpdateManagedDIDError
import io.iohk.atala.agent.walletapi.model.error.{*, given}
import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
+import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
import io.iohk.atala.agent.walletapi.util.OperationFactory
import io.iohk.atala.castor.core.model.did.PrismDIDOperation
@@ -16,6 +17,8 @@ import io.iohk.atala.castor.core.model.did.PrismDIDOperation.Update
import io.iohk.atala.castor.core.model.did.ScheduledDIDOperationStatus
import io.iohk.atala.castor.core.model.did.SignedPrismDIDOperation
import io.iohk.atala.shared.crypto.Apollo
+import io.iohk.atala.shared.crypto.Ed25519KeyPair
+import io.iohk.atala.shared.crypto.X25519KeyPair
import io.iohk.atala.shared.models.WalletAccessContext
import scala.collection.immutable.ArraySeq
import zio.*
@@ -23,6 +26,7 @@ import zio.*
private[walletapi] class DIDUpdateHandler(
apollo: Apollo,
nonSecretStorage: DIDNonSecretStorage,
+ secretStorage: DIDSecretStorage,
walletSecretStorage: WalletSecretStorage,
publicationHandler: PublicationHandler
) {
@@ -33,29 +37,26 @@ private[walletapi] class DIDUpdateHandler(
): ZIO[WalletAccessContext, UpdateManagedDIDError, DIDUpdateMaterial] = {
val operationFactory = OperationFactory(apollo)
val did = state.createOperation.did
- state.keyMode match {
- case KeyManagementMode.HD =>
- for {
- walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId)
- seed <- walletSecretStorage.getWalletSeed
- .someOrElseZIO(ZIO.dieMessage(s"Wallet seed for wallet $walletId does not exist"))
- .mapError(UpdateManagedDIDError.WalletStorageError.apply)
- keyCounter <- nonSecretStorage
- .getHdKeyCounter(did)
- .mapError(UpdateManagedDIDError.WalletStorageError.apply)
- .someOrFail(
- UpdateManagedDIDError.DataIntegrityError("DID is in HD key mode, but its key counter is not found")
- )
- result <- operationFactory.makeUpdateOperationHdKey(seed.toByteArray)(
- did,
- previousOperationHash,
- actions,
- keyCounter
- )
- (operation, hdKey) = result
- signedOperation <- publicationHandler.signOperationWithMasterKey[UpdateManagedDIDError](state, operation)
- } yield HdKeyUpdateMaterial(nonSecretStorage)(operation, signedOperation, state, hdKey)
- }
+ for {
+ walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId)
+ seed <- walletSecretStorage.getWalletSeed
+ .someOrElseZIO(ZIO.dieMessage(s"Wallet seed for wallet $walletId does not exist"))
+ .mapError(UpdateManagedDIDError.WalletStorageError.apply)
+ keyCounter <- nonSecretStorage
+ .getHdKeyCounter(did)
+ .mapError(UpdateManagedDIDError.WalletStorageError.apply)
+ .someOrFail(
+ UpdateManagedDIDError.DataIntegrityError("DID is in HD key mode, but its key counter is not found")
+ )
+ result <- operationFactory.makeUpdateOperation(seed.toByteArray)(
+ did,
+ previousOperationHash,
+ actions,
+ keyCounter
+ )
+ (operation, hdKey) = result
+ signedOperation <- publicationHandler.signOperationWithMasterKey[UpdateManagedDIDError](state, operation)
+ } yield HdKeyUpdateMaterial(nonSecretStorage, secretStorage)(operation, signedOperation, state, hdKey)
}
}
@@ -88,19 +89,34 @@ private[walletapi] trait DIDUpdateMaterial {
}
-private class HdKeyUpdateMaterial(nonSecretStorage: DIDNonSecretStorage)(
+private class HdKeyUpdateMaterial(nonSecretStorage: DIDNonSecretStorage, secretStorage: DIDSecretStorage)(
val operation: PrismDIDOperation.Update,
val signedOperation: SignedPrismDIDOperation,
val state: ManagedDIDState,
- hdKey: UpdateDIDHdKey
+ keys: UpdateDIDKey
) extends DIDUpdateMaterial {
private def persistKeyMaterial: RIO[WalletAccessContext, Unit] = {
val did = operation.did
val operationHash = operation.toAtalaOperationHash
- ZIO.foreachDiscard(hdKey.newKeyPaths) { case (keyId, keyPath) =>
- nonSecretStorage.insertHdKeyPath(did, keyId, keyPath, operationHash)
- }
+ // OPTIMIZE: refactoring insertKey to a bulk insert (non-secret part)
+ for {
+ _ <- ZIO.foreach(keys.hdKeys.toList) { case (keyId, keyPath) =>
+ val meta = ManagedDIDKeyMeta.HD(keyPath)
+ nonSecretStorage.insertKeyMeta(did, keyId, meta, operationHash)
+ }
+ _ <- ZIO.foreach(keys.randKeyMeta.toList) { case (keyId, rand) =>
+ val meta = ManagedDIDKeyMeta.Rand(rand)
+ nonSecretStorage.insertKeyMeta(did, keyId, meta, operationHash)
+ }
+ _ <- ZIO.foreach(keys.randKeys.toList) { case (keyId, key) =>
+ key.keyPair match {
+ case kp: Ed25519KeyPair => secretStorage.insertPrismDIDKeyPair(did, keyId, operationHash, kp)
+ case kp: X25519KeyPair => secretStorage.insertPrismDIDKeyPair(did, keyId, operationHash, kp)
+ }
+ }
+ } yield ()
+
}
override def persist: RIO[WalletAccessContext, Unit] =
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/PublicationHandler.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/PublicationHandler.scala
index debc2ff156..1cdf639732 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/PublicationHandler.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/PublicationHandler.scala
@@ -9,6 +9,7 @@ import io.iohk.atala.castor.core.model.did.ScheduleDIDOperationOutcome
import io.iohk.atala.castor.core.model.did.SignedPrismDIDOperation
import io.iohk.atala.castor.core.model.error.DIDOperationError
import io.iohk.atala.castor.core.service.DIDService
+import io.iohk.atala.shared.crypto.Secp256k1KeyPair
import io.iohk.atala.shared.models.WalletAccessContext
import scala.collection.immutable.ArraySeq
import scala.language.implicitConversions
@@ -22,11 +23,10 @@ class PublicationHandler(didService: DIDService, keyResolver: KeyResolver)(maste
for {
masterKeyPair <-
keyResolver
- .getKey(state, masterKeyId)
- .mapError[E](CommonWalletStorageError.apply)
- .someOrElseZIO(
- ZIO.die(Exception("master-key must exists in the wallet for signing DID operation and submit to Node"))
- )
+ .getKey(state.did, masterKeyId)
+ .someOrFail(Exception("master-key must exists in the wallet for signing DID operation and submit to Node"))
+ .collect(Exception("master-key must be secp256k1 key")) { case keyPair: Secp256k1KeyPair => keyPair }
+ .orDie
signedOperation <- ZIO
.succeed(masterKeyPair.privateKey.sign(operation.toAtalaOperation.toByteArray))
.map(signature =>
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala
index eb14c8cf4f..8ec4b39311 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala
@@ -6,6 +6,7 @@ import doobie.postgres.implicits.*
import io.iohk.atala.agent.walletapi.model.*
import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
import io.iohk.atala.castor.core.model.did.{
+ EllipticCurve,
InternalKeyPurpose,
PrismDID,
ScheduledDIDOperationStatus,
@@ -33,7 +34,6 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
| publish_operation_id,
| created_at,
| updated_at,
- | key_mode,
| did_index,
| wallet_id
| FROM public.prism_did_wallet_state
@@ -50,7 +50,8 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
override def insertManagedDID(
did: PrismDID,
state: ManagedDIDState,
- hdKey: Map[String, ManagedDIDHdKeyPath]
+ hdKey: Map[String, ManagedDIDHdKeyPath],
+ randKey: Map[String, ManagedDIDRandKeyMeta]
): RIO[WalletAccessContext, Unit] = {
val insertStateIO = (row: DIDStateRow) => sql"""
| INSERT INTO public.prism_did_wallet_state(
@@ -60,7 +61,6 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
| publish_operation_id,
| created_at,
| updated_at,
- | key_mode,
| did_index,
| wallet_id
| )
@@ -71,7 +71,6 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
| ${row.publishOperationId},
| ${row.createdAt},
| ${row.updatedAt},
- | ${row.keyMode},
| ${row.didIndex},
| ${row.walletId}
| )
@@ -79,16 +78,34 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
val operationHash = state.createOperation.toAtalaOperationHash
val hdKeyValues = (now: Instant) =>
- hdKey.toList.map { case (key, path) => (did, key, path.keyUsage, path.keyIndex, now, operationHash) }
+ hdKey.toList.map { case (keyId, path) =>
+ (did, keyId, path.keyUsage, Some(path.keyIndex), now, operationHash, path.keyMode, path.curve)
+ }
+ val randKeyValues = (now: Instant) =>
+ randKey.toList.map { (keyId, rand) =>
+ (did, keyId, rand.keyUsage, None, now, operationHash, rand.keyMode, rand.curve)
+ }
val insertHdKeyIO =
- Update[(PrismDID, String, VerificationRelationship | InternalKeyPurpose, Int, Instant, Array[Byte])](
- "INSERT INTO public.prism_did_hd_key(did, key_id, key_usage, key_index, created_at, operation_hash) VALUES (?, ?, ?, ?, ?, ?)"
+ Update[
+ (
+ PrismDID,
+ String,
+ VerificationRelationship | InternalKeyPurpose,
+ Option[Int],
+ Instant,
+ Array[Byte],
+ KeyManagementMode,
+ EllipticCurve
+ )
+ ](
+ "INSERT INTO public.prism_did_key(did, key_id, key_usage, key_index, created_at, operation_hash, key_mode, curve_name) VALUES (?, ?, ?, ?, ?, ?, ?, ?)"
)
val txnIO = (now: Instant, walletId: WalletId) =>
for {
_ <- insertStateIO(DIDStateRow.from(did, state, now, walletId)).run
_ <- insertHdKeyIO.updateMany(hdKeyValues(now))
+ _ <- insertHdKeyIO.updateMany(randKeyValues(now))
} yield ()
for {
@@ -140,11 +157,12 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
| SELECT
| hd.key_usage AS key_usage,
| MAX(hd.key_index) AS key_index
- | FROM public.prism_did_hd_key hd
+ | FROM public.prism_did_key hd
| LEFT JOIN public.prism_did_wallet_state ws ON hd.did = ws.did
| LEFT JOIN public.prism_did_update_lineage ul ON hd.operation_hash = ul.operation_hash
| WHERE
| hd.did = $did
+ | AND hd.key_mode = ${KeyManagementMode.HD}
| AND (ul.status = $status OR (ul.status IS NULL AND hd.operation_hash = sha256(ws.atala_operation_content)))
| GROUP BY hd.did, hd.key_usage
""".stripMargin
@@ -178,15 +196,21 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
}
}
- override def getHdKeyPath(did: PrismDID, keyId: String): RIO[WalletAccessContext, Option[ManagedDIDHdKeyPath]] = {
+ override def getKeyMeta(
+ did: PrismDID,
+ keyId: String
+ ): RIO[WalletAccessContext, Option[(ManagedDIDKeyMeta, Array[Byte])]] = {
val status: ScheduledDIDOperationStatus = ScheduledDIDOperationStatus.Confirmed
val cxnIO =
sql"""
| SELECT
| ws.did_index,
| hd.key_usage,
- | hd.key_index
- | FROM public.prism_did_hd_key hd
+ | hd.key_index,
+ | hd.key_mode,
+ | hd.curve_name,
+ | hd.operation_hash
+ | FROM public.prism_did_key hd
| LEFT JOIN public.prism_did_wallet_state ws ON hd.did = ws.did
| LEFT JOIN public.prism_did_update_lineage ul ON hd.operation_hash = ul.operation_hash
| WHERE
@@ -194,10 +218,28 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
| AND hd.key_id = $keyId
| AND (ul.status = $status OR (ul.status IS NULL AND hd.operation_hash = sha256(ws.atala_operation_content)))
""".stripMargin
- .query[ManagedDIDHdKeyPath]
+ .query[
+ (
+ Option[Int],
+ VerificationRelationship | InternalKeyPurpose,
+ Option[Int],
+ KeyManagementMode,
+ EllipticCurve,
+ Array[Byte]
+ )
+ ]
.option
- cxnIO.transactWallet(xa)
+ cxnIO
+ .transactWallet(xa)
+ .flatMap {
+ case Some(Some(didIndex), keyUsage, Some(keyIndex), KeyManagementMode.HD, _, oh) =>
+ ZIO.some(ManagedDIDKeyMeta.HD(ManagedDIDHdKeyPath(didIndex, keyUsage, keyIndex)), oh)
+ case Some(_, keyUsage, _, KeyManagementMode.RANDOM, curve, oh) =>
+ ZIO.some(ManagedDIDKeyMeta.Rand(ManagedDIDRandKeyMeta(keyUsage, curve)) -> oh)
+ case None => ZIO.none
+ case _ => ZIO.dieMessage(s"Key metadata of $did#$keyId is corrupted")
+ }
}
override def listHdKeyPath(
@@ -210,8 +252,8 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
| operation_hash,
| key_usage,
| key_index
- | FROM public.prism_did_hd_key
- | WHERE did = $did
+ | FROM public.prism_did_key
+ | WHERE did = $did AND key_mode = ${KeyManagementMode.HD}
""".stripMargin
.query[(String, ArraySeq[Byte], VerificationRelationship | InternalKeyPurpose, Int)]
.to[List]
@@ -226,24 +268,29 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
}
}
- override def insertHdKeyPath(
+ override def insertKeyMeta(
did: PrismDID,
keyId: String,
- hdKeyPath: ManagedDIDHdKeyPath,
+ meta: ManagedDIDKeyMeta,
operationHash: Array[Byte]
): RIO[WalletAccessContext, Unit] = {
+ val (keyUsage, keyIndex, keyMode, curve) = meta match {
+ case ManagedDIDKeyMeta.HD(k) => (k.keyUsage, Some(k.keyIndex), k.keyMode, k.curve)
+ case ManagedDIDKeyMeta.Rand(k) => (k.keyUsage, None, k.keyMode, k.curve)
+ }
val cxnIO = (now: Instant) => sql"""
- | INSERT INTO public.prism_did_hd_key(did, key_id, key_usage, key_index, created_at, operation_hash)
+ | INSERT INTO public.prism_did_key(did, key_id, key_usage, key_index, created_at, operation_hash, key_mode, curve_name)
| VALUES
| (
| $did,
| $keyId,
- | ${hdKeyPath.keyUsage},
- | ${hdKeyPath.keyIndex},
+ | ${keyUsage},
+ | ${keyIndex},
| $now,
- | $operationHash
+ | $operationHash,
+ | ${keyMode},
+ | ${curve}
| )
- | ON CONFLICT (did, key_id, operation_hash) DO NOTHING
|""".stripMargin.update
for {
@@ -273,7 +320,6 @@ class JdbcDIDNonSecretStorage(xa: Transactor[ContextAwareTask], xb: Transactor[T
| publish_operation_id,
| created_at,
| updated_at,
- | key_mode,
| did_index,
| wallet_id
| FROM public.prism_did_wallet_state
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDSecretStorage.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDSecretStorage.scala
index 134d614c2d..dfba408e2e 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDSecretStorage.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDSecretStorage.scala
@@ -3,24 +3,24 @@ package io.iohk.atala.agent.walletapi.sql
import com.nimbusds.jose.jwk.OctetKeyPair
import doobie.*
import doobie.implicits.*
+import doobie.postgres.implicits.*
import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
+import io.iohk.atala.castor.core.model.did.PrismDID
import io.iohk.atala.mercury.model.DidId
+import io.iohk.atala.shared.crypto.jwk.FromJWK
+import io.iohk.atala.shared.crypto.jwk.JWK
import io.iohk.atala.shared.db.ContextAwareTask
import io.iohk.atala.shared.db.Implicits.*
import io.iohk.atala.shared.models.WalletAccessContext
import zio.*
import java.time.Instant
-import java.util.UUID
+import scala.language.implicitConversions
class JdbcDIDSecretStorage(xa: Transactor[ContextAwareTask]) extends DIDSecretStorage {
case class InstantAsBigInt(value: Instant)
- given uuidGet: Get[UUID] = Get[String].map(UUID.fromString)
-
- given uuidPut: Put[UUID] = Put[String].contramap(_.toString())
-
given instantGet: Get[InstantAsBigInt] = Get[Long].map(Instant.ofEpochSecond).map(InstantAsBigInt.apply)
given instantPut: Put[InstantAsBigInt] = Put[Long].contramap(_.value.getEpochSecond())
@@ -64,6 +64,61 @@ class JdbcDIDSecretStorage(xa: Transactor[ContextAwareTask]) extends DIDSecretSt
} yield result
}
+ override def insertPrismDIDKeyPair[K](
+ did: PrismDID,
+ keyId: String,
+ operationHash: Array[Byte],
+ keyPair: K
+ )(using c: Conversion[K, JWK]): URIO[WalletAccessContext, Unit] = {
+ val jwk = c(keyPair)
+ val cxnIO = (now: Instant) => sql"""
+ | INSERT INTO public.prism_did_rand_key(
+ | did,
+ | created_at,
+ | key_id,
+ | operation_hash,
+ | key_pair
+ | ) values (
+ | ${did},
+ | ${now},
+ | ${keyId},
+ | ${operationHash},
+ | ${jwk}
+ | )
+ """.stripMargin.update
+
+ for {
+ now <- Clock.instant
+ _ <- cxnIO(now).run.transactWallet(xa).orDie
+ } yield ()
+ }
+
+ override def getPrismDIDKeyPair[K](did: PrismDID, keyId: String, operationHash: Array[Byte])(using
+ c: FromJWK[K]
+ ): URIO[WalletAccessContext, Option[K]] = {
+ val cxnIO = sql"""
+ | SELECT key_pair
+ | FROM public.prism_did_rand_key
+ | WHERE
+ | did = $did
+ | AND operation_hash = $operationHash
+ | AND key_id = $keyId
+ """.stripMargin
+ .query[JWK]
+ .option
+
+ cxnIO
+ .transactWallet(xa)
+ .flatMap {
+ case None => ZIO.none
+ case Some(jwk) =>
+ ZIO
+ .fromEither(c.from(jwk))
+ .mapError(msg => Exception(s"Failed to parse key pair from JWK: $msg"))
+ .asSome
+ }
+ .orDie
+ }
}
object JdbcDIDSecretStorage {
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/package.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/package.scala
index 105699c31f..b1330ecd6c 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/package.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/package.scala
@@ -10,11 +10,13 @@ import io.circe.syntax.*
import io.iohk.atala.agent.walletapi.model.Wallet
import io.iohk.atala.agent.walletapi.model.{ManagedDIDState, PublicationState, KeyManagementMode}
import io.iohk.atala.castor.core.model.ProtoModelHelper.*
+import io.iohk.atala.castor.core.model.did.EllipticCurve
import io.iohk.atala.castor.core.model.did.InternalKeyPurpose
import io.iohk.atala.castor.core.model.did.VerificationRelationship
import io.iohk.atala.castor.core.model.did.{PrismDID, PrismDIDOperation, ScheduledDIDOperationStatus}
import io.iohk.atala.event.notification.EventNotificationConfig
import io.iohk.atala.prism.protos.node_models
+import io.iohk.atala.shared.crypto.jwk.JWK
import io.iohk.atala.shared.models.WalletId
import zio.json.*
import zio.json.ast.Json
@@ -67,10 +69,20 @@ package object sql {
given Meta[KeyManagementMode] = pgEnumString(
"PRISM_DID_KEY_MODE",
{
- case "HD" => KeyManagementMode.HD
- case s => throw InvalidEnum[KeyManagementMode](s)
+ case "HD" => KeyManagementMode.HD
+ case "RANDOM" => KeyManagementMode.RANDOM
+ case s => throw InvalidEnum[KeyManagementMode](s)
},
- { case KeyManagementMode.HD => "HD" }
+ {
+ case KeyManagementMode.HD => "HD"
+ case KeyManagementMode.RANDOM => "RANDOM"
+ }
+ )
+
+ given Meta[EllipticCurve] = pgEnumString(
+ "CURVE_NAME",
+ s => EllipticCurve.parseString(s).get,
+ _.name
)
given Meta[PublicationStatusType] = pgEnumString(
@@ -117,6 +129,9 @@ package object sql {
given octetKeyPairGet: Get[OctetKeyPair] = Get[String].map(OctetKeyPair.parse)
given octetKeyPairPut: Put[OctetKeyPair] = Put[String].contramap(_.toJSONString)
+ given jwkGet: Get[JWK] = Get[String].map(s => JWK.fromString(s).left.map(Exception(_)).toTry.get)
+ given jwkPut: Put[JWK] = Put[String].contramap(_.toJsonString)
+
given jsonGet: Get[Json] = Get[String].map(_.fromJson[Json] match {
case Right(value) => value
case Left(error) => throw new RuntimeException(error)
@@ -130,7 +145,6 @@ package object sql {
publishOperationId: Option[Array[Byte]],
createdAt: Instant,
updatedAt: Instant,
- keyMode: KeyManagementMode,
didIndex: Int,
walletId: WalletId
) {
@@ -190,7 +204,6 @@ package object sql {
publishOperationId = publishedOperationId.map(_.toArray),
createdAt = now,
updatedAt = now,
- keyMode = state.keyMode,
didIndex = state.didIndex,
walletId = walletId
)
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDNonSecretStorage.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDNonSecretStorage.scala
index fa4311a512..91a0106567 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDNonSecretStorage.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDNonSecretStorage.scala
@@ -15,7 +15,8 @@ trait DIDNonSecretStorage {
def insertManagedDID(
did: PrismDID,
state: ManagedDIDState,
- hdKey: Map[String, ManagedDIDHdKeyPath]
+ hdKey: Map[String, ManagedDIDHdKeyPath],
+ randKey: Map[String, ManagedDIDRandKeyMeta]
): RIO[WalletAccessContext, Unit]
def updateManagedDID(did: PrismDID, patch: ManagedDIDStatePatch): RIO[WalletAccessContext, Unit]
@@ -24,12 +25,12 @@ trait DIDNonSecretStorage {
def getHdKeyCounter(did: PrismDID): RIO[WalletAccessContext, Option[HdKeyIndexCounter]]
- def getHdKeyPath(did: PrismDID, keyId: String): RIO[WalletAccessContext, Option[ManagedDIDHdKeyPath]]
+ def getKeyMeta(did: PrismDID, keyId: String): RIO[WalletAccessContext, Option[(ManagedDIDKeyMeta, Array[Byte])]]
- def insertHdKeyPath(
+ def insertKeyMeta(
did: PrismDID,
keyId: String,
- hdKeyPath: ManagedDIDHdKeyPath,
+ meta: ManagedDIDKeyMeta,
operationHash: Array[Byte]
): RIO[WalletAccessContext, Unit]
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorage.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorage.scala
index 1f1e2f3f1c..52f84e3ed1 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorage.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorage.scala
@@ -1,7 +1,10 @@
package io.iohk.atala.agent.walletapi.storage
import com.nimbusds.jose.jwk.OctetKeyPair
+import io.iohk.atala.castor.core.model.did.PrismDID
import io.iohk.atala.mercury.model.DidId
+import io.iohk.atala.shared.crypto.jwk.FromJWK
+import io.iohk.atala.shared.crypto.jwk.JWK
import io.iohk.atala.shared.models.WalletAccessContext
import zio.*
@@ -9,4 +12,15 @@ import zio.*
trait DIDSecretStorage {
def insertKey(did: DidId, keyId: String, keyPair: OctetKeyPair): RIO[WalletAccessContext, Int]
def getKey(did: DidId, keyId: String): RIO[WalletAccessContext, Option[OctetKeyPair]]
+
+ def insertPrismDIDKeyPair[K](
+ did: PrismDID,
+ keyId: String,
+ operationHash: Array[Byte],
+ keyPair: K
+ )(using c: Conversion[K, JWK]): URIO[WalletAccessContext, Unit]
+
+ def getPrismDIDKeyPair[K](did: PrismDID, keyId: String, operationHash: Array[Byte])(using
+ c: FromJWK[K]
+ ): URIO[WalletAccessContext, Option[K]]
}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/KeyResolver.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/KeyResolver.scala
index d5c02f9216..487060a96b 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/KeyResolver.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/KeyResolver.scala
@@ -1,46 +1,56 @@
package io.iohk.atala.agent.walletapi.util
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.crypto.Secp256k1KeyPair
-import io.iohk.atala.agent.walletapi.model.KeyManagementMode
-import io.iohk.atala.agent.walletapi.model.ManagedDIDState
+import io.iohk.atala.agent.walletapi.model.ManagedDIDHdKeyPath
+import io.iohk.atala.agent.walletapi.model.ManagedDIDKeyMeta
+import io.iohk.atala.agent.walletapi.model.ManagedDIDRandKeyMeta
import io.iohk.atala.agent.walletapi.model.WalletSeed
import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
+import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
+import io.iohk.atala.castor.core.model.did.EllipticCurve
import io.iohk.atala.castor.core.model.did.PrismDID
+import io.iohk.atala.shared.crypto.Apollo
+import io.iohk.atala.shared.crypto.Ed25519KeyPair
+import io.iohk.atala.shared.crypto.Secp256k1KeyPair
+import io.iohk.atala.shared.crypto.X25519KeyPair
import io.iohk.atala.shared.models.WalletAccessContext
import zio.*
-class KeyResolver(apollo: Apollo, nonSecretStorage: DIDNonSecretStorage, walletSecretStorage: WalletSecretStorage) {
- def getKey(state: ManagedDIDState, keyId: String): RIO[WalletAccessContext, Option[Secp256k1KeyPair]] = {
- val did = state.createOperation.did
- getKey(did, state.keyMode, keyId)
- }
-
+class KeyResolver(
+ apollo: Apollo,
+ nonSecretStorage: DIDNonSecretStorage,
+ secretStorage: DIDSecretStorage,
+ walletSecretStorage: WalletSecretStorage
+) {
def getKey(
did: PrismDID,
- keyMode: KeyManagementMode,
keyId: String
- ): RIO[WalletAccessContext, Option[Secp256k1KeyPair]] = {
- keyMode match {
- case KeyManagementMode.HD => resolveHdKey(did, keyId)
+ ): RIO[WalletAccessContext, Option[Secp256k1KeyPair | Ed25519KeyPair | X25519KeyPair]] =
+ nonSecretStorage.getKeyMeta(did, keyId).flatMap {
+ case None => ZIO.none
+ case Some(ManagedDIDKeyMeta.HD(path), oh) => deriveHdKey(path)
+ case Some(ManagedDIDKeyMeta.Rand(meta), oh) => getRandKey(did, keyId, meta, oh)
+ }
+
+ private def deriveHdKey(path: ManagedDIDHdKeyPath): RIO[WalletAccessContext, Option[Secp256k1KeyPair]] =
+ walletSecretStorage.getWalletSeed.flatMap {
+ case None => ZIO.none
+ case Some(seed) => apollo.secp256k1.deriveKeyPair(seed.toByteArray)(path.derivationPath: _*).asSome
}
- }
- private def resolveHdKey(did: PrismDID, keyId: String): RIO[WalletAccessContext, Option[Secp256k1KeyPair]] = {
- for {
- maybeSeed <- walletSecretStorage.getWalletSeed
- maybeKeyPair <- maybeSeed.fold(ZIO.none) { seed =>
- nonSecretStorage
- .getHdKeyPath(did, keyId)
- .flatMap {
- case None => ZIO.none
- case Some(path) =>
- apollo.secp256k1
- .deriveKeyPair(seed.toByteArray)(path.derivationPath: _*)
- .asSome
- }
- }
- } yield maybeKeyPair
+ private def getRandKey(
+ did: PrismDID,
+ keyId: String,
+ meta: ManagedDIDRandKeyMeta,
+ operationHash: Array[Byte]
+ ): RIO[WalletAccessContext, Option[Ed25519KeyPair | X25519KeyPair]] = {
+ meta.curve match {
+ case EllipticCurve.SECP256K1 =>
+ ZIO.die(Exception("Reading secp256k1 random key is not yet supported"))
+ case EllipticCurve.ED25519 =>
+ secretStorage.getPrismDIDKeyPair[Ed25519KeyPair](did, keyId, operationHash)
+ case EllipticCurve.X25519 =>
+ secretStorage.getPrismDIDKeyPair[X25519KeyPair](did, keyId, operationHash)
+ }
}
}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidator.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidator.scala
index 2734901a42..93c7ffe99a 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidator.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidator.scala
@@ -2,10 +2,16 @@ package io.iohk.atala.agent.walletapi.util
import io.iohk.atala.agent.walletapi.model.ManagedDIDTemplate
import io.iohk.atala.agent.walletapi.service.ManagedDIDService
+import io.iohk.atala.castor.core.model.did.EllipticCurve
+import io.iohk.atala.castor.core.model.did.VerificationRelationship
object ManagedDIDTemplateValidator {
- def validate(template: ManagedDIDTemplate): Either[String, Unit] = validateReservedKeyId(template)
+ def validate(template: ManagedDIDTemplate): Either[String, Unit] =
+ for {
+ _ <- validateReservedKeyId(template)
+ _ <- validateCurveUsage(template)
+ } yield ()
private def validateReservedKeyId(template: ManagedDIDTemplate): Either[String, Unit] = {
val keyIds = template.publicKeys.map(_.id)
@@ -15,4 +21,26 @@ object ManagedDIDTemplateValidator {
else Right(())
}
+ private def validateCurveUsage(template: ManagedDIDTemplate): Either[String, Unit] = {
+ val ed25519AllowedUsage = Set(VerificationRelationship.Authentication, VerificationRelationship.AssertionMethod)
+ val x25519AllowedUsage = Set(VerificationRelationship.KeyAgreement)
+ val disallowedKeys = template.publicKeys
+ .filter { k =>
+ k.curve match {
+ case EllipticCurve.ED25519 => !ed25519AllowedUsage.contains(k.purpose)
+ case EllipticCurve.X25519 => !x25519AllowedUsage.contains(k.purpose)
+ case _ => false
+ }
+ }
+ .map(_.id)
+
+ if (disallowedKeys.isEmpty) Right(())
+ else
+ Left(
+ s"Invalid key purpose for key ${disallowedKeys.mkString("[", ", ", "]")}. " +
+ s"Ed25519 must be used in ${ed25519AllowedUsage.mkString("[", ", ", "]")}. " +
+ s"X25519 must be used in ${x25519AllowedUsage.mkString("[", ", ", "]")}"
+ )
+ }
+
}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/OperationFactory.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/OperationFactory.scala
index 883ea4b9a0..e94cb31582 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/OperationFactory.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/OperationFactory.scala
@@ -1,32 +1,22 @@
package io.iohk.atala.agent.walletapi.util
-import io.iohk.atala.agent.walletapi.model.HdKeyIndexCounter
-import io.iohk.atala.agent.walletapi.model.ManagedDIDHdKeyPath
+import io.iohk.atala.agent.walletapi.model.*
import io.iohk.atala.agent.walletapi.model.error.{CreateManagedDIDError, UpdateManagedDIDError}
-import io.iohk.atala.agent.walletapi.model.{
- DIDPublicKeyTemplate,
- ManagedDIDTemplate,
- UpdateManagedDIDAction,
- CreateDIDHdKey,
- CreateDIDRandKey,
- UpdateDIDHdKey,
- UpdateDIDRandKey
+import io.iohk.atala.castor.core.model.did.*
+import io.iohk.atala.shared.crypto.{
+ Apollo,
+ Ed25519KeyPair,
+ Ed25519PublicKey,
+ Secp256k1KeyPair,
+ Secp256k1PublicKey,
+ X25519KeyPair,
+ X25519PublicKey
}
-import io.iohk.atala.castor.core.model.did.EllipticCurve
-import io.iohk.atala.castor.core.model.did.{
- CanonicalPrismDID,
- InternalKeyPurpose,
- InternalPublicKey,
- PrismDIDOperation,
- PublicKey,
- PublicKeyData,
- UpdateDIDAction
-}
-import io.iohk.atala.shared.crypto.{Apollo, Secp256k1KeyPair as ECKeyPair, Secp256k1PublicKey as ECPublicKey}
import io.iohk.atala.shared.models.Base64UrlString
import zio.*
import scala.collection.immutable.ArraySeq
+import scala.language.implicitConversions
private[util] final case class KeyDerivationOutcome[PK](
publicKey: PK,
@@ -34,6 +24,11 @@ private[util] final case class KeyDerivationOutcome[PK](
nextCounter: HdKeyIndexCounter
)
+private[util] final case class KeyGenerationOutcome(
+ publicKey: PublicKey,
+ key: ManagedDIDRandKeyPair
+)
+
class OperationFactory(apollo: Apollo) {
/** Generates a key pair and a public key from a DID template
@@ -47,119 +42,94 @@ class OperationFactory(apollo: Apollo) {
* @param didIndex
* The index of the DID to be used for the key derivation
*/
- def makeCreateOperationHdKey(
+ def makeCreateOperation(
masterKeyId: String,
seed: Array[Byte]
)(
didIndex: Int,
didTemplate: ManagedDIDTemplate
- ): IO[CreateManagedDIDError, (PrismDIDOperation.Create, CreateDIDHdKey)] = {
- val initKeysWithCounter = (Vector.empty[(PublicKey, ManagedDIDHdKeyPath)], HdKeyIndexCounter.zero(didIndex))
+ ): IO[CreateManagedDIDError, (PrismDIDOperation.Create, CreateDIDKey)] = {
+ val initKeysWithCounter = (Vector.empty[KeyDerivationOutcome[PublicKey]], HdKeyIndexCounter.zero(didIndex))
+ val (hdKeysTemplate, randKeysTemplate) = didTemplate.publicKeys.partition(_.curve == EllipticCurve.SECP256K1)
for {
- keysWithCounter <- ZIO.foldLeft(didTemplate.publicKeys)(initKeysWithCounter) {
- case ((keys, keyCounter), template) =>
- derivePublicKey(seed)(template, keyCounter)
- .map { outcome =>
- val newKeys = keys :+ (outcome.publicKey, outcome.path)
- (newKeys, outcome.nextCounter)
- }
+ randKeys <- ZIO.foreach(randKeysTemplate)(generatePublicKey)
+ hdKeysWithCounter <- ZIO.foldLeft(hdKeysTemplate)(initKeysWithCounter) { case ((keys, keyCounter), template) =>
+ derivePublicKey(seed)(template, keyCounter)
+ .map(outcome => (keys :+ outcome, outcome.nextCounter))
}
masterKeyOutcome <- deriveInternalPublicKey(seed)(
masterKeyId,
InternalKeyPurpose.Master,
- keysWithCounter._2
+ hdKeysWithCounter._2
)
operation = PrismDIDOperation.Create(
- publicKeys = keysWithCounter._1.map(_._1) ++ Seq(masterKeyOutcome.publicKey),
+ publicKeys = hdKeysWithCounter._1.map(_._1) ++ randKeys.map(_.publicKey) ++ Seq(masterKeyOutcome.publicKey),
services = didTemplate.services,
context = didTemplate.contexts
)
- hdKeys = CreateDIDHdKey(
- keyPaths = keysWithCounter._1.map { case (publicKey, path) => publicKey.id -> path }.toMap,
- internalKeyPaths = Map(masterKeyOutcome.publicKey.id -> masterKeyOutcome.path),
+ keys = CreateDIDKey(
+ hdKeys = hdKeysWithCounter._1.map(i => i.publicKey.id -> i.path).toMap ++
+ Map(masterKeyOutcome.publicKey.id -> masterKeyOutcome.path),
+ randKeys = randKeys.map(i => i.publicKey.id -> i.key).toMap,
)
- } yield operation -> hdKeys
+ } yield operation -> keys
}
- def makeCreateOperationRandKey(
- masterKeyId: String
- )(didTemplate: ManagedDIDTemplate): IO[CreateManagedDIDError, (PrismDIDOperation.Create, CreateDIDRandKey)] = {
- for {
- randomSeed <- apollo.secp256k1.randomBip32Seed.map(_._1)
- operationWithHdKey <- makeCreateOperationHdKey(masterKeyId, randomSeed)(0, didTemplate)
- (operation, hdKeys) = operationWithHdKey
- keyPairs <- ZIO.foreach(hdKeys.keyPaths) { case (id, path) =>
- deriveSecp256k1KeyPair(randomSeed, path).map(id -> _)
- }
- internalKeyPairs <- ZIO.foreach(hdKeys.internalKeyPaths) { case (id, path) =>
- deriveSecp256k1KeyPair(randomSeed, path).map(id -> _)
- }
- } yield operation -> CreateDIDRandKey(
- keyPairs = keyPairs,
- internalKeyPairs = internalKeyPairs
- )
- }
-
- def makeUpdateOperationHdKey(seed: Array[Byte])(
+ def makeUpdateOperation(seed: Array[Byte])(
did: CanonicalPrismDID,
previousOperationHash: Array[Byte],
actions: Seq[UpdateManagedDIDAction],
fromKeyCounter: HdKeyIndexCounter
- ): IO[UpdateManagedDIDError, (PrismDIDOperation.Update, UpdateDIDHdKey)] = {
+ ): IO[UpdateManagedDIDError, (PrismDIDOperation.Update, UpdateDIDKey)] = {
val initKeysWithCounter =
- (Vector.empty[(UpdateManagedDIDAction, Option[(PublicKey, ManagedDIDHdKeyPath)])], fromKeyCounter)
+ (
+ Vector.empty[(UpdateManagedDIDAction, Option[(PublicKey, ManagedDIDHdKeyPath | ManagedDIDRandKeyPair)])],
+ fromKeyCounter
+ )
val actionsWithKeyMaterial = ZIO.foldLeft(actions)(initKeysWithCounter) { case ((acc, keyCounter), action) =>
- val derivation = action match {
- case UpdateManagedDIDAction.AddKey(template) => derivePublicKey(seed)(template, keyCounter).asSome
- case _ => ZIO.none
+ val outcome: UIO[Option[KeyGenerationOutcome | KeyDerivationOutcome[PublicKey]]] = action match {
+ case UpdateManagedDIDAction.AddKey(template) =>
+ if template.curve == EllipticCurve.SECP256K1
+ then derivePublicKey(seed)(template, keyCounter).asSome
+ else generatePublicKey(template).asSome
+ case _ => ZIO.none
}
- derivation.map {
- case Some(outcome) => (acc :+ (action -> Some((outcome.publicKey, outcome.path))), outcome.nextCounter)
- case None => (acc :+ (action -> None), keyCounter)
+ outcome.map {
+ case Some(outcome: KeyDerivationOutcome[PublicKey]) =>
+ (acc :+ (action -> Some((outcome.publicKey, outcome.path))), outcome.nextCounter)
+ case Some(outcome: KeyGenerationOutcome) =>
+ (acc :+ (action -> Some((outcome.publicKey, outcome.key))), keyCounter)
+ case None =>
+ (acc :+ (action -> None), keyCounter)
}
}
for {
actionsWithKeyMaterial <- actionsWithKeyMaterial
- (actionWithHdKey, keyCounter) = actionsWithKeyMaterial
- transformedActions <- ZIO.foreach(actionWithHdKey) { case (action, keyMaterial) =>
+ (actionWithKey, keyCounter) = actionsWithKeyMaterial
+ transformedActions <- ZIO.foreach(actionWithKey) { case (action, keyMaterial) =>
transformUpdateAction(action, keyMaterial.map(_._1))
}
- keys = actionWithHdKey.collect { case (UpdateManagedDIDAction.AddKey(_), Some(secret)) => secret }
+ keys = actionWithKey.collect { case (UpdateManagedDIDAction.AddKey(_), Some(secret)) => secret }
+ (randKeys, hdKeys) = keys.partitionMap {
+ case (pk, hdPath: ManagedDIDHdKeyPath) => Right(pk.id -> hdPath)
+ case (pk, keyPair: ManagedDIDRandKeyPair) => Left(pk.id -> keyPair)
+ }
operation = PrismDIDOperation.Update(
did = did,
previousOperationHash = ArraySeq.from(previousOperationHash),
actions = transformedActions
)
- hdKeys = UpdateDIDHdKey(
+ updateKey = UpdateDIDKey(
// NOTE: Prism DID specification currently doesn't allow updating existing key with the same key-id.
// Duplicated key-id in AddKey action can be ignored as the specification will reject the whole update operation.
// If the specification supports updating existing key, the key that will be stored in the wallet
// MUST be aligned with the spec (e.g. keep first / keep last in the action list)
- newKeyPaths = keys.map { case (publicKey, path) => publicKey.id -> path }.toMap,
+ hdKeys = hdKeys.toMap,
+ randKeys = randKeys.toMap,
counter = keyCounter
)
- } yield operation -> hdKeys
- }
-
- def makeUpdateOperationRandKey(
- did: CanonicalPrismDID,
- previousOperationHash: Array[Byte],
- actions: Seq[UpdateManagedDIDAction]
- ): IO[UpdateManagedDIDError, (PrismDIDOperation.Update, UpdateDIDRandKey)] = {
- for {
- randomSeed <- apollo.secp256k1.randomBip32Seed.map(_._1)
- operationWithHdKey <- makeUpdateOperationHdKey(randomSeed)(
- did,
- previousOperationHash,
- actions,
- HdKeyIndexCounter.zero(0)
- )
- (operation, hdKeys) = operationWithHdKey
- keyPairs <- ZIO.foreach(hdKeys.newKeyPaths) { case (id, path) =>
- deriveSecp256k1KeyPair(randomSeed, path).map(id -> _)
- }
- } yield operation -> UpdateDIDRandKey(newKeyPairs = keyPairs)
+ } yield operation -> updateKey
}
private def transformUpdateAction(
@@ -183,6 +153,24 @@ class OperationFactory(apollo: Apollo) {
}
}
+ private def generatePublicKey(template: DIDPublicKeyTemplate): UIO[KeyGenerationOutcome] = {
+ ZIO.attempt {
+ val (publicKeyData, keyPair) = template.curve match {
+ case EllipticCurve.SECP256K1 => throw Exception("secp256k1 key must be derived, not randomly generated")
+ case EllipticCurve.ED25519 =>
+ val kp = apollo.ed25519.generateKeyPair
+ toPublicKeyData(kp.publicKey) -> kp
+ case EllipticCurve.X25519 =>
+ val kp = apollo.x25519.generateKeyPair
+ toPublicKeyData(kp.publicKey) -> kp
+ }
+ KeyGenerationOutcome(
+ publicKey = PublicKey(template.id, template.purpose, publicKeyData),
+ key = ManagedDIDRandKeyPair(template.purpose, keyPair)
+ )
+ }.orDie
+ }
+
private def derivePublicKey(seed: Array[Byte])(
template: DIDPublicKeyTemplate,
keyCounter: HdKeyIndexCounter
@@ -207,12 +195,26 @@ class OperationFactory(apollo: Apollo) {
} yield KeyDerivationOutcome(internalPublicKey, keyPath, keyCounter.next(purpose))
}
- private def deriveSecp256k1KeyPair(seed: Array[Byte], path: ManagedDIDHdKeyPath): UIO[ECKeyPair] =
+ private def deriveSecp256k1KeyPair(seed: Array[Byte], path: ManagedDIDHdKeyPath): UIO[Secp256k1KeyPair] =
apollo.secp256k1.deriveKeyPair(seed)(path.derivationPath: _*)
- private def toPublicKeyData(publicKey: ECPublicKey): PublicKeyData = PublicKeyData.ECCompressedKeyData(
- crv = EllipticCurve.SECP256K1,
- data = Base64UrlString.fromByteArray(publicKey.getEncodedCompressed),
- )
+ private def toPublicKeyData(publicKey: Secp256k1PublicKey | Ed25519PublicKey | X25519PublicKey): PublicKeyData =
+ publicKey match {
+ case pk: Secp256k1PublicKey =>
+ PublicKeyData.ECCompressedKeyData(
+ crv = EllipticCurve.SECP256K1,
+ data = Base64UrlString.fromByteArray(pk.getEncodedCompressed),
+ )
+ case pk: Ed25519PublicKey =>
+ PublicKeyData.ECCompressedKeyData(
+ crv = EllipticCurve.ED25519,
+ data = Base64UrlString.fromByteArray(publicKey.getEncoded),
+ )
+ case pk: X25519PublicKey =>
+ PublicKeyData.ECCompressedKeyData(
+ crv = EllipticCurve.X25519,
+ data = Base64UrlString.fromByteArray(publicKey.getEncoded),
+ )
+ }
}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultDIDSecretStorage.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultDIDSecretStorage.scala
index 133572740c..27ce96f99d 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultDIDSecretStorage.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultDIDSecretStorage.scala
@@ -2,8 +2,12 @@ package io.iohk.atala.agent.walletapi.vault
import com.nimbusds.jose.jwk.OctetKeyPair
import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
+import io.iohk.atala.castor.core.model.did.PrismDID
import io.iohk.atala.mercury.model.DidId
import io.iohk.atala.prism.crypto.Sha256
+import io.iohk.atala.shared.crypto.jwk.FromJWK
+import io.iohk.atala.shared.crypto.jwk.JWK
+import io.iohk.atala.shared.models.HexString
import io.iohk.atala.shared.models.WalletAccessContext
import io.iohk.atala.shared.models.WalletId
import zio.*
@@ -32,6 +36,37 @@ class VaultDIDSecretStorage(vaultKV: VaultKVClient, useSemanticPath: Boolean) ex
} yield keyPair
}
+ override def insertPrismDIDKeyPair[K](
+ did: PrismDID,
+ keyId: String,
+ operationHash: Array[Byte],
+ keyPair: K
+ )(using c: Conversion[K, JWK]): URIO[WalletAccessContext, Unit] = {
+ for {
+ walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId)
+ (path, metadata) = prismDIDKeyPath(walletId)(did, keyId, operationHash)
+ alreadyExist <- vaultKV.get[JWK](path).map(_.isDefined)
+ jwk = c(keyPair)
+ _ <- vaultKV
+ .set[JWK](path, jwk, metadata)
+ .when(!alreadyExist)
+ .someOrFail(Exception(s"Secret on path $path already exists."))
+ } yield ()
+ }.orDie
+
+ override def getPrismDIDKeyPair[K](did: PrismDID, keyId: String, operationHash: Array[Byte])(using
+ c: FromJWK[K]
+ ): URIO[WalletAccessContext, Option[K]] = {
+ for {
+ walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId)
+ (path, _) = prismDIDKeyPath(walletId)(did, keyId, operationHash: Array[Byte])
+ keyPair <- vaultKV.get[JWK](path).flatMap {
+ case None => ZIO.none
+ case Some(jwk) => ZIO.fromEither(c.from(jwk)).mapError(Exception(_)).asSome
+ }
+ } yield keyPair
+ }.orDie
+
/** @return A tuple of secret path and a secret custom_metadata */
private def peerDidKeyPath(walletId: WalletId)(did: DidId, keyId: String): (String, Map[String, String]) = {
val basePath = s"${walletBasePath(walletId)}/dids/peer"
@@ -43,6 +78,20 @@ class VaultDIDSecretStorage(vaultKV: VaultKVClient, useSemanticPath: Boolean) ex
s"$basePath/$relativePathHash" -> Map(SEMANTIC_PATH_METADATA_KEY -> relativePath)
}
}
+
+ /** @return A tuple of secret path and a secret custom_metadata */
+ private def prismDIDKeyPath(
+ walletId: WalletId
+ )(did: PrismDID, keyId: String, operationHash: Array[Byte]): (String, Map[String, String]) = {
+ val basePath = s"${walletBasePath(walletId)}/dids/prism"
+ val relativePath = s"${did.asCanonical}/keys/$keyId/${HexString.fromByteArray(operationHash)}"
+ if (useSemanticPath) {
+ s"$basePath/$relativePath" -> Map.empty
+ } else {
+ val relativePathHash = Sha256.compute(relativePath.getBytes(StandardCharsets.UTF_8)).getHexValue()
+ s"$basePath/$relativePathHash" -> Map(SEMANTIC_PATH_METADATA_KEY -> relativePath)
+ }
+ }
}
object VaultDIDSecretStorage {
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/package.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/package.scala
index 2576b73a6b..3b5822a0dd 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/package.scala
+++ b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/package.scala
@@ -2,6 +2,7 @@ package io.iohk.atala.agent.walletapi
import com.nimbusds.jose.jwk.OctetKeyPair
import io.iohk.atala.agent.walletapi.model.WalletSeed
+import io.iohk.atala.shared.crypto.jwk.JWK
import io.iohk.atala.shared.models.HexString
import io.iohk.atala.shared.models.WalletId
import zio.json.*
@@ -68,4 +69,15 @@ package object vault {
.toTry
} yield keyPair
}
+
+ given KVCodec[JWK] = new {
+ override def encode(value: JWK): Map[String, String] =
+ Map("value" -> value.toJsonString)
+
+ override def decode(kv: Map[String, String]): Try[JWK] =
+ for {
+ json <- kv.get("value").toRight(Exception("A property 'value' is missing from vault KV data")).toTry
+ jwk <- JWK.fromString(json).left.map(Exception(_)).toTry
+ } yield jwk
+ }
}
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/benchmark/KeyDerivation.scala b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/benchmark/KeyDerivation.scala
index dede81bd06..981b934fad 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/benchmark/KeyDerivation.scala
+++ b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/benchmark/KeyDerivation.scala
@@ -77,7 +77,7 @@ object KeyDerivation extends ZIOSpecDefault, VaultTestContainerSupport {
for {
vaultClient <- ZIO.service[VaultKVClient]
apollo <- ZIO.service[Apollo]
- keyPair <- apollo.secp256k1.generateKeyPair
+ keyPair = apollo.secp256k1.generateKeyPair
_ <- ZIO
.foreach(1 to 50_000) { i =>
given KVCodec[Secp256k1PrivateKey] = codec(apollo)
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceSpec.scala b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceSpec.scala
index b7474f4d94..5ffc724abf 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceSpec.scala
+++ b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceSpec.scala
@@ -238,8 +238,8 @@ object ManagedDIDServiceSpec
test("create and store DID secret in DIDSecretStorage") {
val template = generateDIDTemplate(
publicKeys = Seq(
- DIDPublicKeyTemplate("key1", VerificationRelationship.Authentication),
- DIDPublicKeyTemplate("key2", VerificationRelationship.KeyAgreement)
+ DIDPublicKeyTemplate("key1", VerificationRelationship.Authentication, EllipticCurve.SECP256K1),
+ DIDPublicKeyTemplate("key2", VerificationRelationship.KeyAgreement, EllipticCurve.SECP256K1)
)
)
for {
@@ -251,9 +251,9 @@ object ManagedDIDServiceSpec
test("created DID have corresponding public keys in CreateOperation") {
val template = generateDIDTemplate(
publicKeys = Seq(
- DIDPublicKeyTemplate("key1", VerificationRelationship.Authentication),
- DIDPublicKeyTemplate("key2", VerificationRelationship.KeyAgreement),
- DIDPublicKeyTemplate("key3", VerificationRelationship.AssertionMethod)
+ DIDPublicKeyTemplate("key1", VerificationRelationship.Authentication, EllipticCurve.SECP256K1),
+ DIDPublicKeyTemplate("key2", VerificationRelationship.KeyAgreement, EllipticCurve.SECP256K1),
+ DIDPublicKeyTemplate("key3", VerificationRelationship.AssertionMethod, EllipticCurve.SECP256K1)
)
)
for {
@@ -289,7 +289,7 @@ object ManagedDIDServiceSpec
// this template will fail during validation for reserved key id
val template = generateDIDTemplate(
publicKeys = Seq(
- DIDPublicKeyTemplate("master0", VerificationRelationship.Authentication)
+ DIDPublicKeyTemplate("master0", VerificationRelationship.Authentication, EllipticCurve.SECP256K1)
)
)
val result = ZIO.serviceWithZIO[ManagedDIDService](_.createAndStoreDID(template))
@@ -394,7 +394,9 @@ object ManagedDIDServiceSpec
did <- initPublishedDID
_ <- testDIDSvc.setResolutionResult(Some(resolutionResult()))
actions = Seq("key-1", "key-2").map(id =>
- UpdateManagedDIDAction.AddKey(DIDPublicKeyTemplate(id, VerificationRelationship.Authentication))
+ UpdateManagedDIDAction.AddKey(
+ DIDPublicKeyTemplate(id, VerificationRelationship.Authentication, EllipticCurve.SECP256K1)
+ )
)
_ <- svc.updateManagedDID(did, actions)
keyPaths <- svc.nonSecretStorage.listHdKeyPath(did)
@@ -409,7 +411,9 @@ object ManagedDIDServiceSpec
did <- initPublishedDID
_ <- testDIDSvc.setResolutionResult(Some(resolutionResult()))
actions = Seq("key-1", "key-2").map(id =>
- UpdateManagedDIDAction.AddKey(DIDPublicKeyTemplate(id, VerificationRelationship.Authentication))
+ UpdateManagedDIDAction.AddKey(
+ DIDPublicKeyTemplate(id, VerificationRelationship.Authentication, EllipticCurve.SECP256K1)
+ )
)
_ <- svc.updateManagedDID(did, actions) // 1st update
_ <- svc.updateManagedDID(did, actions.take(1)) // 2nd update: key-1 is added twice
@@ -431,7 +435,9 @@ object ManagedDIDServiceSpec
_ <- ZIO.foreach(1 to 5) { i =>
val actions =
Seq(
- UpdateManagedDIDAction.AddKey(DIDPublicKeyTemplate(s"key-$i", VerificationRelationship.Authentication))
+ UpdateManagedDIDAction.AddKey(
+ DIDPublicKeyTemplate(s"key-$i", VerificationRelationship.Authentication, EllipticCurve.SECP256K1)
+ )
)
svc.updateManagedDID(did, actions)
}
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorageSpec.scala b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorageSpec.scala
index 3822e6f195..974c885f12 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorageSpec.scala
+++ b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorageSpec.scala
@@ -1,7 +1,5 @@
package io.iohk.atala.agent.walletapi.storage
-import io.iohk.atala.agent.walletapi.memory.DIDSecretStorageInMemory
-import io.iohk.atala.agent.walletapi.memory.WalletSecretStorageInMemory
import io.iohk.atala.agent.walletapi.model.Wallet
import io.iohk.atala.agent.walletapi.service.{WalletManagementService, WalletManagementServiceImpl}
import io.iohk.atala.agent.walletapi.sql.{
@@ -75,23 +73,10 @@ object DIDSecretStorageSpec
ZLayer.succeed(WalletAdministrationContext.Admin())
)
- val inMemoryTestSuite = commonSpec("InMemoryDIDSecretStorage")
- .provide(
- JdbcDIDNonSecretStorage.layer,
- DIDSecretStorageInMemory.layer,
- WalletSecretStorageInMemory.layer,
- systemTransactorLayer,
- contextAwareTransactorLayer,
- pgContainerLayer,
- walletManagementServiceLayer,
- ZLayer.succeed(WalletAdministrationContext.Admin())
- )
-
suite("DIDSecretStorage")(
jdbcTestSuite,
vaultTestSuite,
vaultFsTestSuite,
- inMemoryTestSuite
) @@ TestAspect.sequential
}
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcDIDNonSecretStorageSpec.scala b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcDIDNonSecretStorageSpec.scala
index 1762405ae2..3ab5831ce1 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcDIDNonSecretStorageSpec.scala
+++ b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcDIDNonSecretStorageSpec.scala
@@ -34,6 +34,7 @@ object JdbcDIDNonSecretStorageSpec
_ <- storage.insertManagedDID(
op.did,
ManagedDIDState(op, idx, PublicationState.Created()),
+ Map.empty,
Map.empty
)
_ <- TestClock.adjust(delay)
@@ -75,16 +76,18 @@ object JdbcDIDNonSecretStorageSpec
storage <- ZIO.service[DIDNonSecretStorage]
did1 = PrismDID.buildCanonicalFromSuffix("0" * 64).toOption.get
did2 = PrismDID.buildCanonicalFromSuffix("1" * 64).toOption.get
- createOperation1 <- generateCreateOperation(Seq("key-1")).map(_._1)
- createOperation2 <- generateCreateOperation(Seq("key-1")).map(_._1)
+ createOperation1 <- generateCreateOperation(Seq("key-1"), 0).map(_._1)
+ createOperation2 <- generateCreateOperation(Seq("key-1"), 1).map(_._1)
_ <- storage.insertManagedDID(
did1,
ManagedDIDState(createOperation1, 0, PublicationState.Created()),
+ Map.empty,
Map.empty
)
_ <- storage.insertManagedDID(
did2,
ManagedDIDState(createOperation2, 1, PublicationState.Created()),
+ Map.empty,
Map.empty
)
states <- storage.listManagedDID(None, None).map(_._1)
@@ -93,7 +96,7 @@ object JdbcDIDNonSecretStorageSpec
test("list stored dids and return correct item count when using offset and limit") {
for {
storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(_ => generateCreateOperation(Seq("key-1")).map(_._1))
+ operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
_ <- insertDIDStateWithDelay(operations, 100.millis)
resultsWithCount <- storage.listManagedDID(offset = Some(20), limit = Some(10))
(results, count) = resultsWithCount
@@ -103,7 +106,7 @@ object JdbcDIDNonSecretStorageSpec
test("list stored dids and return correct item count when using offset only") {
for {
storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(_ => generateCreateOperation(Seq("key-1")).map(_._1))
+ operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
_ <- insertDIDStateWithDelay(operations, 100.millis)
resultsWithCount <- storage.listManagedDID(offset = Some(20), limit = None)
(results, count) = resultsWithCount
@@ -113,7 +116,7 @@ object JdbcDIDNonSecretStorageSpec
test("list stored dids and return correct item count when using limit only") {
for {
storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(_ => generateCreateOperation(Seq("key-1")).map(_._1))
+ operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
_ <- insertDIDStateWithDelay(operations, 100.millis)
resultsWithCount <- storage.listManagedDID(offset = None, limit = Some(10))
(results, count) = resultsWithCount
@@ -123,7 +126,7 @@ object JdbcDIDNonSecretStorageSpec
test("return empty list when limit is zero") {
for {
storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(_ => generateCreateOperation(Seq("key-1")).map(_._1))
+ operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
_ <- insertDIDStateWithDelay(operations, 100.millis)
resultsWithCount <- storage.listManagedDID(offset = None, limit = Some(0))
(results, count) = resultsWithCount
@@ -133,7 +136,7 @@ object JdbcDIDNonSecretStorageSpec
test("fail when limit is negative") {
for {
storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(_ => generateCreateOperation(Seq("key-1")).map(_._1))
+ operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
_ <- insertDIDStateWithDelay(operations, 100.millis)
exit <- storage.listManagedDID(offset = None, limit = Some(-1)).exit
} yield assert(exit)(
@@ -145,7 +148,7 @@ object JdbcDIDNonSecretStorageSpec
test("fail when offset is negative") {
for {
storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(_ => generateCreateOperation(Seq("key-1")).map(_._1))
+ operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
_ <- insertDIDStateWithDelay(operations, 100.millis)
exit <- storage.listManagedDID(offset = Some(-1), limit = None).exit
} yield assert(exit)(
@@ -174,12 +177,12 @@ object JdbcDIDNonSecretStorageSpec
(3, PublicationState.Published(ArraySeq.fill(32)(1))),
)
states <- ZIO.foreach(inputs) { case (didIndex, publicationState) =>
- val operation = generateCreateOperationHdKey(Seq("key-1"), didIndex).map(_._1)
+ val operation = generateCreateOperation(Seq("key-1"), didIndex).map(_._1)
operation.map(o => ManagedDIDState(o, didIndex, publicationState))
}
readStates <- ZIO.foreach(states) { state =>
for {
- _ <- storage.insertManagedDID(state.createOperation.did, state, Map.empty)
+ _ <- storage.insertManagedDID(state.createOperation.did, state, Map.empty, Map.empty)
readState <- storage.getManagedDIDState(state.createOperation.did)
} yield readState
}
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/StorageSpecHelper.scala b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/StorageSpecHelper.scala
index e8ba0ffad5..1670b6b1e1 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/StorageSpecHelper.scala
+++ b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/StorageSpecHelper.scala
@@ -8,6 +8,7 @@ import io.iohk.atala.agent.walletapi.model.PublicationState
import io.iohk.atala.agent.walletapi.model.Wallet
import io.iohk.atala.agent.walletapi.service.WalletManagementService
import io.iohk.atala.agent.walletapi.util.OperationFactory
+import io.iohk.atala.castor.core.model.did.EllipticCurve
import io.iohk.atala.castor.core.model.did.PrismDID
import io.iohk.atala.castor.core.model.did.PrismDIDOperation
import io.iohk.atala.castor.core.model.did.ScheduledDIDOperationStatus
@@ -39,20 +40,12 @@ trait StorageSpecHelper extends ApolloSpecHelper {
protected def generateKeyPair() = apollo.secp256k1.generateKeyPair
- protected def generateCreateOperation(keyIds: Seq[String]) =
- OperationFactory(apollo).makeCreateOperationRandKey("master0")(
- ManagedDIDTemplate(
- publicKeys = keyIds.map(DIDPublicKeyTemplate(_, VerificationRelationship.Authentication)),
- services = Nil,
- contexts = Nil
- )
- )
-
- protected def generateCreateOperationHdKey(keyIds: Seq[String], didIndex: Int) =
- OperationFactory(apollo).makeCreateOperationHdKey("master0", Array.fill(64)(0))(
+ protected def generateCreateOperation(keyIds: Seq[String], didIndex: Int) =
+ OperationFactory(apollo).makeCreateOperation("master0", Array.fill(64)(0))(
didIndex,
ManagedDIDTemplate(
- publicKeys = keyIds.map(DIDPublicKeyTemplate(_, VerificationRelationship.Authentication)),
+ publicKeys =
+ keyIds.map(DIDPublicKeyTemplate(_, VerificationRelationship.Authentication, EllipticCurve.SECP256K1)),
services = Nil,
contexts = Nil
)
@@ -61,13 +54,14 @@ trait StorageSpecHelper extends ApolloSpecHelper {
protected def initializeDIDStateAndKeys(keyIds: Seq[String] = Nil, didIndex: Int) = {
for {
nonSecretStorage <- ZIO.service[DIDNonSecretStorage]
- generated <- generateCreateOperationHdKey(keyIds, didIndex)
- (createOperation, hdKeys) = generated
+ generated <- generateCreateOperation(keyIds, didIndex)
+ (createOperation, keys) = generated
did = createOperation.did
_ <- nonSecretStorage.insertManagedDID(
did,
ManagedDIDState(createOperation, didIndex, PublicationState.Created()),
- hdKeys.keyPaths ++ hdKeys.internalKeyPaths
+ keys.hdKeys,
+ keys.randKeyMeta
)
} yield did
}
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala
index cae3258cd1..f8bfb61541 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala
+++ b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala
@@ -2,15 +2,17 @@ package io.iohk.atala.agent.walletapi.util
import io.iohk.atala.agent.walletapi.model.{DIDPublicKeyTemplate, ManagedDIDTemplate}
import io.iohk.atala.agent.walletapi.service.ManagedDIDService
+import io.iohk.atala.castor.core.model.did.EllipticCurve
import io.iohk.atala.castor.core.model.did.ServiceEndpoint
import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriValue
import io.iohk.atala.castor.core.model.did.{Service, ServiceType, VerificationRelationship}
-import scala.language.implicitConversions
import zio.*
import zio.test.*
import zio.test.Assertion.*
+import scala.language.implicitConversions
+
object ManagedDIDTemplateValidatorSpec extends ZIOSpecDefault {
override def spec = suite("ManagedDIDTemplateValidator")(
@@ -23,7 +25,8 @@ object ManagedDIDTemplateValidatorSpec extends ZIOSpecDefault {
publicKeys = Seq(
DIDPublicKeyTemplate(
id = "auth0",
- purpose = VerificationRelationship.Authentication
+ purpose = VerificationRelationship.Authentication,
+ curve = EllipticCurve.SECP256K1
)
),
services = Seq(
@@ -42,7 +45,8 @@ object ManagedDIDTemplateValidatorSpec extends ZIOSpecDefault {
publicKeys = Seq(
DIDPublicKeyTemplate(
id = ManagedDIDService.DEFAULT_MASTER_KEY_ID,
- purpose = VerificationRelationship.Authentication
+ purpose = VerificationRelationship.Authentication,
+ curve = EllipticCurve.SECP256K1
)
),
services = Nil,
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/OperationFactorySpec.scala b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/OperationFactorySpec.scala
index c68e1076f2..4e9f684160 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/OperationFactorySpec.scala
+++ b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/OperationFactorySpec.scala
@@ -29,9 +29,9 @@ object OperationFactorySpec extends ZIOSpecDefault, ApolloSpecHelper {
test("make CrateOperation from same seed is deterministic") {
val didTemplate = ManagedDIDTemplate(Nil, Nil, Nil)
for {
- result1 <- operationFactory.makeCreateOperationHdKey("master0", seed)(0, didTemplate)
+ result1 <- operationFactory.makeCreateOperation("master0", seed)(0, didTemplate)
(op1, hdKey1) = result1
- result2 <- operationFactory.makeCreateOperationHdKey("master0", seed)(0, didTemplate)
+ result2 <- operationFactory.makeCreateOperation("master0", seed)(0, didTemplate)
(op2, hdKey2) = result2
} yield assert(op1)(equalTo(op2)) &&
assert(hdKey1)(equalTo(hdKey2))
@@ -39,7 +39,7 @@ object OperationFactorySpec extends ZIOSpecDefault, ApolloSpecHelper {
test("make CreateOperation must contain 1 master key") {
val didTemplate = ManagedDIDTemplate(Nil, Nil, Nil)
for {
- result <- operationFactory.makeCreateOperationHdKey("master-0", seed)(0, didTemplate)
+ result <- operationFactory.makeCreateOperation("master-0", seed)(0, didTemplate)
(op, hdKey) = result
pk = op.publicKeys.head.asInstanceOf[InternalPublicKey]
} yield assert(op.publicKeys)(hasSize(equalTo(1))) &&
@@ -49,23 +49,22 @@ object OperationFactorySpec extends ZIOSpecDefault, ApolloSpecHelper {
test("make CreateOperation containing multiple keys") {
val didTemplate = ManagedDIDTemplate(
Seq(
- DIDPublicKeyTemplate("auth-0", VerificationRelationship.Authentication),
- DIDPublicKeyTemplate("auth-1", VerificationRelationship.Authentication),
- DIDPublicKeyTemplate("issue-0", VerificationRelationship.AssertionMethod),
+ DIDPublicKeyTemplate("auth-0", VerificationRelationship.Authentication, EllipticCurve.SECP256K1),
+ DIDPublicKeyTemplate("auth-1", VerificationRelationship.Authentication, EllipticCurve.SECP256K1),
+ DIDPublicKeyTemplate("issue-0", VerificationRelationship.AssertionMethod, EllipticCurve.SECP256K1),
),
Nil,
Nil
)
for {
- result <- operationFactory.makeCreateOperationHdKey("master-0", seed)(0, didTemplate)
+ result <- operationFactory.makeCreateOperation("master-0", seed)(0, didTemplate)
(op, hdKey) = result
} yield assert(op.publicKeys.length)(equalTo(4)) &&
- assert(hdKey.internalKeyPaths.size)(equalTo(1)) &&
- assert(hdKey.keyPaths.size)(equalTo(3)) &&
- assert(hdKey.internalKeyPaths.get("master-0").get.keyIndex)(equalTo(0)) &&
- assert(hdKey.keyPaths.get("auth-0").get.keyIndex)(equalTo(0)) &&
- assert(hdKey.keyPaths.get("auth-1").get.keyIndex)(equalTo(1)) &&
- assert(hdKey.keyPaths.get("issue-0").get.keyIndex)(equalTo(0))
+ assert(hdKey.hdKeys.size)(equalTo(4)) &&
+ assert(hdKey.hdKeys.get("master-0").get.keyIndex)(equalTo(0)) &&
+ assert(hdKey.hdKeys.get("auth-0").get.keyIndex)(equalTo(0)) &&
+ assert(hdKey.hdKeys.get("auth-1").get.keyIndex)(equalTo(1)) &&
+ assert(hdKey.hdKeys.get("issue-0").get.keyIndex)(equalTo(0))
}
)
@@ -73,11 +72,15 @@ object OperationFactorySpec extends ZIOSpecDefault, ApolloSpecHelper {
test("make UpdateOperation from same seed is deterministic") {
val counter = HdKeyIndexCounter.zero(0)
val actions =
- Seq(UpdateManagedDIDAction.AddKey(DIDPublicKeyTemplate("issue-42", VerificationRelationship.AssertionMethod)))
+ Seq(
+ UpdateManagedDIDAction.AddKey(
+ DIDPublicKeyTemplate("issue-42", VerificationRelationship.AssertionMethod, EllipticCurve.SECP256K1)
+ )
+ )
for {
- result1 <- operationFactory.makeUpdateOperationHdKey(seed)(didExample, previousOperationHash, actions, counter)
+ result1 <- operationFactory.makeUpdateOperation(seed)(didExample, previousOperationHash, actions, counter)
(op1, hdKey1) = result1
- result2 <- operationFactory.makeUpdateOperationHdKey(seed)(didExample, previousOperationHash, actions, counter)
+ result2 <- operationFactory.makeUpdateOperation(seed)(didExample, previousOperationHash, actions, counter)
(op2, hdKey2) = result2
} yield assert(op1)(equalTo(op2)) && assert(hdKey1)(equalTo(hdKey2))
},
@@ -91,11 +94,15 @@ object OperationFactorySpec extends ZIOSpecDefault, ApolloSpecHelper {
)
)
val actions = Seq(
- UpdateManagedDIDAction.AddKey(DIDPublicKeyTemplate("auth-42", VerificationRelationship.Authentication)),
- UpdateManagedDIDAction.AddKey(DIDPublicKeyTemplate("issue-42", VerificationRelationship.AssertionMethod)),
+ UpdateManagedDIDAction.AddKey(
+ DIDPublicKeyTemplate("auth-42", VerificationRelationship.Authentication, EllipticCurve.SECP256K1)
+ ),
+ UpdateManagedDIDAction.AddKey(
+ DIDPublicKeyTemplate("issue-42", VerificationRelationship.AssertionMethod, EllipticCurve.SECP256K1)
+ ),
)
for {
- result <- operationFactory.makeUpdateOperationHdKey(seed)(didExample, previousOperationHash, actions, counter)
+ result <- operationFactory.makeUpdateOperation(seed)(didExample, previousOperationHash, actions, counter)
(op, hdKey) = result
} yield {
// counter is correct
@@ -108,9 +115,9 @@ object OperationFactorySpec extends ZIOSpecDefault, ApolloSpecHelper {
assert(hdKey.counter.internalKey.master)(equalTo(0)) &&
assert(hdKey.counter.internalKey.revocation)(equalTo(0)) &&
// path is correct
- assert(hdKey.newKeyPaths.size)(equalTo(2)) &&
- assert(hdKey.newKeyPaths.get("auth-42").get.keyIndex)(equalTo(3)) &&
- assert(hdKey.newKeyPaths.get("issue-42").get.keyIndex)(equalTo(1)) &&
+ assert(hdKey.hdKeys.size)(equalTo(2)) &&
+ assert(hdKey.hdKeys.get("auth-42").get.keyIndex)(equalTo(3)) &&
+ assert(hdKey.hdKeys.get("issue-42").get.keyIndex)(equalTo(1)) &&
// operation is correct
assert(op.actions)(hasSize(equalTo(2))) &&
assert(op.actions.collect { case UpdateDIDAction.AddKey(pk) => pk.id })(
diff --git a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Apollo.scala b/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Apollo.scala
index d2760358ab..a342fa62d0 100644
--- a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Apollo.scala
+++ b/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Apollo.scala
@@ -21,8 +21,8 @@ object Apollo {
def default: Apollo = new {
override def secp256k1: Secp256k1KeyOps = KmpSecp256k1KeyOps
- override def ed25519: Ed25519KeyOps = ???
- override def x25519: X25519KeyOps = ???
+ override def ed25519: Ed25519KeyOps = KmpEd25519KeyOps
+ override def x25519: X25519KeyOps = KmpX25519KeyOps
}
}
@@ -50,7 +50,7 @@ enum DerivationPath {
case Hardened(i: Int) extends DerivationPath
}
-final case class ECPoint(x: BigInt, y: BigInt)
+final case class ECPoint(x: Array[Byte], y: Array[Byte])
// secp256k1
final case class Secp256k1KeyPair(publicKey: Secp256k1PublicKey, privateKey: Secp256k1PrivateKey)
@@ -71,8 +71,8 @@ trait Secp256k1PublicKey extends PublicKey, Verifiable {
def toJavaPublicKey: java.security.interfaces.ECPublicKey = {
val point = getECPoint
- val x = point.x
- val y = point.y
+ val x = BigInt(1, point.x)
+ val y = BigInt(1, point.y)
val keyFactory = KeyFactory.getInstance("EC", new BouncyCastleProvider())
val ecParameterSpec = ECNamedCurveTable.getParameterSpec("secp256k1")
val ecNamedCurveSpec = ECNamedCurveSpec(
@@ -112,21 +112,23 @@ trait Secp256k1PrivateKey extends PrivateKey, Signable {
}
trait Secp256k1KeyOps {
def publicKeyFromEncoded(bytes: Array[Byte]): Try[Secp256k1PublicKey]
+ def publicKeyFromCoordinate(x: Array[Byte], y: Array[Byte]): Try[Secp256k1PublicKey]
def privateKeyFromEncoded(bytes: Array[Byte]): Try[Secp256k1PrivateKey]
- def generateKeyPair: UIO[Secp256k1KeyPair]
+ def generateKeyPair: Secp256k1KeyPair
def randomBip32Seed: UIO[(Array[Byte], Seq[String])]
def deriveKeyPair(seed: Array[Byte])(path: DerivationPath*): UIO[Secp256k1KeyPair]
}
// ed25519
final case class Ed25519KeyPair(publicKey: Ed25519PublicKey, privateKey: Ed25519PrivateKey)
-trait Ed25519PublicKey extends PublicKey
+trait Ed25519PublicKey extends PublicKey, Verifiable
trait Ed25519PrivateKey extends PrivateKey, Signable {
type Pub = Ed25519PublicKey
}
trait Ed25519KeyOps {
def publicKeyFromEncoded(bytes: Array[Byte]): Try[Ed25519PublicKey]
def privateKeyFromEncoded(bytes: Array[Byte]): Try[Ed25519PrivateKey]
+ def generateKeyPair: Ed25519KeyPair
}
// x25519
@@ -138,4 +140,5 @@ trait X25519PrivateKey extends PrivateKey {
trait X25519KeyOps {
def publicKeyFromEncoded(bytes: Array[Byte]): Try[X25519PublicKey]
def privateKeyFromEncoded(bytes: Array[Byte]): Try[X25519PrivateKey]
+ def generateKeyPair: X25519KeyPair
}
diff --git a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/KmpApollo.scala b/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/KmpApollo.scala
index a5410add2f..5cc85400c6 100644
--- a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/KmpApollo.scala
+++ b/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/KmpApollo.scala
@@ -6,6 +6,12 @@ import io.iohk.atala.prism.apollo.secp256k1.Secp256k1Lib
import io.iohk.atala.prism.apollo.securerandom.SecureRandom
import io.iohk.atala.prism.apollo.utils.KMMECSecp256k1PrivateKey
import io.iohk.atala.prism.apollo.utils.KMMECSecp256k1PublicKey
+import io.iohk.atala.prism.apollo.utils.KMMEdKeyPair
+import io.iohk.atala.prism.apollo.utils.KMMEdPrivateKey
+import io.iohk.atala.prism.apollo.utils.KMMEdPublicKey
+import io.iohk.atala.prism.apollo.utils.KMMX25519KeyPair
+import io.iohk.atala.prism.apollo.utils.KMMX25519PrivateKey
+import io.iohk.atala.prism.apollo.utils.KMMX25519PublicKey
import zio.*
import scala.jdk.CollectionConverters.*
@@ -15,9 +21,7 @@ final case class KmpSecp256k1PublicKey(publicKey: KMMECSecp256k1PublicKey) exten
override def getECPoint: ECPoint = {
val point = publicKey.getCurvePoint()
- val x = BigInt(1, point.getX())
- val y = BigInt(1, point.getY())
- ECPoint(x, y)
+ ECPoint(point.getX(), point.getY())
}
override def getEncoded: Array[Byte] = publicKey.getCompressed()
@@ -53,19 +57,27 @@ object KmpSecp256k1KeyOps extends Secp256k1KeyOps {
else throw new Exception("The public key is not on the secp256k1 curve")
}
+ override def publicKeyFromCoordinate(x: Array[Byte], y: Array[Byte]): Try[Secp256k1PublicKey] =
+ Try {
+ val pk = KMMECSecp256k1PublicKey.Companion.secp256k1FromByteCoordinates(x, y)
+ val point = pk.getCurvePoint()
+ val isOnCurve = KMMECSecp256k1PublicKey.Companion.isPointOnSecp256k1Curve(point)
+ if (isOnCurve) KmpSecp256k1PublicKey(pk)
+ else throw Exception("The point is not on the secp256k1 curve")
+ }
+
override def privateKeyFromEncoded(bytes: Array[Byte]): Try[Secp256k1PrivateKey] =
Try(KMMECSecp256k1PrivateKey.Companion.secp256k1FromByteArray(bytes)).map(KmpSecp256k1PrivateKey(_))
- override def generateKeyPair: UIO[Secp256k1KeyPair] =
- ZIO.attemptBlocking {
- val randBytes = secureRandom.nextBytes(32)
- val privateKey = KMMECSecp256k1PrivateKey(randBytes)
- val publicKey = privateKey.getPublicKey
- Secp256k1KeyPair(
- KmpSecp256k1PublicKey(publicKey),
- KmpSecp256k1PrivateKey(privateKey)
- )
- }.orDie
+ override def generateKeyPair: Secp256k1KeyPair = {
+ val randBytes = secureRandom.nextBytes(32)
+ val privateKey = KMMECSecp256k1PrivateKey(randBytes)
+ val publicKey = privateKey.getPublicKey
+ Secp256k1KeyPair(
+ KmpSecp256k1PublicKey(publicKey),
+ KmpSecp256k1PrivateKey(privateKey)
+ )
+ }
def randomBip32Seed: UIO[(Array[Byte], Seq[String])] =
ZIO.attemptBlocking {
@@ -95,3 +107,71 @@ object KmpSecp256k1KeyOps extends Secp256k1KeyOps {
}.orDie
}
+
+final case class KmpEd25519PublicKey(publicKey: KMMEdPublicKey) extends Ed25519PublicKey {
+ override def getEncoded: Array[Byte] = publicKey.getRaw()
+ override def verify(data: Array[Byte], signature: Array[Byte]): Try[Unit] =
+ Try(publicKey.verify(data, signature))
+ .flatMap(isValid => if (isValid) Success(()) else Failure(Exception("The signature verification does not match")))
+}
+
+final case class KmpEd25519PrivateKey(privateKey: KMMEdPrivateKey) extends Ed25519PrivateKey {
+ override def getEncoded: Array[Byte] = privateKey.getRaw()
+ override def sign(data: Array[Byte]): Array[Byte] = privateKey.sign(data)
+ override def toPublicKey: Ed25519PublicKey = KmpEd25519PublicKey(privateKey.publicKey())
+}
+
+object KmpEd25519KeyOps extends Ed25519KeyOps {
+
+ override def publicKeyFromEncoded(bytes: Array[Byte]): Try[Ed25519PublicKey] =
+ Try {
+ if bytes.length != 32 then throw Exception("Invalid public key length")
+ KmpEd25519PublicKey(KMMEdPublicKey(bytes))
+ }
+
+ override def privateKeyFromEncoded(bytes: Array[Byte]): Try[Ed25519PrivateKey] =
+ Try {
+ if bytes.length != 32 then throw Exception("Invalid private key length")
+ KmpEd25519PrivateKey(KMMEdPrivateKey(bytes))
+ }
+
+ override def generateKeyPair: Ed25519KeyPair = {
+ val keyPair = KMMEdKeyPair.Companion.generateKeyPair()
+ Ed25519KeyPair(
+ KmpEd25519PublicKey(keyPair.getPublicKey()),
+ KmpEd25519PrivateKey(keyPair.getPrivateKey())
+ )
+ }
+
+}
+
+final case class KmpX25519PublicKey(publicKey: KMMX25519PublicKey) extends X25519PublicKey {
+ override def getEncoded: Array[Byte] = publicKey.getRaw()
+}
+
+final case class KmpX25519PrivateKey(privateKey: KMMX25519PrivateKey) extends X25519PrivateKey {
+ override def getEncoded: Array[Byte] = privateKey.getRaw()
+ override def toPublicKey: X25519PublicKey = KmpX25519PublicKey(privateKey.publicKey())
+}
+
+object KmpX25519KeyOps extends X25519KeyOps {
+ override def publicKeyFromEncoded(bytes: Array[Byte]): Try[X25519PublicKey] =
+ Try {
+ if bytes.length != 32 then throw Exception("Invalid public key length")
+ KmpX25519PublicKey(KMMX25519PublicKey(bytes))
+ }
+
+ override def privateKeyFromEncoded(bytes: Array[Byte]): Try[X25519PrivateKey] =
+ Try {
+ if bytes.length != 32 then throw Exception("Invalid private key length")
+ KmpX25519PrivateKey(KMMX25519PrivateKey(bytes))
+ }
+
+ override def generateKeyPair: X25519KeyPair = {
+ val keyPair = KMMX25519KeyPair.Companion.generateKeyPair()
+ X25519KeyPair(
+ KmpX25519PublicKey(keyPair.getPublicKey()),
+ KmpX25519PrivateKey(keyPair.getPrivateKey())
+ )
+ }
+}
diff --git a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Prism14Apollo.scala b/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Prism14Apollo.scala
new file mode 100644
index 0000000000..37e049c386
--- /dev/null
+++ b/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Prism14Apollo.scala
@@ -0,0 +1,96 @@
+package io.iohk.atala.shared.crypto
+
+import io.iohk.atala.prism.crypto.EC
+import io.iohk.atala.prism.crypto.derivation.DerivationAxis
+import io.iohk.atala.prism.crypto.derivation.KeyDerivation
+import zio.*
+
+import scala.jdk.CollectionConverters.*
+import scala.util.{Try, Success, Failure}
+
+final case class Prism14Secp256k1PublicKey(publicKey: io.iohk.atala.prism.crypto.keys.ECPublicKey)
+ extends Secp256k1PublicKey {
+
+ override def getEncoded: Array[Byte] = getEncodedCompressed
+
+ override def getEncodedUncompressed: Array[Byte] = publicKey.getEncoded()
+
+ override def getEncodedCompressed: Array[Byte] = publicKey.getEncodedCompressed()
+
+ override def getECPoint: ECPoint = {
+ val point = publicKey.getCurvePoint
+ ECPoint(point.getX().bytes(), point.getY().bytes())
+ }
+
+ override def verify(data: Array[Byte], signature: Array[Byte]): Try[Unit] = Try {
+ val sig = EC.INSTANCE.toSignatureFromBytes(signature)
+ EC.INSTANCE.verifyBytes(data, publicKey, sig)
+ }.flatMap(isValid => if (isValid) Success(()) else Failure(Exception("The signature verification does not match")))
+
+}
+
+final case class Prism14Secp256k1PrivateKey(privateKey: io.iohk.atala.prism.crypto.keys.ECPrivateKey)
+ extends Secp256k1PrivateKey {
+
+ override def toPublicKey: Secp256k1PublicKey = Prism14Secp256k1PublicKey(
+ EC.INSTANCE.toPublicKeyFromPrivateKey(privateKey)
+ )
+
+ override def getEncoded: Array[Byte] = privateKey.getEncoded()
+
+ override def sign(data: Array[Byte]): Array[Byte] = EC.INSTANCE.signBytes(data, privateKey).getEncoded
+
+}
+
+object Prism14Secp256k1Ops extends Secp256k1KeyOps {
+
+ override def generateKeyPair: Secp256k1KeyPair = {
+ val keyPair = EC.INSTANCE.generateKeyPair()
+ Secp256k1KeyPair(
+ Prism14Secp256k1PublicKey(keyPair.getPublicKey()),
+ Prism14Secp256k1PrivateKey(keyPair.getPrivateKey()),
+ )
+ }
+
+ override def privateKeyFromEncoded(bytes: Array[Byte]): Try[Secp256k1PrivateKey] =
+ Try(Prism14Secp256k1PrivateKey(EC.INSTANCE.toPrivateKeyFromBytes(bytes)))
+
+ override def publicKeyFromEncoded(bytes: Array[Byte]): Try[Secp256k1PublicKey] =
+ Try(EC.INSTANCE.toPublicKeyFromBytes(bytes))
+ .orElse(Try(EC.INSTANCE.toPublicKeyFromCompressed(bytes)))
+ .map(Prism14Secp256k1PublicKey.apply)
+
+ override def publicKeyFromCoordinate(x: Array[Byte], y: Array[Byte]): Try[Secp256k1PublicKey] =
+ Try {
+ val pk = EC.INSTANCE.toPublicKeyFromByteCoordinates(x, y)
+ val point = pk.getCurvePoint()
+ val isOnCurve = EC.INSTANCE.isSecp256k1(point)
+ if (isOnCurve) Prism14Secp256k1PublicKey(pk)
+ else throw Exception("The point is not on the secp256k1 curve")
+ }
+
+ override def deriveKeyPair(seed: Array[Byte])(path: DerivationPath*): UIO[Secp256k1KeyPair] =
+ ZIO.attempt {
+ val extendedKey = path
+ .foldLeft(KeyDerivation.INSTANCE.derivationRoot(seed)) { case (extendedKey, p) =>
+ val axis = p match {
+ case DerivationPath.Hardened(i) => DerivationAxis.hardened(i)
+ case DerivationPath.Normal(i) => DerivationAxis.normal(i)
+ }
+ extendedKey.derive(axis)
+ }
+ val prism14KeyPair = extendedKey.keyPair()
+ Secp256k1KeyPair(
+ Prism14Secp256k1PublicKey(prism14KeyPair.getPublicKey()),
+ Prism14Secp256k1PrivateKey(prism14KeyPair.getPrivateKey())
+ )
+ }.orDie
+
+ override def randomBip32Seed: UIO[(Array[Byte], Seq[String])] =
+ ZIO.attemptBlocking {
+ val mnemonic = KeyDerivation.INSTANCE.randomMnemonicCode()
+ val words = mnemonic.getWords().asScala.toList
+ KeyDerivation.INSTANCE.binarySeed(mnemonic, "") -> words
+ }.orDie
+
+}
diff --git a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/jwk/JWK.scala b/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/jwk/JWK.scala
new file mode 100644
index 0000000000..1e4050a121
--- /dev/null
+++ b/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/jwk/JWK.scala
@@ -0,0 +1,61 @@
+package io.iohk.atala.shared.crypto.jwk
+
+import com.nimbusds.jose.jwk.Curve
+import com.nimbusds.jose.jwk.OctetKeyPair
+import com.nimbusds.jose.util.Base64URL
+import io.iohk.atala.shared.crypto.*
+import zio.json.*
+import zio.json.ast.Json
+
+import scala.language.implicitConversions
+import scala.util.Try
+
+opaque type JWK = Json
+
+object JWK {
+ def fromString(json: String): Either[String, JWK] = json.fromJson[Json]
+ extension (jwk: JWK) {
+ def toJsonString: String = jwk.toJson
+ def toJsonAst: Json = jwk
+ }
+
+ given Conversion[Ed25519KeyPair, JWK] = keyPair => {
+ val x = Base64URL.encode(keyPair.publicKey.getEncoded)
+ val d = Base64URL.encode(keyPair.privateKey.getEncoded)
+ val octetKey = OctetKeyPair.Builder(Curve.Ed25519, x).d(d).build()
+ octetKey.toJSONString().fromJson[Json].toOption.get // .get cannot fail
+ }
+
+ given Conversion[X25519KeyPair, JWK] = keyPair => {
+ val x = Base64URL.encode(keyPair.publicKey.getEncoded)
+ val d = Base64URL.encode(keyPair.privateKey.getEncoded)
+ val octetKey = OctetKeyPair.Builder(Curve.X25519, x).d(d).build()
+ octetKey.toJSONString().fromJson[Json].toOption.get // .get cannot fail
+ }
+}
+
+trait FromJWK[K] {
+ def from(jwk: JWK): Either[String, K]
+}
+
+object FromJWK {
+ given FromJWK[Ed25519KeyPair] = jwk => {
+ val keyPair = for {
+ okp <- Try(OctetKeyPair.parse(jwk.toJsonString))
+ d <- Try(okp.getD().decode())
+ privateKey <- Apollo.default.ed25519.privateKeyFromEncoded(d)
+ publicKey = privateKey.toPublicKey
+ } yield Ed25519KeyPair(publicKey, privateKey)
+ keyPair.toEither.left.map(_.getMessage())
+ }
+
+ given FromJWK[X25519KeyPair] = jwk => {
+ val keyPair = for {
+ okp <- Try(OctetKeyPair.parse(jwk.toJsonString))
+ d <- Try(okp.getD().decode())
+ privateKey <- Apollo.default.x25519.privateKeyFromEncoded(d)
+ publicKey = privateKey.toPublicKey
+ } yield X25519KeyPair(publicKey, privateKey)
+ keyPair.toEither.left.map(_.getMessage())
+ }
+}
diff --git a/shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpec.scala b/shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpec.scala
index 85a954ebba..c6bd785e43 100644
--- a/shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpec.scala
+++ b/shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpec.scala
@@ -9,19 +9,19 @@ object ApolloSpec extends ZIOSpecDefault {
override def spec = {
val tests = Seq(
- publicKeySpec,
- privateKeySpec,
- secp256k1Spec,
+ secp256k1PublicKeySpec,
+ secp256k1PrivateKeySpec,
+ secp256k1OpsSpec,
bip32Spec,
)
suite("Apollo - KMP implementation")(tests: _*).provideLayer(Apollo.layer)
}
- private val publicKeySpec = suite("Secp256k1PublicKey")(
+ private val secp256k1PublicKeySpec = suite("Secp256k1PublicKey")(
test("same public key bytes must be equal and have same hashCode") {
for {
apollo <- ZIO.service[Apollo]
- keyPair <- apollo.secp256k1.generateKeyPair
+ keyPair = apollo.secp256k1.generateKeyPair
pk1 = keyPair.publicKey
pk2 = apollo.secp256k1.publicKeyFromEncoded(pk1.getEncoded).get
} yield assert(pk1)(equalTo(pk2)) &&
@@ -31,8 +31,8 @@ object ApolloSpec extends ZIOSpecDefault {
test("different public key bytes must not be equal and have different hashCode") {
for {
apollo <- ZIO.service[Apollo]
- keyPair1 <- apollo.secp256k1.generateKeyPair
- keyPair2 <- apollo.secp256k1.generateKeyPair
+ keyPair1 = apollo.secp256k1.generateKeyPair
+ keyPair2 = apollo.secp256k1.generateKeyPair
pk1 = keyPair1.publicKey
pk2 = keyPair2.publicKey
} yield assert(pk1)(not(equalTo(pk2))) &&
@@ -60,11 +60,11 @@ object ApolloSpec extends ZIOSpecDefault {
}
)
- private val privateKeySpec = suite("Secp256k1PrivateKey")(
+ private val secp256k1PrivateKeySpec = suite("Secp256k1PrivateKey")(
test("same private key bytes must be equal and have same hashCode") {
for {
apollo <- ZIO.service[Apollo]
- keyPair <- apollo.secp256k1.generateKeyPair
+ keyPair = apollo.secp256k1.generateKeyPair
pk1 = keyPair.privateKey
pk2 = apollo.secp256k1.privateKeyFromEncoded(pk1.getEncoded).get
} yield assert(pk1)(equalTo(pk2)) &&
@@ -74,8 +74,8 @@ object ApolloSpec extends ZIOSpecDefault {
test("different private key bytes must not be equal and have different hashCode") {
for {
apollo <- ZIO.service[Apollo]
- keyPair1 <- apollo.secp256k1.generateKeyPair
- keyPair2 <- apollo.secp256k1.generateKeyPair
+ keyPair1 = apollo.secp256k1.generateKeyPair
+ keyPair2 = apollo.secp256k1.generateKeyPair
pk1 = keyPair1.privateKey
pk2 = keyPair2.privateKey
} yield assert(pk1)(not(equalTo(pk2))) &&
@@ -120,7 +120,7 @@ object ApolloSpec extends ZIOSpecDefault {
val message = BigInt("42").toByteArray
for {
apollo <- ZIO.service[Apollo]
- keyPair <- apollo.secp256k1.generateKeyPair
+ keyPair = apollo.secp256k1.generateKeyPair
privateKey = keyPair.privateKey
publicKey = privateKey.toPublicKey
signature = privateKey.sign(message)
@@ -130,8 +130,8 @@ object ApolloSpec extends ZIOSpecDefault {
val message = BigInt("42").toByteArray
for {
apollo <- ZIO.service[Apollo]
- keyPair1 <- apollo.secp256k1.generateKeyPair
- keyPair2 <- apollo.secp256k1.generateKeyPair
+ keyPair1 = apollo.secp256k1.generateKeyPair
+ keyPair2 = apollo.secp256k1.generateKeyPair
privateKey = keyPair1.privateKey
publicKey = keyPair2.publicKey
signature = privateKey.sign(message)
@@ -139,7 +139,7 @@ object ApolloSpec extends ZIOSpecDefault {
},
)
- private val secp256k1Spec = suite("Secp256k1Ops")(
+ private val secp256k1OpsSpec = suite("Secp256k1Ops")(
test("decode invalid public key should fail") {
for {
apollo <- ZIO.service[Apollo]
From 56cad40bdaad04944c194d63355ecabf1b26aef2 Mon Sep 17 00:00:00 2001
From: Yurii Shynbuiev - IOHK
Date: Thu, 25 Apr 2024 07:53:51 +0700
Subject: [PATCH 04/12] ci: update labeler permissions (#981)
Signed-off-by: Yurii Shynbuiev - IOHK
---
.github/workflows/labeler.yml | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/.github/workflows/labeler.yml b/.github/workflows/labeler.yml
index 538ebeb9d8..86c36d5f06 100644
--- a/.github/workflows/labeler.yml
+++ b/.github/workflows/labeler.yml
@@ -5,7 +5,9 @@ on:
jobs:
triage:
runs-on: self-hosted
+ permissions:
+ pull-requests: write
steps:
- uses: actions/labeler@v5
with:
- repo-token: "${{ secrets.ATALA_GITHUB_TOKEN }}"
+ repo-token: "${{ secrets.GITHUB_TOKEN }}"
From 733fecc888a44d1a4347f58191378233b3d578a1 Mon Sep 17 00:00:00 2001
From: Yurii Shynbuiev - IOHK
Date: Thu, 25 Apr 2024 07:54:32 +0700
Subject: [PATCH 05/12] ci: update release workflow (#980)
Signed-off-by: Yurii Shynbuiev - IOHK
---
.github/workflows/release.yml | 13 ++++++++-----
1 file changed, 8 insertions(+), 5 deletions(-)
diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml
index ddcca98eb5..c4e5c6a805 100644
--- a/.github/workflows/release.yml
+++ b/.github/workflows/release.yml
@@ -20,17 +20,20 @@ on:
jobs:
release:
env:
- GITHUB_ACTOR: ${{ secrets.ATALA_GITHUB_ACTOR }}
- GITHUB_TOKEN: ${{ secrets.ATALA_GITHUB_TOKEN }}
+ GITHUB_ACTOR: ${{ secrets.GITHUB_ACTOR }}
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }}
# New JDK version makes 'localhost' lookup on linux return ipv6.
# Our test containers are on ipv4. We need to make 'localhost' resolve to ipv4.
JAVA_TOOL_OPTIONS: -Djava.net.preferIPv4Stack=true
runs-on: ubuntu-latest
+ permissions:
+ contents: read
+ packages: write
steps:
- uses: actions/checkout@v3
with:
- token: ${{ secrets.ATALA_GITHUB_TOKEN }}
+ token: ${{ secrets.GITHUB_TOKEN }}
ref: ${{ github.event.inputs.release-branch }}
fetch-depth: 0
- name: Setup Java and Scala
@@ -58,8 +61,8 @@ jobs:
uses: docker/login-action@v2
with:
registry: ghcr.io
- username: ${{ secrets.ATALA_GITHUB_ACTOR }}
- password: ${{ secrets.ATALA_GITHUB_TOKEN }}
+ username: ${{ secrets.GITHUB_ACTOR }}
+ password: ${{ secrets.GITHUB_TOKEN }}
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
- name: Set up Docker Buildx
From 0b2a9ed91a15943327551766a762e93684bef195 Mon Sep 17 00:00:00 2001
From: Yurii Shynbuiev - IOHK
Date: Thu, 25 Apr 2024 10:40:50 +0700
Subject: [PATCH 06/12] ci: use github.actor in the release workflow (#982)
Signed-off-by: Yurii Shynbuiev - IOHK
---
.github/workflows/release.yml | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml
index c4e5c6a805..f93df5b17f 100644
--- a/.github/workflows/release.yml
+++ b/.github/workflows/release.yml
@@ -20,7 +20,7 @@ on:
jobs:
release:
env:
- GITHUB_ACTOR: ${{ secrets.GITHUB_ACTOR }}
+ GITHUB_ACTOR: ${{ github.actor }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }}
# New JDK version makes 'localhost' lookup on linux return ipv6.
@@ -61,7 +61,7 @@ jobs:
uses: docker/login-action@v2
with:
registry: ghcr.io
- username: ${{ secrets.GITHUB_ACTOR }}
+ username: github.actor
password: ${{ secrets.GITHUB_TOKEN }}
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
From 6d33929fd6c6baada4c3cc7408b21c0899b43bb4 Mon Sep 17 00:00:00 2001
From: Yurii Shynbuiev - IOHK
Date: Thu, 25 Apr 2024 11:13:13 +0700
Subject: [PATCH 07/12] ci: add permission to push the tag for semantic-release
[skip ci] (#983)
Signed-off-by: Yurii Shynbuiev - IOHK
---
.github/workflows/release.yml | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml
index f93df5b17f..30e41094c1 100644
--- a/.github/workflows/release.yml
+++ b/.github/workflows/release.yml
@@ -28,7 +28,7 @@ jobs:
JAVA_TOOL_OPTIONS: -Djava.net.preferIPv4Stack=true
runs-on: ubuntu-latest
permissions:
- contents: read
+ contents: write
packages: write
steps:
- uses: actions/checkout@v3
From 7ee0b1692964ad17538a90c500431eaa01d7bf61 Mon Sep 17 00:00:00 2001
From: Yurii Shynbuiev - IOHK
Date: Thu, 25 Apr 2024 13:17:18 +0700
Subject: [PATCH 08/12] =?UTF-8?q?ci:=20switch=20to=20the=20hyperledger=20o?=
=?UTF-8?q?rganization=20in=20publishing=20the=20image=20to=20ghc=E2=80=A6?=
=?UTF-8?q?=20(#984)?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
Signed-off-by: Yurii Shynbuiev
---
README.md | 2 +-
build.sbt | 10 +-
infrastructure/charts/agent/values.yaml | 2 +-
.../ci/docker-compose-multiple-actors.yml | 154 ------------------
infrastructure/shared/docker-compose-demo.yml | 2 +-
.../shared/docker-compose-mt-keycloak.yml | 2 +-
infrastructure/shared/docker-compose.yml | 2 +-
.../docker-compose.yml | 6 +-
package.json | 4 +-
.../src/test/resources/containers/agent.yml | 2 +-
10 files changed, 16 insertions(+), 170 deletions(-)
delete mode 100644 infrastructure/ci/docker-compose-multiple-actors.yml
diff --git a/README.md b/README.md
index 2387fa44a4..9c899610f8 100644
--- a/README.md
+++ b/README.md
@@ -3,7 +3,7 @@
- Open Enterprise Cloud Agent
+ Identus Cloud Agent
diff --git a/build.sbt b/build.sbt
index 141c9734e9..a4bde4d552 100644
--- a/build.sbt
+++ b/build.sbt
@@ -5,14 +5,14 @@ import sbtbuildinfo.BuildInfoPlugin.autoImport.*
inThisBuild(
Seq(
- organization := "io.iohk.atala",
+ organization := "org.hyperledger",
scalaVersion := "3.3.1",
fork := true,
run / connectInput := true,
releaseUseGlobalVersion := false,
versionScheme := Some("semver-spec"),
- githubOwner := "input-output-hk",
- githubRepository := "atala-prism-building-blocks",
+ githubOwner := "hyperledger",
+ githubRepository := "identus-cloud-agent",
resolvers += "Local Maven Repository" at "file://" + Path.userHome.absolutePath + "/.m2/repository",
resolvers += "jitpack" at "https://jitpack.io",
)
@@ -848,7 +848,7 @@ lazy val prismAgentServer = project
.in(file("prism-agent/service/server"))
.settings(commonSetttings)
.settings(
- name := "prism-agent",
+ name := "identus-cloud-agent",
fork := true,
libraryDependencies ++= D_PrismAgent.serverDependencies,
excludeDependencies ++= Seq(
@@ -858,7 +858,7 @@ lazy val prismAgentServer = project
),
Compile / mainClass := Some("io.iohk.atala.agent.server.MainApp"),
Docker / maintainer := "atala-coredid@iohk.io",
- Docker / dockerUsername := Some("input-output-hk"),
+ Docker / dockerUsername := Some("hyperledger"),
Docker / dockerRepository := Some("ghcr.io"),
dockerExposedPorts := Seq(8080, 8085, 8090),
// Official docker image for openjdk 21 with curl and bash
diff --git a/infrastructure/charts/agent/values.yaml b/infrastructure/charts/agent/values.yaml
index a2937a8adb..0fc766bbd4 100644
--- a/infrastructure/charts/agent/values.yaml
+++ b/infrastructure/charts/agent/values.yaml
@@ -23,7 +23,7 @@ server:
image:
repository: ghcr.io
pullPolicy: IfNotPresent
- tag: input-output-hk/prism-agent
+ tag: hyperledger/identus-cloud-agent
resources:
limits:
cpu: 500m
diff --git a/infrastructure/ci/docker-compose-multiple-actors.yml b/infrastructure/ci/docker-compose-multiple-actors.yml
deleted file mode 100644
index 660755415e..0000000000
--- a/infrastructure/ci/docker-compose-multiple-actors.yml
+++ /dev/null
@@ -1,154 +0,0 @@
-version: "3.8"
-
-services:
- ##########################
- # Pollux Databases
- ##########################
-
- db_pollux_issuer:
- image: postgres:13
- restart: always
- environment:
- POSTGRES_DB: pollux_issuer
- POSTGRES_USER: postgres
- POSTGRES_PASSWORD: postgres
- ports:
- - 5435:5432
- volumes:
- - pg_data_pollux_db_issuer:/var/lib/postgresql/data
- healthcheck:
- test: ["CMD", "pg_isready", "-U", "postgres", "-d", "pollux_issuer"]
- interval: 10s
- timeout: 5s
- retries: 5
-
- db_pollux_holder:
- image: postgres:13
- restart: always
- environment:
- POSTGRES_DB: pollux_holder
- POSTGRES_USER: postgres
- POSTGRES_PASSWORD: postgres
- ports:
- - 5436:5432
- volumes:
- - pg_data_pollux_db_holder:/var/lib/postgresql/data
- healthcheck:
- test: ["CMD", "pg_isready", "-U", "postgres", "-d", "pollux_holder"]
- interval: 10s
- timeout: 5s
- retries: 5
-
- ##########################
- # Connect Databases
- ##########################
-
- db_connect_issuer:
- image: postgres:13
- restart: always
- environment:
- POSTGRES_DB: connect_issuer
- POSTGRES_USER: postgres
- POSTGRES_PASSWORD: postgres
- ports:
- - 5437:5432
- volumes:
- - pg_data_connect_db_issuer:/var/lib/postgresql/data
- healthcheck:
- test: ["CMD", "pg_isready", "-U", "postgres", "-d", "connect_issuer"]
- interval: 10s
- timeout: 5s
- retries: 5
-
- db_connect_holder:
- image: postgres:13
- restart: always
- environment:
- POSTGRES_DB: connect_holder
- POSTGRES_USER: postgres
- POSTGRES_PASSWORD: postgres
- ports:
- - 5438:5432
- volumes:
- - pg_data_connect_db_holder:/var/lib/postgresql/data
- healthcheck:
- test: ["CMD", "pg_isready", "-U", "postgres", "-d", "connect_holder"]
- interval: 10s
- timeout: 5s
- retries: 5
-
- ##########################
- # Services
- ##########################c
-
- prism-agent-issuer:
- image: ghcr.io/input-output-hk/prism-agent:0.5.0
- environment:
- REST_SERVICE_PORT: 8080
- DIDCOMM_SERVICE_PORT: 8081
- CASTOR_DB_HOST: db_castor_issuer
- CASTOR_DB_PORT: 5432
- CASTOR_DB_NAME: castor_issuer
- CASTOR_DB_USER: postgres
- CASTOR_DB_PASSWORD: postgres
- POLLUX_DB_HOST: db_pollux_issuer
- POLLUX_DB_PORT: 5432
- POLLUX_DB_NAME: pollux_issuer
- POLLUX_DB_USER: postgres
- POLLUX_DB_PASSWORD: postgres
- CONNECT_DB_HOST: db_connect_issuer
- CONNECT_DB_PORT: 5432
- CONNECT_DB_NAME: connect_issuer
- CONNECT_DB_USER: postgres
- CONNECT_DB_PASSWORD: postgres
- DIDCOMM_SERVICE_URL: "http://prism-agent-issuer"
- ports:
- - "8080:8080"
- - "8081:8081"
- depends_on:
- - db_castor_issuer
- - db_pollux_issuer
- healthcheck:
- test: ["CMD", "curl", "-f", "http://prism-agent-issuer:8080/dids/xyz"]
- interval: 30s
- timeout: 10s
- retries: 5
-
- prism-agent-holder:
- image: ghcr.io/input-output-hk/prism-agent:0.5.0
- environment:
- REST_SERVICE_PORT: 8090
- DIDCOMM_SERVICE_PORT: 8091
- CASTOR_DB_HOST: db_castor_holder
- CASTOR_DB_PORT: 5432
- CASTOR_DB_NAME: castor_holder
- CASTOR_DB_USER: postgres
- CASTOR_DB_PASSWORD: postgres
- POLLUX_DB_HOST: db_pollux_holder
- POLLUX_DB_PORT: 5432
- POLLUX_DB_NAME: pollux_holder
- POLLUX_DB_USER: postgres
- POLLUX_DB_PASSWORD: postgres
- CONNECT_DB_HOST: db_connect_holder
- CONNECT_DB_PORT: 5432
- CONNECT_DB_NAME: connect_holder
- CONNECT_DB_USER: postgres
- CONNECT_DB_PASSWORD: postgres
- DIDCOMM_SERVICE_URL: "http://prism-agent-holder"
- ports:
- - "8090:8090"
- - "8091:8091"
- depends_on:
- - db_castor_holder
- - db_pollux_holder
- healthcheck:
- test: ["CMD", "curl", "-f", "http://prism-agent-holder:8090/dids/xyz"]
- interval: 30s
- timeout: 10s
- retries: 5
-
-volumes:
- pg_data_pollux_db_issuer:
- pg_data_pollux_db_holder:
- pg_data_connect_db_issuer:
- pg_data_connect_db_holder:
diff --git a/infrastructure/shared/docker-compose-demo.yml b/infrastructure/shared/docker-compose-demo.yml
index aae1127117..a448aa3e05 100644
--- a/infrastructure/shared/docker-compose-demo.yml
+++ b/infrastructure/shared/docker-compose-demo.yml
@@ -29,7 +29,7 @@ services:
condition: service_healthy
prism-agent:
- image: ghcr.io/input-output-hk/prism-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
environment:
DIDCOMM_SERVICE_URL: http://${DOCKERHOST}:${PORT}/didcomm
REST_SERVICE_URL: http://${DOCKERHOST}:${PORT}/prism-agent
diff --git a/infrastructure/shared/docker-compose-mt-keycloak.yml b/infrastructure/shared/docker-compose-mt-keycloak.yml
index aa15f60155..5b0e6c5d7f 100644
--- a/infrastructure/shared/docker-compose-mt-keycloak.yml
+++ b/infrastructure/shared/docker-compose-mt-keycloak.yml
@@ -70,7 +70,7 @@ services:
retries: 5
prism-agent:
- image: ghcr.io/input-output-hk/prism-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
environment:
POLLUX_DB_HOST: db
POLLUX_DB_PORT: 5432
diff --git a/infrastructure/shared/docker-compose.yml b/infrastructure/shared/docker-compose.yml
index 01bcd0dd58..70384c1b62 100644
--- a/infrastructure/shared/docker-compose.yml
+++ b/infrastructure/shared/docker-compose.yml
@@ -71,7 +71,7 @@ services:
retries: 5
prism-agent:
- image: ghcr.io/input-output-hk/prism-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
environment:
POLLUX_DB_HOST: db
POLLUX_DB_PORT: 5432
diff --git a/infrastructure/single-tenant-testing-stack/docker-compose.yml b/infrastructure/single-tenant-testing-stack/docker-compose.yml
index d153375e02..ea959fcfd5 100644
--- a/infrastructure/single-tenant-testing-stack/docker-compose.yml
+++ b/infrastructure/single-tenant-testing-stack/docker-compose.yml
@@ -85,7 +85,7 @@ services:
condition: service_healthy
issuer-oea:
- image: ghcr.io/input-output-hk/prism-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
environment:
POLLUX_DB_HOST: issuer-db
POLLUX_DB_PORT: 5432
@@ -155,7 +155,7 @@ services:
- 9095:9095
verifier-oea:
- image: ghcr.io/input-output-hk/prism-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
environment:
POLLUX_DB_HOST: verifier-db
POLLUX_DB_PORT: 5432
@@ -227,7 +227,7 @@ services:
- DATA_SOURCE_NAME=postgresql://postgres:postgres@issuer-db:5432/postgres?sslmode=disable
holder-oea:
- image: ghcr.io/input-output-hk/prism-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
environment:
POLLUX_DB_HOST: holder-db
POLLUX_DB_PORT: 5432
diff --git a/package.json b/package.json
index 13262facb7..b3d7ac8d33 100644
--- a/package.json
+++ b/package.json
@@ -77,7 +77,7 @@
[
"@semantic-release/exec",
{
- "prepareCmd": "helm repo index --url \"https://raw.githubusercontent.com/hyperledger-labs/open-enterprise-agent/main/infrastructure/charts\" --merge index.yaml infrastructure/charts"
+ "prepareCmd": "helm repo index --url \"https://raw.githubusercontent.com/hyperledger/identus-cloud-agent/main/infrastructure/charts\" --merge index.yaml infrastructure/charts"
}
],
[
@@ -89,7 +89,7 @@
[
"@semantic-release/exec",
{
- "prepareCmd": "docker buildx build --platform=linux/arm64,linux/amd64 --push -t ghcr.io/input-output-hk/prism-agent:${nextRelease.version} ./prism-agent/service/server/target/docker/stage"
+ "prepareCmd": "docker buildx build --platform=linux/arm64,linux/amd64 --push -t ghcr.io/hyperledger/identus-cloud-agent:${nextRelease.version} ./prism-agent/service/server/target/docker/stage"
}
],
[
diff --git a/tests/integration-tests/src/test/resources/containers/agent.yml b/tests/integration-tests/src/test/resources/containers/agent.yml
index da6905dbb7..555889085b 100644
--- a/tests/integration-tests/src/test/resources/containers/agent.yml
+++ b/tests/integration-tests/src/test/resources/containers/agent.yml
@@ -22,7 +22,7 @@ services:
# Open Enterprise Agent
open-enterprise-agent:
- image: ghcr.io/input-output-hk/prism-agent:${OPEN_ENTERPRISE_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${OPEN_ENTERPRISE_AGENT_VERSION}
environment:
PRISM_NODE_HOST: host.docker.internal
PRISM_NODE_PORT:
From cf691d1e15e2915fa37f5bd918b855edddee9a96 Mon Sep 17 00:00:00 2001
From: Yurii Shynbuiev - IOHK
Date: Fri, 26 Apr 2024 01:27:50 +0700
Subject: [PATCH 09/12] ci: use hyperledger-bot instead of atala-dev account
[skip ci] (#987)
Signed-off-by: Yurii Shynbuiev - IOHK
---
.github/workflows/release.yml | 10 ++++++----
1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml
index 30e41094c1..96ec683ef6 100644
--- a/.github/workflows/release.yml
+++ b/.github/workflows/release.yml
@@ -20,7 +20,8 @@ on:
jobs:
release:
env:
- GITHUB_ACTOR: ${{ github.actor }}
+ GITHUB_ACTOR: "hyperledger-bot"
+ GITHUB_ACTOR_EMAIL: "hyperledger-bot@hyperledger.org"
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }}
# New JDK version makes 'localhost' lookup on linux return ipv6.
@@ -54,15 +55,16 @@ jobs:
- uses: crazy-max/ghaction-import-gpg@v3
id: import_gpg
with:
- gpg-private-key: ${{ secrets.GPG_PRIVATE_KEY }}
+ gpg-private-key: ${{ secrets.HYP_BOT_GPG_PRIVATE }}
+ passphrase: ${{ secrets.HYP_BOT_GPG_PASSWORD }}
git-user-signingkey: true
git-commit-gpgsign: true
- name: Login to GitHub Container Registry
uses: docker/login-action@v2
with:
registry: ghcr.io
- username: github.actor
- password: ${{ secrets.GITHUB_TOKEN }}
+ username: ${{ env.GITHUB_ACTOR }}
+ password: ${{ env.GITHUB_TOKEN }}
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
- name: Set up Docker Buildx
From e902b83721db5f426ee012d3804ea200545f2ed2 Mon Sep 17 00:00:00 2001
From: Yurii Shynbuiev - IOHK
Date: Fri, 26 Apr 2024 02:35:06 +0700
Subject: [PATCH 10/12] ci: fix semantic-release (#988)
Signed-off-by: Yurii Shynbuiev - IOHK
---
.github/workflows/release.yml | 2 ++
1 file changed, 2 insertions(+)
diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml
index 96ec683ef6..eb404d10b5 100644
--- a/.github/workflows/release.yml
+++ b/.github/workflows/release.yml
@@ -59,6 +59,8 @@ jobs:
passphrase: ${{ secrets.HYP_BOT_GPG_PASSWORD }}
git-user-signingkey: true
git-commit-gpgsign: true
+ git_config_global: true
+ git_tag_gpgsign: true
- name: Login to GitHub Container Registry
uses: docker/login-action@v2
with:
From 9fc7bb07cac9aae1db8d389ec8831403f106d612 Mon Sep 17 00:00:00 2001
From: Shailesh Patil <53746241+mineme0110@users.noreply.github.com>
Date: Thu, 25 Apr 2024 22:34:56 +0100
Subject: [PATCH 11/12] feat: Align the repo with new name identus-cloud-agent
(#973)
Signed-off-by: Pat Losoponkul
Signed-off-by: mineme0110
Co-authored-by: patlo-iog
---
.github/ISSUE_TEMPLATE/1-bug-report.yaml | 10 +-
.github/ISSUE_TEMPLATE/2-feature-request.yaml | 2 +-
.github/workflows/integration-tests.yml | 12 +-
.github/workflows/performance-tests.yml | 8 +-
.mega-linter.yml | 6 +-
CODE_OF_CONDUCT.md | 2 +-
CONTRIBUTING.md | 14 +-
DCO.md | 2 +-
README.md | 66 +-
SECURITY.md | 4 +-
build.sbt | 101 +-
castor/{lib => }/CHANGELOG.md | 0
castor/{lib => }/README.md | 0
.../repository/DIDOperationRepository.scala | 7 -
.../castor/core/model/ProtoModelHelper.scala | 10 +-
.../identus}/castor/core/model/did/DID.scala | 2 +-
.../castor/core/model/did/DIDData.scala | 2 +-
.../castor/core/model/did/DIDUrl.scala | 2 +-
.../castor/core/model/did/EllipticCurve.scala | 2 +-
.../castor/core/model/did/PrismDID.scala | 8 +-
.../core/model/did/PrismDIDOperation.scala | 4 +-
.../castor/core/model/did/PublicKey.scala | 4 +-
.../castor/core/model/did/Service.scala | 2 +-
.../core/model/did/ServiceEndpoint.scala | 4 +-
.../castor/core/model/did/ServiceType.scala | 2 +-
.../model/did/VerificationRelationship.scala | 2 +-
.../core/model/did/w3c/DIDDocumentRepr.scala | 2 +-
.../core/model/did/w3c/DIDMetadata.scala | 2 +-
.../core/model/did/w3c/W3CModelHelper.scala | 12 +-
.../castor/core/model/did/w3c/package.scala | 6 +-
.../castor/core/model/error/package.scala | 2 +-
.../repository/DIDOperationRepository.scala | 7 +
.../castor/core/service/DIDService.scala | 14 +-
.../castor/core/service/MockDIDService.scala | 12 +-
.../core/util/DIDOperationValidator.scala | 16 +-
.../identus}/castor/core/util/Prelude.scala | 2 +-
.../identus}/castor/core/util/UriUtils.scala | 2 +-
.../core/model/ProtoModelHelperSpec.scala | 13 +-
.../castor/core/model/did/DIDSpec.scala | 5 +-
.../castor/core/model/did/PrismDIDSpec.scala | 5 +-
.../core/model/did/ServiceEndpointSpec.scala | 3 +-
.../core/model/did/ServiceTypeSpec.scala | 3 +-
.../model/did/w3c/W3CModelHelperSpec.scala | 7 +-
.../castor/core/service/DIDServiceSpec.scala | 12 +-
.../core/util/DIDOperationValidatorSpec.scala | 10 +-
.../identus}/castor/core/util/GenUtils.scala | 12 +-
.../client/.gitignore | 0
{prism-agent => cloud-agent}/client/README.md | 0
.../client/generator/clean.sh | 0
.../client/generator/generate-clients.sh | 20 +
.../client/generator/openapitools.json | 0
.../client/generator/package.json | 2 +-
.../client/generator/publish-clients.sh | 16 +
.../client/generator/yarn.lock | 0
.../client/kotlin/.openapi-generator-ignore | 0
.../client/kotlin/build.gradle | 0
.../client/kotlin/gradle.properties | 0
.../kotlin/gradle/wrapper/gradle-wrapper.jar | Bin
.../gradle/wrapper/gradle-wrapper.properties | 0
.../client/kotlin/gradlew | 0
.../client/kotlin/gradlew.bat | 0
.../client/kotlin/settings.gradle | 0
.../atala/prism/models/CredentialSubject.kt | 2 +-
.../io/iohk/atala/prism/models/Service.kt | 4 +-
.../models/UpdateManagedDIDServiceAction.kt | 4 +-
.../client/python/.openapi-generator-ignore | 0
.../client/python/setup.py | 0
.../typescript/.openapi-generator-ignore | 0
.../client/typescript/models/Service.ts | 0
.../models/UpdateManagedDIDServiceAction.ts | 0
.../client/typescript/package.json | 0
.../service/CHANGELOG.md | 0
.../service/README.md | 0
.../api/http/cloud-agent-openapi-spec.yaml | 3710 +++++++++--------
.../src/main/resources/application.conf | 0
.../server/src/main/resources/logback.xml | 0
.../org/hyperledger/identus}/LogUtils.scala | 4 +-
.../notification/JsonEventEncoders.scala | 24 +-
.../agent/notification/WebhookPublisher.scala | 24 +-
.../notification/WebhookPublisherError.scala | 2 +-
.../agent/server/ControllerHelper.scala | 35 +-
.../agent/server/DidCommHttpServer.scala | 42 +-
.../agent/server/DidCommHttpServerError.scala | 2 +-
.../identus/agent/server/MainApp.scala | 70 +-
.../identus}/agent/server/Modules.scala | 60 +-
.../identus}/agent/server/PrismAgentApp.scala | 65 +-
.../agent/server/config/AppConfig.scala | 10 +-
.../http/CustomServerInterceptors.scala | 6 +-
.../agent/server/http/DocModels.scala | 16 +-
.../server/http/ZHttp4sBlazeServer.scala | 6 +-
.../agent/server/http/ZHttpEndpoints.scala | 4 +-
.../agent/server/http/ZioHttpClient.scala | 4 +-
.../server/jobs/BackgroundJobError.scala | 4 +-
.../server/jobs/BackgroundJobsHelper.scala | 26 +-
.../server/jobs/ConnectBackgroundJobs.scala | 32 +-
.../jobs/DIDStateSyncBackgroundJobs.scala | 4 +-
.../server/jobs/IssueBackgroundJobs.scala | 26 +-
.../server/jobs/PresentBackgroundJobs.scala | 59 +-
.../agent/server/jobs/StatusListJobs.scala | 18 +-
.../agent/server/sql/Migrations.scala | 8 +-
.../identus}/api/http/EndpointOutputs.scala | 2 +-
.../identus}/api/http/ErrorResponse.scala | 6 +-
.../identus}/api/http/RequestContext.scala | 2 +-
.../api/http/codec/CirceJsonInterop.scala | 2 +-
.../api/http/codec/CustomMediaTypes.scala | 2 +-
.../identus}/api/http/codec/DIDCodec.scala | 4 +-
.../api/http/codec/DidCommIDCodec.scala | 4 +-
.../identus}/api/http/codec/OrderCodec.scala | 6 +-
.../api/http/model/CollectionStats.scala | 2 +-
.../identus}/api/http/model/Order.scala | 2 +-
.../api/http/model/PaginationInput.scala | 2 +-
.../identus}/api/http/package.scala | 2 +-
.../identus}/api/util/PaginationUtils.scala | 4 +-
.../controller/ConnectionController.scala | 10 +-
.../controller/ConnectionControllerImpl.scala | 18 +-
.../controller/ConnectionEndpoints.scala | 18 +-
.../ConnectionServerEndpoints.scala | 22 +-
.../AcceptConnectionInvitationRequest.scala | 6 +-
.../connect/controller/http/Connection.scala | 12 +-
.../http/ConnectionInvitation.scala | 8 +-
.../controller/http/ConnectionsPage.scala | 6 +-
.../http/CreateConnectionRequest.scala | 6 +-
.../identus}/controller/DIDController.scala | 16 +-
.../identus}/controller/DIDEndpoints.scala | 10 +-
.../controller/DIDRegistrarController.scala | 42 +-
.../controller/DIDRegistrarEndpoints.scala | 22 +-
.../DIDRegistrarServerEndpoints.scala | 16 +-
.../controller/DIDServerEndpoints.scala | 4 +-
.../controller/http/DIDDocument.scala | 8 +-
.../controller/http/DIDDocumentMetadata.scala | 8 +-
.../identus}/controller/http/DIDInput.scala | 2 +-
.../http/DIDResolutionMetadata.scala | 6 +-
.../controller/http/DIDResolutionResult.scala | 2 +-
.../identus}/controller/http/ManagedDID.scala | 24 +-
.../controller/http/PublicKeyJwk.scala | 4 +-
.../controller/http/ScheduledOperation.scala | 8 +-
.../identus}/controller/http/Service.scala | 16 +-
.../controller/http/UpdateManagedDID.scala | 10 +-
.../controller/http/VerificationMethod.scala | 8 +-
.../CredentialStatusController.scala | 12 +-
.../CredentialStatusControllerImpl.scala | 12 +-
.../CredentialStatusEndpoints.scala | 20 +-
.../CredentialStatusServiceEndpoints.scala | 20 +-
.../http/StatusListCredential.scala | 12 +-
.../event/controller/EventController.scala | 28 +-
.../event/controller/EventEndpoints.scala | 24 +-
.../controller/EventServerEndpoints.scala | 16 +-
.../http/CreateWebhookNotification.scala | 2 +-
.../controller/http/WebhookNotification.scala | 6 +-
.../authentication/AuthenticationConfig.scala | 8 +-
.../iam/authentication/Authenticator.scala | 18 +-
.../authentication/DefaultAuthenticator.scala | 20 +-
.../iam/authentication/SecurityLogic.scala | 22 +-
.../admin/AdminApiKeyAuthenticator.scala | 10 +-
.../admin/AdminApiKeyAuthenticatorImpl.scala | 6 +-
.../admin/AdminApiKeyCredentials.scala | 4 +-
.../admin/AdminApiKeySecurityLogic.scala | 2 +-
.../authentication/admin/AdminConfig.scala | 4 +-
.../apikey/ApiKeyAuthenticator.scala | 12 +-
.../apikey/ApiKeyAuthenticatorImpl.scala | 16 +-
.../authentication/apikey/ApiKeyConfig.scala | 4 +-
.../apikey/ApiKeyEndpointSecurityLogic.scala | 2 +-
.../apikey/AuthenticationRepository.scala | 2 +-
.../apikey/JdbcAuthenticationRepository.scala | 2 +-
.../iam/authentication/apikey/package.scala | 2 +-
.../authentication/oidc/JwtCredentials.scala | 6 +-
.../oidc/JwtSecurityLogic.scala | 2 +-
.../oidc/KeycloakAuthenticator.scala | 18 +-
.../oidc/KeycloakAuthenticatorImpl.scala | 16 +-
.../authentication/oidc/KeycloakClient.scala | 2 +-
.../authentication/oidc/KeycloakConfig.scala | 4 +-
.../DefaultPermissionManagementService.scala | 16 +-
.../EntityPermissionManagementService.scala | 18 +-
.../core/PermissionManagement.scala | 20 +-
.../KeycloakPermissionManagementService.scala | 22 +-
.../iam/entity/http/EntityEndpoints.scala | 18 +-
.../entity/http/EntityServerEndpoints.scala | 28 +-
.../http/controller/EntityController.scala | 10 +-
.../controller/EntityControllerImpl.scala | 18 +-
.../model/ApiKeyAuthenticationRequest.scala | 6 +-
.../http/model/CreateEntityRequest.scala | 6 +-
.../entity/http/model/EntityResponse.scala | 8 +-
.../http/model/EntityResponsePage.scala | 8 +-
.../http/model/UpdateEntityNameRequest.scala | 6 +-
.../model/UpdateEntityWalletIdRequest.scala | 6 +-
.../http/WalletManagementEndpoints.scala | 30 +-
.../WalletManagementServerEndpoints.scala | 20 +-
.../WalletManagementController.scala | 46 +-
.../http/model/CreateWalletRequest.scala | 4 +-
.../CreateWalletUmaPermissionRequest.scala | 4 +-
.../iam/wallet/http/model/WalletDetail.scala | 6 +-
.../issue/controller/IssueController.scala | 12 +-
.../controller/IssueControllerImpl.scala | 48 +-
.../issue/controller/IssueEndpoints.scala | 20 +-
.../controller/IssueServerEndpoints.scala | 24 +-
.../http/AcceptCredentialOfferRequest.scala | 6 +-
.../CreateIssueCredentialRecordRequest.scala | 6 +-
.../http/IssueCredentialRecord.scala | 10 +-
.../http/IssueCredentialRecordPage.scala | 6 +-
...redentialDefinitionRegistryEndpoints.scala | 20 +-
...ialDefinitionRegistryServerEndpoints.scala | 26 +-
.../CredentialDefinitionController.scala | 14 +-
.../CredentialDefinitionControllerImpl.scala | 30 +-
.../CredentialDefinitionControllerLogic.scala | 12 +-
.../http/CredentialDefinitionInput.scala | 8 +-
.../http/CredentialDefinitionResponse.scala | 10 +-
.../CredentialDefinitionResponsePage.scala | 6 +-
.../http/FilterInput.scala | 10 +-
.../credentialdefinition/http/Proof.scala | 6 +-
.../SchemaRegistryEndpoints.scala | 20 +-
.../SchemaRegistryServerEndpoints.scala | 20 +-
.../VerificationPolicyEndpoints.scala | 20 +-
.../VerificationPolicyServerEndpoints.scala | 26 +-
.../CredentialSchemaController.scala | 14 +-
.../CredentialSchemaControllerImpl.scala | 28 +-
.../CredentialSchemaControllerLogic.scala | 10 +-
.../VerificationPolicyController.scala | 10 +-
.../VerificationPolicyControllerImpl.scala | 22 +-
.../VerificationPolicyPageRequestLogic.scala | 10 +-
.../http/CredentialSchemaInput.scala | 8 +-
.../http/CredentialSchemaResponse.scala | 10 +-
.../http/CredentialSchemaResponsePage.scala | 6 +-
.../credentialschema/http/FilterInput.scala | 10 +-
.../pollux/credentialschema/http/Proof.scala | 6 +-
.../http/VerificationPolicyResponse.scala | 10 +-
.../controller/PresentProofController.scala | 16 +-
.../PresentProofControllerImpl.scala | 30 +-
.../controller/PresentProofEndpoints.scala | 18 +-
.../PresentProofServerEndpoints.scala | 24 +-
.../controller/http/Options.scala | 6 +-
.../controller/http/PresentationStatus.scala | 10 +-
.../http/PresentationStatusPage.scala | 6 +-
.../controller/http/ProofRequestAux.scala | 6 +-
.../http/RequestPresentationAction.scala | 8 +-
.../http/RequestPresentationInput.scala | 8 +-
.../system/controller/SystemController.scala | 6 +-
.../controller/SystemControllerImpl.scala | 8 +-
.../system/controller/SystemEndpoints.scala | 8 +-
.../controller/SystemServerEndpoints.scala | 8 +-
.../system/controller/http/HealthInfo.scala | 6 +-
.../controller/VcVerificationController.scala | 8 +-
.../VcVerificationControllerImpl.scala | 8 +-
.../controller/VcVerificationEndpoints.scala | 14 +-
.../VcVerificationServerEndpoints.scala | 16 +-
.../http/ParameterizableVcVerification.scala | 2 +-
.../controller/http/VcVerification.scala | 8 +-
.../http/VcVerificationParameter.scala | 2 +-
.../http/VcVerificationRequest.scala | 6 +-
.../http/VcVerificationResponse.scala | 4 +-
.../http/VcVerificationResult.scala | 4 +-
.../resources/anoncred-schema-example.json | 0
.../server/src/test/resources/logback.xml | 0
.../src/test/resources/vc-schema-example.json | 0
.../hyperledger/identus}/ZioHttpTest.scala | 2 +-
.../server/AgentInitializationSpec.scala | 38 +-
.../agent/server/config/AppConfigSpec.scala | 4 +-
.../api/util/PaginationUtilsSpec.scala | 6 +-
.../identus}/api/util/Tapir2StaticOAS.scala | 35 +-
.../container/util}/MigrationAspect.scala | 4 +-
.../authentication/SecurityLogicSpec.scala | 10 +-
.../apikey/ApiKeyAuthenticatorSpec.scala | 26 +-
.../JdbcAuthenticationRepositorySpec.scala | 8 +-
.../oidc/KeycloakAuthenticatorSpec.scala | 34 +-
.../core/EntityPermissionManagementSpec.scala | 34 +-
.../keycloak/admin/KeycloakAdmin.scala | 2 +-
.../keycloak/admin/KeycloakAdminSpec.scala | 4 +-
.../keycloak/admin/KeycloakConfigUtils.scala | 6 +-
...cloakPermissionManagementServiceSpec.scala | 36 +-
.../controller/IssueControllerImplSpec.scala | 38 +-
.../controller/IssueControllerSpec.scala | 12 +-
.../controller/IssueControllerTestTools.scala | 28 +-
.../CredentialDefinitionBasicSpec.scala | 23 +-
.../CredentialDefinitionFailureSpec.scala | 14 +-
...ialDefinitionLookupAndPaginationSpec.scala | 17 +-
.../CredentialDefinitionTestTools.scala | 36 +-
.../schema/CredentialSchemaAnoncredSpec.scala | 22 +-
.../schema/CredentialSchemaBasicSpec.scala | 20 +-
.../schema/CredentialSchemaFailureSpec.scala | 16 +-
...dentialSchemaLookupAndPaginationSpec.scala | 16 +-
.../CredentialSchemaMultiTenancySpec.scala | 14 +-
.../schema/CredentialSchemaTestTools.scala | 39 +-
.../controller/SystemControllerImplSpec.scala | 6 +-
.../SystemControllerTestTools.scala | 10 +-
.../VcVerificationControllerImplSpec.scala | 16 +-
.../VcVerificationControllerTestTools.scala | 28 +-
.../sql/agent/V10__create_peer_did_table.sql | 0
.../sql/agent/V11__wallet_seed_digest.sql | 0
.../sql/agent/V12__generic_secret.sql | 0
...13__apikey_authentication_improvements.sql | 0
.../sql/agent/V14__multiple_did_key_types.sql | 0
.../resources/sql/agent/V1__init_tables.sql | 0
.../sql/agent/V2__did_nonsecret_storage.sql | 0
.../sql/agent/V3__did_update_state.sql | 0
.../resources/sql/agent/V4__did_hd_key.sql | 0
.../sql/agent/V5__remove_did_rand_key.sql | 0
.../V6__add_schema_id_to_secret_table.sql | 0
.../sql/agent/V7__mutitenant_wallet.sql | 0
.../V8__init_entity_repository_tables.sql | 0
..._init_authentication_repository_tables.sql | 0
.../memory/GenericSecretStorageInMemory.scala | 10 +-
.../memory/WalletSecretStorageInMemory.scala | 10 +-
.../agent/walletapi/model/Entity.scala | 4 +-
.../agent/walletapi/model/KeyManagement.scala | 14 +-
.../agent/walletapi/model/ManagedDID.scala | 4 +-
.../walletapi/model/ManagedDIDTemplate.scala | 4 +-
.../agent/walletapi/model/PeerDIDRecord.scala | 8 +
.../agent/walletapi/model/Wallet.scala | 4 +-
.../model/error/CreateManagedDIDError.scala | 5 +-
.../model/error/DIDSecretStorageError.scala | 4 +-
.../model/error/EntityServiceError.scala | 2 +-
.../walletapi/model/error/GetKeyError.scala | 2 +-
.../model/error/GetManagedDIDError.scala | 4 +-
.../model/error/PublishManagedDIDError.scala | 6 +-
.../model/error/UpdateManagedDIDError.scala | 7 +-
.../agent/walletapi/model/error/package.scala | 4 +-
.../walletapi/service/EntityService.scala | 6 +-
.../walletapi/service/EntityServiceImpl.scala | 8 +-
.../walletapi/service/ManagedDIDService.scala | 24 +-
.../service/ManagedDIDServiceImpl.scala | 36 +-
...dDIDServiceWithEventNotificationImpl.scala | 26 +-
.../service/MockManagedDIDService.scala | 20 +-
.../service/WalletManagementService.scala | 16 +-
.../service/WalletManagementServiceImpl.scala | 20 +-
.../service/handler/DIDCreateHandler.scala | 32 +-
.../service/handler/DIDUpdateHandler.scala | 42 +-
.../service/handler/PublicationHandler.scala | 24 +-
.../walletapi/sql/EntityRepository.scala | 6 +-
.../sql/JdbcDIDNonSecretStorage.scala | 16 +-
.../walletapi/sql/JdbcDIDSecretStorage.scala | 18 +-
.../walletapi/sql/JdbcEntityRepository.scala | 8 +-
.../sql/JdbcGenericSecretStorage.scala | 12 +-
.../sql/JdbcWalletNonSecretStorage.scala | 22 +-
.../sql/JdbcWalletSecretStorage.scala | 14 +-
.../agent/walletapi/sql/package.scala | 22 +-
.../storage/DIDNonSecretStorage.scala | 10 +-
.../walletapi/storage/DIDSecretStorage.scala | 12 +-
.../storage/GenericSecretStorage.scala | 4 +-
.../storage/WalletNonSecretStorage.scala | 10 +-
.../storage/WalletSecretStorage.scala | 10 +
.../agent/walletapi/util/KeyResolver.scala | 30 +-
.../util/ManagedDIDTemplateValidator.scala | 10 +-
.../walletapi/util/OperationFactory.scala | 12 +-
.../UpdateManagedDIDActionValidator.scala | 6 +-
.../agent/walletapi/vault/VaultClient.scala | 2 +-
.../vault/VaultDIDSecretStorage.scala | 18 +-
.../vault/VaultGenericSecretStorage.scala | 10 +-
.../vault/VaultWalletSecretStorage.scala | 10 +-
.../agent/walletapi/vault/package.scala | 10 +-
.../wallet-api/src/test/resources/logback.xml | 0
.../walletapi/benchmark/KeyDerivation.scala | 18 +-
.../service/ManagedDIDServiceSpec.scala | 30 +-
.../service/WalletManagementServiceSpec.scala | 32 +-
.../storage/DIDSecretStorageSpec.scala | 22 +-
.../storage/GenericSecretStorageSpec.scala | 28 +-
.../storage/JdbcEntityRepositorySpec.scala | 14 +-
.../JdbcWalletNonSecretStorageSpec.scala | 22 +-
.../walletapi/storage/StorageSpecHelper.scala | 34 +-
.../storage/WalletSecretStorageSpec.scala | 20 +-
.../ManagedDIDTemplateValidatorSpec.scala | 16 +-
.../walletapi/util/OperationFactorySpec.scala | 10 +-
.../identus}/test/container/DBTestUtils.scala | 2 +-
.../identus}/test/container/VaultLayer.scala | 6 +-
.../container/VaultTestContainerSupport.scala | 8 +-
connect/{lib => }/CHANGELOG.md | 0
connect/{lib => }/README.md | 0
connect/{lib => }/connect-protocol-state.md | 0
.../connect/core/model/ConnectionRecord.scala | 8 +-
.../model/error/ConnectionServiceError.scala | 6 +-
.../repository/ConnectionRepository.scala | 10 +-
.../ConnectionRepositoryInMemory.scala | 16 +-
.../core/service/ConnectionService.scala | 16 +-
.../core/service/ConnectionServiceImpl.scala | 29 +-
.../service/ConnectionServiceNotifier.scala | 18 +-
.../core/service/MockConnectionService.scala | 16 +-
.../ConnectionRepositoryInMemorySpec.scala | 2 +-
.../ConnectionRepositorySpecSuite.scala | 18 +-
.../service/ConnectionServiceImplSpec.scala | 18 +-
.../ConnectionServiceNotifierSpec.scala | 18 +-
.../resources/sql/connect/V1__init_tables.sql | 0
.../V2__add_thid_unique_constraint.sql | 0
...add_meta_retries_and_meta_last_failure.sql | 0
.../V4__create_protocol_state_index.sql | 0
.../sql/connect/V5__add_meta_next_retry.sql | 0
.../sql/connect/V6__add_rls_policy.sql | 0
.../connect/V7__add_goal_and_goal_code.sql | 0
.../repository/JdbcConnectionRepository.scala | 18 +-
.../connect/sql/repository/Migrations.scala | 8 +-
.../sql-doobie/src/test/resources/logback.xml | 0
.../JdbcConnectionRepositorySpec.scala | 8 +-
.../container/PostgresTestContainer.scala | 4 +-
...se-zio-failures-and-defects-effectively.md | 6 +-
docs/general/key-derivation-benchmark.md | 2 +-
docs/guides/linting.md | 12 +-
.../identus}/event/notification/Event.scala | 4 +-
.../event/notification/EventConsumer.scala | 2 +-
.../EventNotificationConfig.scala | 6 +-
.../EventNotificationService.scala | 2 +-
.../EventNotificationServiceError.scala | 2 +-
.../EventNotificationServiceImpl.scala | 4 +-
.../event/notification/EventProducer.scala | 2 +-
.../EventNotificationServiceImplSpec.scala | 4 +-
examples/readme.md | 2 +-
.../ci/docker-compose-multiple-actors.yml | 154 +
infrastructure/dev/get-versions.sh | 4 +-
infrastructure/local/.env | 2 +-
infrastructure/local/update_env.sh | 4 +-
infrastructure/multi/.env | 2 +-
infrastructure/shared/docker-compose-demo.yml | 2 +-
.../shared/docker-compose-mt-keycloak.yml | 2 +-
infrastructure/shared/docker-compose.yml | 2 +-
.../single-tenant-testing-stack/.env | 2 +-
.../docker-compose.yml | 6 +-
.../run-performance-tests-local.sh | 2 +-
mercury/{mercury-library => }/CHANGELOG.md | 0
mercury/{mercury-library => }/QuickStart.md | 0
mercury/README.md | 100 +-
mercury/{mercury-library => }/UseCases.md | 0
.../identus}/mercury/AgentPeerService.scala | 4 +-
.../identus}/mercury/DidCommX.scala | 6 +-
.../identus}/mercury/MessagingService.scala | 12 +-
.../identus}/mercury/PeerDID.scala | 4 +-
.../identus}/mercury/model/Conversions.scala | 4 +-
.../mercury/model/JsonUtilsForDidCommx.scala | 2 +-
.../identus}/mercury/model/package.scala | 2 +-
.../resolvers/AliceSecretResolver.scala | 2 +-
.../resolvers/BobSecretResolver.scala | 2 +-
.../identus}/mercury/PeerDIDSpec.scala | 7 +-
.../mercury/model/UnpackMessageImpSpec.scala | 4 +-
.../hyperledger/identus}/mercury/Agent.scala | 4 +-
.../mercury/CoordinateMediationPrograms.scala | 10 +-
.../identus}/mercury/HttpClient.scala | 2 +-
.../identus}/mercury/InvitationPrograms.scala | 8 +-
.../mercury/OutOfBandLoginPrograms.scala | 6 +-
mercury/mercury-library/README.md | 97 -
.../src/main/scala/io/iohk/atala/Main.scala | 129 -
.../resolvers/CharlieSecretResolver.scala | 62 -
.../scala/io/iohk/atala/AgentPrograms.scala | 106 -
.../protocol/didexchange/v1/DIDExchange.scala | 3 -
.../Mercury-Mailbox-Protocol.md | 87 -
.../mercury/protocol/mailbox/Mailbox.scala | 26 -
.../identus}/mercury/DidAgent.scala | 4 +-
.../hyperledger/identus}/mercury/DidOps.scala | 4 +-
.../identus}/mercury/MediaTypes.scala | 2 +-
.../mercury/model/AttachmentDescriptor.scala | 2 +-
.../identus}/mercury/model/DidId.scala | 2 +-
.../mercury/model/EncryptedMessage.scala | 2 +-
.../identus}/mercury/model/Message.scala | 2 +-
.../identus}/mercury/model/SignedMesage.scala | 2 +-
.../identus}/mercury/model/UnpackResult.scala | 2 +-
.../mercury/model/error/package.scala | 2 +-
.../Connection-Protocol.md | 0
.../connection/ConnectionInvitation.scala | 10 +-
.../connection/ConnectionRequest.scala | 10 +-
.../connection/ConnectionResponse.scala | 4 +-
.../protocol/connection/ConnectionSpec.scala | 6 +-
.../Coordinate-Mediation-Protocol.md | 0
.../CoordinateMediation.scala | 4 +-
.../CoordinateMediationSpec.scala | 2 +-
.../DidExchange-Protocol.md | 0
.../didexchange/v1/DidExchangeRequest.scala | 4 +-
.../Invitation-Protocol.md | 0
.../protocol/invitation/OutOfBand.scala | 5 +-
.../protocol/invitation/ServiceType.scala | 2 +-
.../mercury/protocol/invitation/package.scala | 2 +-
.../protocol/invitation/v1/Invitation.scala | 12 +-
.../protocol/invitation/v2/Invitation.scala | 6 +-
.../invitation/v1/InvitationV1Spec.scala | 6 +-
.../invitation/v2/OutOfBandSpec.scala | 10 +-
.../Issue-Credential-Protocol.md | 0
.../protocol/issuecredential/Credential.scala | 2 +-
.../issuecredential/CredentialPreview.scala | 2 +-
.../issuecredential/IssueCredential.scala | 4 +-
.../issuecredential/IssueFormats.scala | 2 +-
.../issuecredential/OfferCredential.scala | 6 +-
.../issuecredential/ProposeCredential.scala | 6 +-
.../issuecredential/RequestCredential.scala | 6 +-
.../protocol/issuecredential/Utils.scala | 4 +-
.../UtilsCredentialSpec.scala | 18 +-
.../issuecredential/IssueCredentialSpec.scala | 6 +-
.../issuecredential/OfferCredentialSpec.scala | 8 +-
.../ProposeCredentialSpec.scala | 9 +-
.../RequestCredentialSpec.scala | 7 +-
.../OutOfBand-Login-Protocol.md | 0
.../outofbandlogin/OutOfBandLogin.scala | 8 +-
.../protocol/outofbandlogin/Utils.scala | 4 +-
.../Present-Proof-Protocol.md | 0
.../presentproof/PresentFormats.scala | 2 +-
.../protocol/presentproof/Presentation.scala | 4 +-
.../protocol/presentproof/ProofType.scala | 4 +-
.../presentproof/ProposePresentation.scala | 5 +-
.../presentproof/RequestPresentation.scala | 5 +-
.../presentproof/PresentationSpec.scala | 9 +-
.../ProposePresentationProofSpec.scala | 8 +-
.../RequestPresentationSpec.scala | 8 +-
.../Report-Problem-Protocol.md | 0
.../reportproblem/v1/ReportProblem.scala | 6 +-
.../reportproblem/v2/ReportProblem.scala | 4 +-
.../reportproblem/v2/ReportProblemSpec.scala | 5 +-
.../Revocation-notification-protocol.md | 0
.../RevocationNotification.scala | 4 +-
.../protocol-routing/Routing-Protocol.md | 0
.../protocol/routing/ForwardMessage.scala | 4 +-
.../protocol/trustping/TrustPing.scala | 4 +-
.../trustping/TrustPingResponse.scala | 4 +-
.../identus}/resolvers/DidValidator.scala | 4 +-
.../identus}/resolvers/PeerDidResolver.scala | 2 +-
.../resolvers/UniversalDidResolver.scala | 4 +-
.../identus}/resolvers/AliceDidDoc.scala | 2 +-
.../identus}/resolvers/BobDidDoc.scala | 4 +-
.../identus}/resolvers/DidValidatorSpec.scala | 4 +-
.../identus}/resolvers/MediatorDidDoc.scala | 2 +-
.../resolvers/PeerDidResolverSpec.scala | 2 +-
mercury/roots-id-mediator/Dockerfile | 8 -
.../REAMDE-ROOTS-ID-mediator.md | 81 -
mercury/roots-id-mediator/docker-compose.yaml | 44 -
.../roots-id-mediator/notebooks/.gitignore | 8 -
.../roots-id-mediator/notebooks/Alice.ipynb | 757 ----
mercury/roots-id-mediator/notebooks/Bob.ipynb | 393 --
.../notebooks/test_mediator.ipynb | 414 --
.../vc/anoncreds/CredentialFilterFormat.scala | 4 +-
.../vc/anoncreds/CredentialFormat.scala | 4 +-
.../vc/anoncreds/CredentialOfferFormat.scala | 4 +-
.../anoncreds/CredentialRequestFormat.scala | 4 +-
.../mercury/vc/anoncreds/ProofFormat.scala | 4 +-
.../vc/anoncreds/ProofRequestFormat.scala | 4 +-
.../mercury/vc/dif}/ProposeCredential.scala | 2 +-
.../mercury/vc/jwt}/ProposeCredential.scala | 2 +-
package.json | 16 +-
pollux/{lib => }/CHANGELOG.md | 0
pollux/{lib => }/README.md | 0
.../{lib => }/anoncreds/README_anoncreds.md | 0
.../anoncreds/anoncreds-jvm-1.0-SNAPSHOT.jar | Bin
.../libuniffi_anoncreds_wrapper.dylib | Bin
.../libuniffi_anoncreds_wrapper.dylib | Bin
.../libuniffi_anoncreds_wrapper.so | Bin
.../libuniffi_anoncreds_wrapper.so | Bin
.../native-lib/helper_script_to_update.sh | 0
.../pollux/anoncreds/AnoncredLib.scala | 2 +-
.../identus}/pollux/anoncreds/Models.scala | 2 +-
.../anoncredsTest/src/test/scala/Uniffy.scala | 0
.../identus}/pollux/anoncreds/PoCNewLib.scala | 11 +-
.../pollux/core/model/CredentialFormat.scala | 2 +-
.../model/CredentialOfferAttachment.scala | 4 +-
.../core/model/CredentialStatusList.scala | 8 +-
.../pollux/core/model/DidCommID.scala | 2 +-
.../core/model/IssueCredentialRecord.scala | 10 +-
.../core/model/PresentationRecord.scala | 6 +-
.../core/model/VerificationPolicy.scala | 2 +-
.../error/CredentialRepositoryError.scala | 2 +-
.../model/error/CredentialSchemaError.scala | 4 +-
.../model/error/CredentialServiceError.scala | 8 +-
.../CredentialStatusListServiceError.scala | 4 +-
.../core/model/error/LinkSecretError.scala | 3 +
.../core/model/error/PresentationError.scala | 4 +-
.../model/error/VerificationPolicyError.scala | 2 +-
.../presentation/PresentationAttachment.scala | 2 +-
.../model/schema/CredentialDefinition.scala | 6 +-
.../core/model/schema/CredentialSchema.scala | 14 +-
.../schema/type/AnoncredSchemaType.scala | 27 +
.../type/CredentialJsonSchemaSerDesV1.scala | 4 +-
.../type/CredentialJsonSchemaType.scala | 8 +-
.../schema/type/CredentialSchemaType.scala | 11 +
.../anoncred/AnoncredSchemaSerDesV1.scala | 4 +-
.../schema/validator/JsonSchemaError.scala | 2 +-
.../schema/validator/JsonSchemaUtils.scala | 4 +-
.../validator/JsonSchemaValidator.scala | 2 +-
.../validator/JsonSchemaValidatorImpl.scala | 8 +-
.../model/schema/validator/SchemaSerDes.scala | 4 +-
.../secret/CredentialDefinitionSecret.scala | 4 +-
.../CredentialDefinitionRepository.scala | 8 +-
...edentialDefinitionRepositoryInMemory.scala | 10 +-
.../repository/CredentialRepository.scala | 12 +-
.../CredentialRepositoryInMemory.scala | 14 +-
.../CredentialSchemaRepository.scala | 10 +-
.../CredentialStatusListRepository.scala | 8 +-
...edentialStatusListRepositoryInMemory.scala | 16 +-
.../repository/PresentationRepository.scala | 10 +-
.../PresentationRepositoryInMemory.scala | 12 +-
.../VerificationPolicyRepository.scala | 6 +-
.../pollux/core/repository/repository.scala | 4 +-
.../service/CredentialDefinitionService.scala | 10 +-
.../CredentialDefinitionServiceImpl.scala | 30 +-
.../service/CredentialSchemaService.scala | 10 +-
.../service/CredentialSchemaServiceImpl.scala | 14 +-
.../core/service/CredentialService.scala | 21 +-
.../core/service/CredentialServiceImpl.scala | 50 +-
.../service/CredentialServiceNotifier.scala | 16 +-
.../service/CredentialStatusListService.scala | 8 +-
.../CredentialStatusListServiceImpl.scala | 12 +-
.../service/HttpURIDereferencerImpl.scala | 8 +-
.../core/service/LinkSecretService.scala | 12 +
.../core/service/LinkSecretServiceImpl.scala | 10 +-
.../core/service/MockCredentialService.scala | 14 +-
.../service/MockPresentationService.scala | 27 +-
.../core/service/PresentationService.scala | 24 +-
.../service/PresentationServiceImpl.scala | 40 +-
.../service/PresentationServiceNotifier.scala | 29 +-
.../service/ResourceURIDereferencerImpl.scala | 4 +-
.../pollux/core/service/URIDereferencer.scala | 2 +-
.../service/VerificationPolicyService.scala | 8 +-
.../VerificationPolicyServiceImpl.scala | 10 +-
.../serdes/AnoncredCredentialProofsV1.scala | 4 +-
.../AnoncredPresentationRequestV1.scala | 4 +-
.../serdes/AnoncredPresentationV1.scala | 4 +-
...teCredentialDefinitionSchemaSerDesV1.scala | 4 +-
...eyCredentialDefinitionSchemaSerDesV1.scala | 4 +-
...icCredentialDefinitionSchemaSerDesV1.scala | 4 +-
.../service/verification/VcVerification.scala | 2 +-
.../verification/VcVerificationService.scala | 2 +-
.../VcVerificationServiceError.scala | 2 +-
.../VcVerificationServiceImpl.scala | 8 +-
.../anoncred-presentation-schema-example.json | 0
.../resources/anoncred-schema-example.json | 0
.../core/src/test/resources/logback.xml | 0
.../src/test/resources/vc-schema-example.json | 0
.../PresentationAttachmentSpec.scala | 2 +-
.../model/schema/AnoncredSchemaTypeSpec.scala | 6 +-
.../model/schema/CredentialSchemaSpec.scala | 16 +-
.../CredentialRepositoryInMemorySpec.scala | 4 +-
.../CredentialRepositorySpecSuite.scala | 16 +-
.../PresentationRepositoryInMemorySpec.scala | 2 +-
.../PresentationRepositorySpecSuite.scala | 14 +-
.../CredentialDefinitionServiceImplSpec.scala | 2 +-
...redentialDefinitionServiceSpecHelper.scala | 14 +-
.../service/CredentialServiceImplSpec.scala | 31 +-
.../CredentialServiceNotifierSpec.scala | 14 +-
.../service/CredentialServiceSpecHelper.scala | 26 +-
.../service/LinkSecretServiceImplSpec.scala | 12 +-
.../PresentationServiceNotifierSpec.scala | 22 +-
.../service/PresentationServiceSpec.scala | 40 +-
.../PresentationServiceSpecHelper.scala | 30 +-
.../AnoncredPresentationRequestSpec.scala | 2 +-
.../serdes/AnoncredPresentationSpec.scala | 4 +-
...CredentialDefinitionSchemaSerDesSpec.scala | 2 +-
.../VcVerificationServiceImplSpec.scala | 14 +-
.../VcVerificationServiceSpecHelper.scala | 20 +-
pollux/{lib => }/issue-protocol-state.md | 0
.../core/model/error/LinkSecretError.scala | 3 -
.../schema/type/AnoncredSchemaType.scala | 27 -
.../schema/type/CredentialSchemaType.scala | 11 -
.../core/service/LinkSecretService.scala | 12 -
...ion_records_add_thid_unique_constraint.sql | 0
...V11__issue_credential_extend_schema_id.sql | 0
...V12__verification_policies_reset_nonce.sql | 0
.../pollux/V13__credential_schema_tables.sql | 0
.../sql/pollux/V14__add_rls_policy.sql | 0
.../sql/pollux/V15__add_anoncreds_columns.sql | 0
...ocation_status_lists_table_and_columns.sql | 0
...dd_anoncred_credentials_to_use_columns.sql | 0
...V18__issue_credential_rename_schema_id.sql | 0
...vocation_status_list_table_and_columns.sql | 0
.../resources/sql/pollux/V1__init_tables.sql | 0
.../sql/pollux/V3__schema_registry_tables.sql | 0
.../V5__create_protocol_state_index.sql | 0
.../pollux/V6__verification_policy_tables.sql | 0
.../pollux/V8__credential_schema_tables.sql | 0
...sue_credential_drop_subjectId_not_null.sql | 0
.../pollux/sql/model/JWTCredentialRow.scala | 2 +-
.../sql/model/db/CredentialDefinition.scala | 12 +-
.../sql/model/db/CredentialSchema.scala | 12 +-
.../sql/model/db/VerificationPolicy.scala | 6 +-
.../pollux/sql/model/db/package.scala | 4 +-
.../pollux/sql/repository/Implicits.scala | 10 +-
.../JdbcCredentialDefinitionRepository.scala | 19 +-
.../repository/JdbcCredentialRepository.scala | 22 +-
.../JdbcCredentialSchemaRepository.scala | 16 +-
.../JdbcCredentialStatusListRepository.scala | 20 +-
.../JdbcPresentationRepository.scala | 16 +-
.../JdbcVerificationPolicyRepository.scala | 20 +-
.../pollux/sql/repository/Migrations.scala | 8 +-
.../data/verifiableCredentialClaims.csv | 0
.../data/verifiableCredentialTypes.csv | 0
...edentialDefinitionSqlIntegrationSpec.scala | 14 +-
.../CredentialSchemaSqlIntegrationSpec.scala | 16 +-
...VerificationPolicySqlIntegrationSpec.scala | 22 +-
.../JdbcCredentialRepositorySpec.scala | 8 +-
.../JdbcPresentationRepositorySpec.scala | 8 +-
.../test/container}/MigrationAspect.scala | 4 +-
.../io/iohk/atala/pollux/vc/jwt/DidJWT.scala | 2 +-
.../atala/pollux/vc/jwt/DidResolver.scala | 6 +-
.../pollux/vc/jwt/InstantDecoderEncoder.scala | 2 +-
.../atala/pollux/vc/jwt/JWTVerification.scala | 4 +-
.../atala/pollux/vc/jwt/MultiBaseString.scala | 4 +-
.../iohk/atala/pollux/vc/jwt/MultiKey.scala | 2 +-
.../io/iohk/atala/pollux/vc/jwt/Proof.scala | 6 +-
.../atala/pollux/vc/jwt/ValidationUtils.scala | 2 +-
.../iohk/atala/pollux/vc/jwt/Verifiable.scala | 2 +-
.../vc/jwt/VerifiableCredentialPayload.scala | 10 +-
.../jwt/VerifiablePresentationPayload.scala | 8 +-
.../pollux/vc/jwt/demos/CredentialDemo.scala | 6 +-
...tCredentialDIDDocumentValidationDemo.scala | 6 +-
.../jwt/demos/JwtCredentialEncodingDemo.scala | 6 +-
...wtCredentialTemporalVerificationDemo.scala | 6 +-
.../demos/JwtPresentationCredentialDemo.scala | 8 +-
...PresentationTemporalVerificationDemo.scala | 8 +-
.../JwtPresentationVerificationDemo.scala | 8 +-
.../pollux/vc/jwt/demos/SchemaDemo.scala | 2 +-
.../pollux/vc/jwt/revocation/BitString.scala | 4 +-
.../vc/jwt/revocation/VCStatusList2021.scala | 6 +-
.../schema/PlaceholderSchemaValidator.scala | 2 +-
.../schema/ReactiveCoreSchemaValidator.scala | 2 +-
.../pollux/vc/jwt/schema/SchemaResolver.scala | 4 +-
.../vc/jwt/schema/SchemaValidator.scala | 2 +-
.../pollux/vc/jwt/ECDSAVerifierTest.scala | 2 +-
.../pollux/vc/jwt/ES256KSignerTest.scala | 2 +-
.../pollux/vc/jwt/JWTVerificationTest.scala | 8 +-
.../vc/jwt/revocation/BitStringSpec.scala | 4 +-
.../jwt/revocation/VCStatusList2021Spec.scala | 4 +-
.../client/generator/generate-clients.sh | 20 -
.../client/generator/publish-clients.sh | 16 -
.../agent/walletapi/model/PeerDIDRecord.scala | 8 -
.../storage/WalletSecretStorage.scala | 10 -
.../storage/JdbcDIDNonSecretStorageSpec.scala | 288 --
.../src/main/resources/package.proto | 2 +-
.../identus}/shared/db/ContextAwareTask.scala | 6 +-
.../identus}/shared/db/DbConfig.scala | 2 +-
.../identus}/shared/db/TransactorLayer.scala | 2 +-
.../shared/http/GenericUriResolver.scala | 2 +-
.../shared/models/Base64UrlString.scala | 4 +-
.../identus}/shared/models/Failure.scala | 2 +-
.../identus}/shared/models/HexString.scala | 4 +-
.../identus}/shared/models/MultiTenancy.scala | 2 +-
.../identus}/shared/utils/Base64Utils.scala | 2 +-
.../identus}/shared/utils/BytesOps.scala | 2 +-
.../identus}/shared/utils/DurationOps.scala | 2 +-
.../identus}/shared/utils/Json.scala | 2 +-
.../identus}/shared/utils/Traverse.scala | 2 +-
.../utils/aspects/CustomMetricsAspect.scala | 4 +-
.../identus}/shared/utils/proto/Path.scala | 2 +-
.../shared/utils/proto/ValidationError.scala | 2 +-
.../identus}/shared/utils/proto/package.scala | 4 +-
.../shared/validation/ValidationUtils.scala | 2 +-
.../identus}/shared/crypto/Apollo.scala | 4 +-
.../identus}/shared/crypto/KmpApollo.scala | 2 +-
.../shared/crypto/Prism14Apollo.scala | 2 +-
.../identus}/shared/crypto/jwk/JWK.scala | 4 +-
.../identus}/shared/crypto/ApolloSpec.scala | 4 +-
.../shared/crypto/ApolloSpecHelper.scala | 3 +-
.../containers/KeycloakContainerCustom.scala | 4 +-
.../containers/KeycloakTestContainer.scala | 2 +-
.../KeycloakTestContainerSupport.scala | 2 +-
.../KeycloakTestContainerSupportSpec.scala | 2 +-
.../PostgreSQLContainerCustom.scala | 2 +-
.../sharedtest/containers/PostgresLayer.scala | 6 +-
.../containers/PostgresTestContainer.scala | 2 +-
.../PostgresTestContainerSupport.scala | 6 +-
.../containers/VaultContainerCustom.scala | 2 +-
.../containers/VaultTestContainer.scala | 2 +-
.../.babelrc | 0
.../.env | 0
.../.gitignore | 0
.../.npmrc | 0
.../.yarnrc | 0
.../README.md | 0
.../package.json | 0
.../run.sh | 0
.../src/actors/Actor.ts | 0
.../src/actors/Holder.ts | 0
.../src/actors/Issuer.ts | 0
.../src/actors/Verifier.ts | 0
.../src/actors/index.ts | 0
.../src/common/Config.ts | 0
.../src/common/ConnectionService.ts | 0
.../src/common/CredentialsService.ts | 0
.../src/common/DidService.ts | 0
.../src/common/HttpService.ts | 0
.../src/common/ProofsService.ts | 0
.../src/k6chaijs.js | 0
.../src/scenarios/default.ts | 0
.../src/tests/common.ts | 0
.../credentials/credential-definition-test.ts | 0
.../credentials/credential-offer-test.ts | 0
.../credentials/credential-schema-test.ts | 0
.../src/tests/dids/create-prism-did-test.ts | 0
.../src/tests/dids/did-publishing-test.ts | 0
.../src/tests/flows/connection-flow-test.ts | 0
.../src/tests/flows/issuance-flow-test.ts | 0
.../tests/flows/present-proof-flow-test.ts | 0
.../tsconfig.json | 0
.../webpack.config.js | 2 +-
.../yarn.lock | 0
.../.gitignore | 0
.../README.md | 0
.../bin/gatling}/common/Configuration.kt | 0
.../bin/gatling}/common/Utils.kt | 0
.../bin/gatling}/gatling.conf | 0
.../simulations/ConnectionSimulation.kt | 0
.../simulations/IssuanceSimulation.kt | 0
.../bin/gatling}/steps/ConnectionSteps.kt | 0
.../bin/gatling}/steps/IssuanceSteps.kt | 0
.../build.gradle.kts | 0
.../gradle.properties | 0
.../gradle/wrapper/gradle-wrapper.jar | Bin
.../gradle/wrapper/gradle-wrapper.properties | 0
.../gradlew | 0
.../gradlew.bat | 0
.../settings.gradle.kts | 3 +
.../gatling/kotlin/common/Configuration.kt | 45 +
.../src/gatling/kotlin/common/Utils.kt | 35 +
.../simulations/ConnectionSimulation.kt | 26 +
.../kotlin/simulations/IssuanceSimulation.kt | 34 +
.../gatling/kotlin/steps/ConnectionSteps.kt | 181 +
.../src/gatling/kotlin/steps/IssuanceSteps.kt | 168 +
.../src/gatling/resources/gatling.conf | 127 +
.../settings.gradle.kts | 3 -
805 files changed, 6116 insertions(+), 7483 deletions(-)
rename castor/{lib => }/CHANGELOG.md (100%)
rename castor/{lib => }/README.md (100%)
delete mode 100644 castor/lib/core/src/main/scala/io/iohk/atala/castor/core/repository/DIDOperationRepository.scala
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/ProtoModelHelper.scala (98%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/DID.scala (96%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/DIDData.scala (89%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/DIDUrl.scala (71%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/EllipticCurve.scala (91%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/PrismDID.scala (95%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/PrismDIDOperation.scala (95%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/PublicKey.scala (85%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/Service.scala (79%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/ServiceEndpoint.scala (93%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/ServiceType.scala (92%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/VerificationRelationship.scala (92%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/w3c/DIDDocumentRepr.scala (93%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/w3c/DIDMetadata.scala (94%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/w3c/W3CModelHelper.scala (94%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/did/w3c/package.scala (87%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/model/error/package.scala (96%)
create mode 100644 castor/src/main/scala/org/hyperledger/identus/castor/core/repository/DIDOperationRepository.scala
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/service/DIDService.scala (93%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/service/MockDIDService.scala (91%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/util/DIDOperationValidator.scala (97%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/util/Prelude.scala (76%)
rename castor/{lib/core/src/main/scala/io/iohk/atala => src/main/scala/org/hyperledger/identus}/castor/core/util/UriUtils.scala (99%)
rename castor/{lib/core/src/test/scala/io/iohk/atala => src/test/scala/org/hyperledger/identus}/castor/core/model/ProtoModelHelperSpec.scala (97%)
rename castor/{lib/core/src/test/scala/io/iohk/atala => src/test/scala/org/hyperledger/identus}/castor/core/model/did/DIDSpec.scala (98%)
rename castor/{lib/core/src/test/scala/io/iohk/atala => src/test/scala/org/hyperledger/identus}/castor/core/model/did/PrismDIDSpec.scala (95%)
rename castor/{lib/core/src/test/scala/io/iohk/atala => src/test/scala/org/hyperledger/identus}/castor/core/model/did/ServiceEndpointSpec.scala (88%)
rename castor/{lib/core/src/test/scala/io/iohk/atala => src/test/scala/org/hyperledger/identus}/castor/core/model/did/ServiceTypeSpec.scala (93%)
rename castor/{lib/core/src/test/scala/io/iohk/atala => src/test/scala/org/hyperledger/identus}/castor/core/model/did/w3c/W3CModelHelperSpec.scala (95%)
rename castor/{lib/core/src/test/scala/io/iohk/atala => src/test/scala/org/hyperledger/identus}/castor/core/service/DIDServiceSpec.scala (93%)
rename castor/{lib/core/src/test/scala/io/iohk/atala => src/test/scala/org/hyperledger/identus}/castor/core/util/DIDOperationValidatorSpec.scala (98%)
rename castor/{lib/core/src/test/scala/io/iohk/atala => src/test/scala/org/hyperledger/identus}/castor/core/util/GenUtils.scala (90%)
rename {prism-agent => cloud-agent}/client/.gitignore (100%)
rename {prism-agent => cloud-agent}/client/README.md (100%)
rename {prism-agent => cloud-agent}/client/generator/clean.sh (100%)
create mode 100755 cloud-agent/client/generator/generate-clients.sh
rename {prism-agent => cloud-agent}/client/generator/openapitools.json (100%)
rename {prism-agent => cloud-agent}/client/generator/package.json (92%)
create mode 100755 cloud-agent/client/generator/publish-clients.sh
rename {prism-agent => cloud-agent}/client/generator/yarn.lock (100%)
rename {prism-agent => cloud-agent}/client/kotlin/.openapi-generator-ignore (100%)
rename {prism-agent => cloud-agent}/client/kotlin/build.gradle (100%)
rename {prism-agent => cloud-agent}/client/kotlin/gradle.properties (100%)
rename {prism-agent => cloud-agent}/client/kotlin/gradle/wrapper/gradle-wrapper.jar (100%)
rename {prism-agent => cloud-agent}/client/kotlin/gradle/wrapper/gradle-wrapper.properties (100%)
rename {prism-agent => cloud-agent}/client/kotlin/gradlew (100%)
rename {prism-agent => cloud-agent}/client/kotlin/gradlew.bat (100%)
rename {prism-agent => cloud-agent}/client/kotlin/settings.gradle (100%)
rename {prism-agent => cloud-agent}/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/CredentialSubject.kt (96%)
rename {prism-agent => cloud-agent}/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/Service.kt (91%)
rename {prism-agent => cloud-agent}/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/UpdateManagedDIDServiceAction.kt (89%)
rename {prism-agent => cloud-agent}/client/python/.openapi-generator-ignore (100%)
rename {prism-agent => cloud-agent}/client/python/setup.py (100%)
rename {prism-agent => cloud-agent}/client/typescript/.openapi-generator-ignore (100%)
rename {prism-agent => cloud-agent}/client/typescript/models/Service.ts (100%)
rename {prism-agent => cloud-agent}/client/typescript/models/UpdateManagedDIDServiceAction.ts (100%)
rename {prism-agent => cloud-agent}/client/typescript/package.json (100%)
rename {prism-agent => cloud-agent}/service/CHANGELOG.md (100%)
rename {prism-agent => cloud-agent}/service/README.md (100%)
rename prism-agent/service/api/http/prism-agent-openapi-spec.yaml => cloud-agent/service/api/http/cloud-agent-openapi-spec.yaml (64%)
rename {prism-agent => cloud-agent}/service/server/src/main/resources/application.conf (100%)
rename {prism-agent => cloud-agent}/service/server/src/main/resources/logback.xml (100%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/LogUtils.scala (91%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/notification/JsonEventEncoders.scala (63%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/notification/WebhookPublisher.scala (83%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/notification/WebhookPublisherError.scala (80%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/ControllerHelper.scala (66%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/DidCommHttpServer.scala (86%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/DidCommHttpServerError.scala (87%)
rename prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Main.scala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/MainApp.scala (76%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/Modules.scala (79%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/PrismAgentApp.scala (76%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/config/AppConfig.scala (95%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/http/CustomServerInterceptors.scala (96%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/http/DocModels.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/http/ZHttp4sBlazeServer.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/http/ZHttpEndpoints.scala (91%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/http/ZioHttpClient.scala (94%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/jobs/BackgroundJobError.scala (80%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/jobs/BackgroundJobsHelper.scala (77%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/jobs/ConnectBackgroundJobs.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/jobs/DIDStateSyncBackgroundJobs.scala (70%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/jobs/IssueBackgroundJobs.scala (95%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/jobs/PresentBackgroundJobs.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/jobs/StatusListJobs.scala (89%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/agent/server/sql/Migrations.scala (89%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/EndpointOutputs.scala (98%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/ErrorResponse.scala (96%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/RequestContext.scala (68%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/codec/CirceJsonInterop.scala (96%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/codec/CustomMediaTypes.scala (88%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/codec/DIDCodec.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/codec/DidCommIDCodec.scala (81%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/codec/OrderCodec.scala (86%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/model/CollectionStats.scala (58%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/model/Order.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/model/PaginationInput.scala (94%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/http/package.scala (94%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/api/util/PaginationUtils.scala (95%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/connect/controller/ConnectionController.scala (72%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/connect/controller/ConnectionControllerImpl.scala (79%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/connect/controller/ConnectionEndpoints.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/connect/controller/ConnectionServerEndpoints.scala (79%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/connect/controller/http/AcceptConnectionInvitationRequest.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/connect/controller/http/Connection.scala (95%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/connect/controller/http/ConnectionInvitation.scala (92%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/connect/controller/http/ConnectionsPage.scala (94%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/connect/controller/http/CreateConnectionRequest.scala (89%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/DIDController.scala (76%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/DIDEndpoints.scala (92%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/DIDRegistrarController.scala (82%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/DIDRegistrarEndpoints.scala (89%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/DIDRegistrarServerEndpoints.scala (88%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/DIDServerEndpoints.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/DIDDocument.scala (92%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/DIDDocumentMetadata.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/DIDInput.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/DIDResolutionMetadata.scala (89%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/DIDResolutionResult.scala (91%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/ManagedDID.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/PublicKeyJwk.scala (86%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/ScheduledOperation.scala (89%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/Service.scala (91%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/UpdateManagedDID.scala (95%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala/castor => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/controller/http/VerificationMethod.scala (88%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/credentialstatus/controller/CredentialStatusController.scala (74%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/credentialstatus/controller/CredentialStatusControllerImpl.scala (69%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/credentialstatus/controller/CredentialStatusEndpoints.scala (68%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/credentialstatus/controller/CredentialStatusServiceEndpoints.scala (73%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/credentialstatus/controller/http/StatusListCredential.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/event/controller/EventController.scala (73%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/event/controller/EventEndpoints.scala (68%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/event/controller/EventServerEndpoints.scala (81%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/event/controller/http/CreateWebhookNotification.scala (90%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/event/controller/http/WebhookNotification.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/AuthenticationConfig.scala (52%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/Authenticator.scala (86%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/DefaultAuthenticator.scala (69%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/SecurityLogic.scala (83%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/admin/AdminApiKeyAuthenticator.scala (63%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/admin/AdminApiKeyAuthenticatorImpl.scala (78%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/admin/AdminApiKeyCredentials.scala (74%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/admin/AdminApiKeySecurityLogic.scala (88%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/admin/AdminConfig.scala (73%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/apikey/ApiKeyAuthenticator.scala (79%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/apikey/ApiKeyAuthenticatorImpl.scala (90%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/apikey/ApiKeyConfig.scala (70%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/apikey/ApiKeyEndpointSecurityLogic.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/apikey/AuthenticationRepository.scala (98%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/apikey/JdbcAuthenticationRepository.scala (98%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/apikey/package.scala (88%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/oidc/JwtCredentials.scala (59%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/oidc/JwtSecurityLogic.scala (83%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/oidc/KeycloakAuthenticator.scala (83%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/oidc/KeycloakAuthenticatorImpl.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/oidc/KeycloakClient.scala (99%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authentication/oidc/KeycloakConfig.scala (80%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authorization/DefaultPermissionManagementService.scala (74%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authorization/core/EntityPermissionManagementService.scala (69%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authorization/core/PermissionManagement.scala (72%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/authorization/keycloak/admin/KeycloakPermissionManagementService.scala (91%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/EntityEndpoints.scala (92%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/EntityServerEndpoints.scala (82%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/controller/EntityController.scala (80%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/controller/EntityControllerImpl.scala (84%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/model/ApiKeyAuthenticationRequest.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/model/CreateEntityRequest.scala (91%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/model/EntityResponse.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/model/EntityResponsePage.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/model/UpdateEntityNameRequest.scala (83%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/entity/http/model/UpdateEntityWalletIdRequest.scala (83%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/wallet/http/WalletManagementEndpoints.scala (85%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/wallet/http/WalletManagementServerEndpoints.scala (83%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/wallet/http/controller/WalletManagementController.scala (82%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/wallet/http/model/CreateWalletRequest.scala (94%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/wallet/http/model/CreateWalletUmaPermissionRequest.scala (90%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/iam/wallet/http/model/WalletDetail.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/issue/controller/IssueController.scala (91%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/issue/controller/IssueControllerImpl.scala (85%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/issue/controller/IssueEndpoints.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/issue/controller/IssueServerEndpoints.scala (80%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/issue/controller/http/AcceptCredentialOfferRequest.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/issue/controller/http/CreateIssueCredentialRecordRequest.scala (96%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/issue/controller/http/IssueCredentialRecord.scala (97%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/issue/controller/http/IssueCredentialRecordPage.scala (95%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/CredentialDefinitionRegistryEndpoints.scala (89%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/CredentialDefinitionRegistryServerEndpoints.scala (77%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/controller/CredentialDefinitionController.scala (82%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/controller/CredentialDefinitionControllerImpl.scala (76%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/controller/CredentialDefinitionControllerLogic.scala (72%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/http/CredentialDefinitionInput.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/http/CredentialDefinitionResponse.scala (96%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/http/CredentialDefinitionResponsePage.scala (94%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/http/FilterInput.scala (85%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialdefinition/http/Proof.scala (95%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/SchemaRegistryEndpoints.scala (92%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/SchemaRegistryServerEndpoints.scala (81%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/VerificationPolicyEndpoints.scala (89%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/VerificationPolicyServerEndpoints.scala (81%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/controller/CredentialSchemaController.scala (82%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/controller/CredentialSchemaControllerImpl.scala (79%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/controller/CredentialSchemaControllerLogic.scala (75%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/controller/VerificationPolicyController.scala (76%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/controller/VerificationPolicyControllerImpl.scala (84%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/controller/VerificationPolicyPageRequestLogic.scala (73%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/http/CredentialSchemaInput.scala (86%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/http/CredentialSchemaResponse.scala (96%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/http/CredentialSchemaResponsePage.scala (94%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/http/FilterInput.scala (85%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/http/Proof.scala (95%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/pollux/credentialschema/http/VerificationPolicyResponse.scala (97%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/PresentProofController.scala (87%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/PresentProofControllerImpl.scala (84%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/PresentProofEndpoints.scala (86%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/PresentProofServerEndpoints.scala (78%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/http/Options.scala (86%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/http/PresentationStatus.scala (93%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/http/PresentationStatusPage.scala (91%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/http/ProofRequestAux.scala (86%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/http/RequestPresentationAction.scala (90%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/presentproof/controller/http/RequestPresentationInput.scala (94%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/system/controller/SystemController.scala (50%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/system/controller/SystemControllerImpl.scala (70%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/system/controller/SystemEndpoints.scala (88%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/system/controller/SystemServerEndpoints.scala (80%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/system/controller/http/HealthInfo.scala (83%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/VcVerificationController.scala (64%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/VcVerificationControllerImpl.scala (79%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/VcVerificationEndpoints.scala (65%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/VcVerificationServerEndpoints.scala (70%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/http/ParameterizableVcVerification.scala (90%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/http/VcVerification.scala (92%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/http/VcVerificationParameter.scala (95%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/http/VcVerificationRequest.scala (91%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/http/VcVerificationResponse.scala (97%)
rename {prism-agent/service/server/src/main/scala/io/iohk/atala => cloud-agent/service/server/src/main/scala/org/hyperledger/identus}/verification/controller/http/VcVerificationResult.scala (80%)
rename {prism-agent => cloud-agent}/service/server/src/test/resources/anoncred-schema-example.json (100%)
rename {prism-agent => cloud-agent}/service/server/src/test/resources/logback.xml (100%)
rename {pollux/lib/core => cloud-agent/service/server}/src/test/resources/vc-schema-example.json (100%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/ZioHttpTest.scala (98%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/agent/server/AgentInitializationSpec.scala (81%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/agent/server/config/AppConfigSpec.scala (98%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/api/util/PaginationUtilsSpec.scala (94%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/api/util/Tapir2StaticOAS.scala (60%)
rename {pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container => cloud-agent/service/server/src/test/scala/org/hyperledger/identus/container/util}/MigrationAspect.scala (96%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/iam/authentication/SecurityLogicSpec.scala (94%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/iam/authentication/apikey/ApiKeyAuthenticatorSpec.scala (90%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/iam/authentication/apikey/JdbcAuthenticationRepositorySpec.scala (93%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/iam/authentication/oidc/KeycloakAuthenticatorSpec.scala (91%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/iam/authorization/core/EntityPermissionManagementSpec.scala (79%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/iam/authorization/keycloak/admin/KeycloakAdmin.scala (95%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/iam/authorization/keycloak/admin/KeycloakAdminSpec.scala (83%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/iam/authorization/keycloak/admin/KeycloakConfigUtils.scala (85%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/iam/authorization/keycloak/admin/KeycloakPermissionManagementServiceSpec.scala (88%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/issue/controller/IssueControllerImplSpec.scala (88%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/issue/controller/IssueControllerSpec.scala (94%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/issue/controller/IssueControllerTestTools.scala (77%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/credentialdefinition/CredentialDefinitionBasicSpec.scala (87%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/credentialdefinition/CredentialDefinitionFailureSpec.scala (76%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/credentialdefinition/CredentialDefinitionLookupAndPaginationSpec.scala (89%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/credentialdefinition/CredentialDefinitionTestTools.scala (84%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/schema/CredentialSchemaAnoncredSpec.scala (85%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/schema/CredentialSchemaBasicSpec.scala (85%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/schema/CredentialSchemaFailureSpec.scala (72%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/schema/CredentialSchemaLookupAndPaginationSpec.scala (89%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/schema/CredentialSchemaMultiTenancySpec.scala (89%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/pollux/schema/CredentialSchemaTestTools.scala (81%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/system/controller/SystemControllerImplSpec.scala (94%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/system/controller/SystemControllerTestTools.scala (86%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/verification/controller/VcVerificationControllerImplSpec.scala (90%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala => cloud-agent/service/server/src/test/scala/org/hyperledger/identus}/verification/controller/VcVerificationControllerTestTools.scala (71%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V10__create_peer_did_table.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V11__wallet_seed_digest.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V12__generic_secret.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V13__apikey_authentication_improvements.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V14__multiple_did_key_types.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V1__init_tables.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V2__did_nonsecret_storage.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V3__did_update_state.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V4__did_hd_key.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V5__remove_did_rand_key.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V6__add_schema_id_to_secret_table.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V7__mutitenant_wallet.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V8__init_entity_repository_tables.sql (100%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/main/resources/sql/agent/V9__init_authentication_repository_tables.sql (100%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/memory/GenericSecretStorageInMemory.scala (84%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/memory/WalletSecretStorageInMemory.scala (71%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/Entity.scala (93%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/KeyManagement.scala (93%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/ManagedDID.scala (84%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/ManagedDIDTemplate.scala (90%)
create mode 100644 cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/PeerDIDRecord.scala
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/Wallet.scala (87%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/error/CreateManagedDIDError.scala (63%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/error/DIDSecretStorageError.scala (69%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/error/EntityServiceError.scala (90%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/error/GetKeyError.scala (77%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/error/GetManagedDIDError.scala (63%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/error/PublishManagedDIDError.scala (67%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/error/UpdateManagedDIDError.scala (77%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/model/error/package.scala (89%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/EntityService.scala (72%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/EntityServiceImpl.scala (86%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/ManagedDIDService.scala (77%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/ManagedDIDServiceImpl.scala (93%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/ManagedDIDServiceWithEventNotificationImpl.scala (73%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/MockManagedDIDService.scala (85%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/WalletManagementService.scala (84%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/WalletManagementServiceImpl.scala (84%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/handler/DIDCreateHandler.scala (68%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/handler/DIDUpdateHandler.scala (72%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/service/handler/PublicationHandler.scala (61%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/sql/EntityRepository.scala (94%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala (96%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/sql/JdbcDIDSecretStorage.scala (85%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/sql/JdbcEntityRepository.scala (93%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/sql/JdbcGenericSecretStorage.scala (80%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/sql/JdbcWalletNonSecretStorage.scala (88%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/sql/JdbcWalletSecretStorage.scala (77%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/sql/package.scala (92%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/storage/DIDNonSecretStorage.scala (84%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/storage/DIDSecretStorage.scala (65%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/storage/GenericSecretStorage.scala (77%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/storage/WalletNonSecretStorage.scala (86%)
create mode 100644 cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/WalletSecretStorage.scala
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/util/KeyResolver.scala (60%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/util/ManagedDIDTemplateValidator.scala (81%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/util/OperationFactory.scala (95%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/util/UpdateManagedDIDActionValidator.scala (82%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/vault/VaultClient.scala (99%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/vault/VaultDIDSecretStorage.scala (87%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/vault/VaultGenericSecretStorage.scala (86%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/vault/VaultWalletSecretStorage.scala (77%)
rename {prism-agent/service/wallet-api/src/main/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus}/agent/walletapi/vault/package.scala (89%)
rename {prism-agent => cloud-agent}/service/wallet-api/src/test/resources/logback.xml (100%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/benchmark/KeyDerivation.scala (89%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/service/ManagedDIDServiceSpec.scala (96%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/service/WalletManagementServiceSpec.scala (87%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/storage/DIDSecretStorageSpec.scala (89%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/storage/GenericSecretStorageSpec.scala (87%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/storage/JdbcEntityRepositorySpec.scala (93%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/storage/JdbcWalletNonSecretStorageSpec.scala (90%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/storage/StorageSpecHelper.scala (65%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/storage/WalletSecretStorageSpec.scala (79%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala (72%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/agent/walletapi/util/OperationFactorySpec.scala (95%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/test/container/DBTestUtils.scala (95%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/test/container/VaultLayer.scala (76%)
rename {prism-agent/service/wallet-api/src/test/scala/io/iohk/atala => cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus}/test/container/VaultTestContainerSupport.scala (71%)
rename connect/{lib => }/CHANGELOG.md (100%)
rename connect/{lib => }/README.md (100%)
rename connect/{lib => }/connect-protocol-state.md (100%)
rename connect/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/connect/core/model/ConnectionRecord.scala (91%)
rename connect/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/connect/core/model/error/ConnectionServiceError.scala (90%)
rename connect/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/connect/core/repository/ConnectionRepository.scala (82%)
rename connect/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/connect/core/repository/ConnectionRepositoryInMemory.scala (93%)
rename connect/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/connect/core/service/ConnectionService.scala (83%)
rename connect/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/connect/core/service/ConnectionServiceImpl.scala (92%)
rename connect/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/connect/core/service/ConnectionServiceNotifier.scala (88%)
rename connect/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/connect/core/service/MockConnectionService.scala (91%)
rename connect/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/connect/core/repository/ConnectionRepositoryInMemorySpec.scala (88%)
rename connect/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/connect/core/repository/ConnectionRepositorySpecSuite.scala (96%)
rename connect/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/connect/core/service/ConnectionServiceImplSpec.scala (95%)
rename connect/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/connect/core/service/ConnectionServiceNotifierSpec.scala (90%)
rename connect/{lib => }/sql-doobie/src/main/resources/sql/connect/V1__init_tables.sql (100%)
rename connect/{lib => }/sql-doobie/src/main/resources/sql/connect/V2__add_thid_unique_constraint.sql (100%)
rename connect/{lib => }/sql-doobie/src/main/resources/sql/connect/V3__add_meta_retries_and_meta_last_failure.sql (100%)
rename connect/{lib => }/sql-doobie/src/main/resources/sql/connect/V4__create_protocol_state_index.sql (100%)
rename connect/{lib => }/sql-doobie/src/main/resources/sql/connect/V5__add_meta_next_retry.sql (100%)
rename connect/{lib => }/sql-doobie/src/main/resources/sql/connect/V6__add_rls_policy.sql (100%)
rename connect/{lib => }/sql-doobie/src/main/resources/sql/connect/V7__add_goal_and_goal_code.sql (100%)
rename connect/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/connect/sql/repository/JdbcConnectionRepository.scala (94%)
rename connect/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/connect/sql/repository/Migrations.scala (89%)
rename connect/{lib => }/sql-doobie/src/test/resources/logback.xml (100%)
rename connect/{lib/sql-doobie/src/test/scala/io/iohk/atala => sql-doobie/src/test/scala/org/hyperledger/identus}/connect/sql/repository/JdbcConnectionRepositorySpec.scala (77%)
rename connect/{lib/sql-doobie/src/test/scala/io/iohk/atala => sql-doobie/src/test/scala/org/hyperledger/identus}/test/container/PostgresTestContainer.scala (78%)
rename event-notification/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/event/notification/Event.scala (73%)
rename event-notification/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/event/notification/EventConsumer.scala (68%)
rename event-notification/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/event/notification/EventNotificationConfig.scala (87%)
rename event-notification/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/event/notification/EventNotificationService.scala (81%)
rename event-notification/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/event/notification/EventNotificationServiceError.scala (76%)
rename event-notification/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/event/notification/EventNotificationServiceImpl.scala (92%)
rename event-notification/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/event/notification/EventProducer.scala (68%)
rename event-notification/src/test/scala/{io/iohk/atala => org/hyperledger/identus}/event/notification/EventNotificationServiceImplSpec.scala (97%)
create mode 100644 infrastructure/ci/docker-compose-multiple-actors.yml
rename mercury/{mercury-library => }/CHANGELOG.md (100%)
rename mercury/{mercury-library => }/QuickStart.md (100%)
rename mercury/{mercury-library => }/UseCases.md (100%)
rename mercury/{mercury-library/agent-didcommx/src/main/scala/io/iohk/atala => agent-didcommx/src/main/scala/org/hyperledger/identus}/mercury/AgentPeerService.scala (96%)
rename mercury/{mercury-library/agent-didcommx/src/main/scala/io/iohk/atala => agent-didcommx/src/main/scala/org/hyperledger/identus}/mercury/DidCommX.scala (93%)
rename mercury/{mercury-library/agent-didcommx/src/main/scala/io/iohk/atala => agent-didcommx/src/main/scala/org/hyperledger/identus}/mercury/MessagingService.scala (94%)
rename mercury/{mercury-library/agent-didcommx/src/main/scala/io/iohk/atala => agent-didcommx/src/main/scala/org/hyperledger/identus}/mercury/PeerDID.scala (97%)
rename mercury/{mercury-library/agent-didcommx/src/main/scala/io/iohk/atala => agent-didcommx/src/main/scala/org/hyperledger/identus}/mercury/model/Conversions.scala (98%)
rename mercury/{mercury-library/agent-didcommx/src/main/scala/io/iohk/atala => agent-didcommx/src/main/scala/org/hyperledger/identus}/mercury/model/JsonUtilsForDidCommx.scala (98%)
rename mercury/{mercury-library/agent-didcommx/src/main/scala/io/iohk/atala => agent-didcommx/src/main/scala/org/hyperledger/identus}/mercury/model/package.scala (97%)
rename mercury/{mercury-library/agent-didcommx/src/main/scala/io/iohk/atala => agent-didcommx/src/main/scala/org/hyperledger/identus/mercury}/resolvers/AliceSecretResolver.scala (96%)
rename mercury/{mercury-library/agent-didcommx/src/main/scala/io/iohk/atala => agent-didcommx/src/main/scala/org/hyperledger/identus/mercury}/resolvers/BobSecretResolver.scala (96%)
rename mercury/{mercury-library/agent-didcommx/src/test/scala/io/iohk/atala => agent-didcommx/src/test/scala/org/hyperledger/identus}/mercury/PeerDIDSpec.scala (78%)
rename mercury/{mercury-library/agent-didcommx/src/test/scala/io/iohk/atala => agent-didcommx/src/test/scala/org/hyperledger/identus}/mercury/model/UnpackMessageImpSpec.scala (94%)
rename mercury/{mercury-library/agent/src/main/scala/io/iohk/atala => agent/src/main/scala/org/hyperledger/identus}/mercury/Agent.scala (96%)
rename mercury/{mercury-library/agent/src/main/scala/io/iohk/atala => agent/src/main/scala/org/hyperledger/identus}/mercury/CoordinateMediationPrograms.scala (89%)
rename mercury/{mercury-library/agent/src/main/scala/io/iohk/atala => agent/src/main/scala/org/hyperledger/identus}/mercury/HttpClient.scala (94%)
rename mercury/{mercury-library/agent/src/main/scala/io/iohk/atala => agent/src/main/scala/org/hyperledger/identus}/mercury/InvitationPrograms.scala (80%)
rename mercury/{mercury-library/agent/src/main/scala/io/iohk/atala => agent/src/main/scala/org/hyperledger/identus}/mercury/OutOfBandLoginPrograms.scala (79%)
delete mode 100644 mercury/mercury-library/README.md
delete mode 100644 mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/Main.scala
delete mode 100644 mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/CharlieSecretResolver.scala
delete mode 100644 mercury/mercury-library/agent/src/main/scala/io/iohk/atala/AgentPrograms.scala
delete mode 100644 mercury/mercury-library/protocol-did-exchange/src/main/scala/io/iohk/atala/mercury/protocol/didexchange/v1/DIDExchange.scala
delete mode 100644 mercury/mercury-library/protocol-mercury-mailbox/Mercury-Mailbox-Protocol.md
delete mode 100644 mercury/mercury-library/protocol-mercury-mailbox/src/main/scala/io/iohk/atala/mercury/protocol/mailbox/Mailbox.scala
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/DidAgent.scala (71%)
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/DidOps.scala (95%)
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/MediaTypes.scala (83%)
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/model/AttachmentDescriptor.scala (99%)
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/model/DidId.scala (86%)
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/model/EncryptedMessage.scala (91%)
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/model/Message.scala (95%)
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/model/SignedMesage.scala (76%)
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/model/UnpackResult.scala (51%)
rename mercury/{mercury-library/models/src/main/scala/io/iohk/atala => models/src/main/scala/org/hyperledger/identus}/mercury/model/error/package.scala (96%)
rename mercury/{mercury-library => }/protocol-connection/Connection-Protocol.md (100%)
rename mercury/{mercury-library/protocol-connection/src/main/scala/io/iohk/atala => protocol-connection/src/main/scala/org/hyperledger/identus}/mercury/protocol/connection/ConnectionInvitation.scala (65%)
rename mercury/{mercury-library/protocol-connection/src/main/scala/io/iohk/atala => protocol-connection/src/main/scala/org/hyperledger/identus}/mercury/protocol/connection/ConnectionRequest.scala (91%)
rename mercury/{mercury-library/protocol-connection/src/main/scala/io/iohk/atala => protocol-connection/src/main/scala/org/hyperledger/identus}/mercury/protocol/connection/ConnectionResponse.scala (95%)
rename mercury/{mercury-library/protocol-connection/src/test/scala/io/iohk/atala => protocol-connection/src/test/scala/org/hyperledger/identus}/mercury/protocol/connection/ConnectionSpec.scala (94%)
rename mercury/{mercury-library => }/protocol-coordinate-mediation/Coordinate-Mediation-Protocol.md (100%)
rename mercury/{mercury-library/protocol-coordinate-mediation/src/main/scala/io/iohk/atala => protocol-coordinate-mediation/src/main/scala/org/hyperledger/identus}/mercury/protocol/coordinatemediation/CoordinateMediation.scala (97%)
rename mercury/{mercury-library/protocol-coordinate-mediation/src/test/scala/io/iohk/atala => protocol-coordinate-mediation/src/test/scala/org/hyperledger/identus}/mercury/protocol/coordinatemediation/CoordinateMediationSpec.scala (94%)
rename mercury/{mercury-library => }/protocol-did-exchange/DidExchange-Protocol.md (100%)
rename mercury/{mercury-library/protocol-did-exchange/src/main/scala/io/iohk/atala => protocol-did-exchange/src/main/scala/org/hyperledger/identus}/mercury/protocol/didexchange/v1/DidExchangeRequest.scala (65%)
rename mercury/{mercury-library => }/protocol-invitation/Invitation-Protocol.md (100%)
rename mercury/{mercury-library/protocol-invitation/src/main/scala/io/iohk/atala => protocol-invitation/src/main/scala/org/hyperledger/identus}/mercury/protocol/invitation/OutOfBand.scala (84%)
rename mercury/{mercury-library/protocol-invitation/src/main/scala/io/iohk/atala => protocol-invitation/src/main/scala/org/hyperledger/identus}/mercury/protocol/invitation/ServiceType.scala (95%)
rename mercury/{mercury-library/protocol-invitation/src/main/scala/io/iohk/atala => protocol-invitation/src/main/scala/org/hyperledger/identus}/mercury/protocol/invitation/package.scala (74%)
rename mercury/{mercury-library/protocol-invitation/src/main/scala/io/iohk/atala => protocol-invitation/src/main/scala/org/hyperledger/identus}/mercury/protocol/invitation/v1/Invitation.scala (75%)
rename mercury/{mercury-library/protocol-invitation/src/main/scala/io/iohk/atala => protocol-invitation/src/main/scala/org/hyperledger/identus}/mercury/protocol/invitation/v2/Invitation.scala (81%)
rename mercury/{mercury-library/protocol-invitation/src/test/scala/io/iohk/atala => protocol-invitation/src/test/scala/org/hyperledger/identus}/mercury/protocol/invitation/v1/InvitationV1Spec.scala (92%)
rename mercury/{mercury-library/protocol-invitation/src/test/scala/io/iohk/atala => protocol-invitation/src/test/scala/org/hyperledger/identus}/mercury/protocol/invitation/v2/OutOfBandSpec.scala (80%)
rename mercury/{mercury-library => }/protocol-issue-credential/Issue-Credential-Protocol.md (100%)
rename mercury/{mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala => protocol-issue-credential/src/main/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/Credential.scala (92%)
rename mercury/{mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala => protocol-issue-credential/src/main/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/CredentialPreview.scala (97%)
rename mercury/{mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala => protocol-issue-credential/src/main/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/IssueCredential.scala (95%)
rename mercury/{mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala => protocol-issue-credential/src/main/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/IssueFormats.scala (99%)
rename mercury/{mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala => protocol-issue-credential/src/main/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/OfferCredential.scala (94%)
rename mercury/{mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala => protocol-issue-credential/src/main/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/ProposeCredential.scala (93%)
rename mercury/{mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala => protocol-issue-credential/src/main/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/RequestCredential.scala (93%)
rename mercury/{mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala => protocol-issue-credential/src/main/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/Utils.scala (88%)
rename mercury/{mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala => protocol-issue-credential/src/test/scala/org/hyperledger/identus}/mercury/protocol/anotherclasspath/UtilsCredentialSpec.scala (88%)
rename mercury/{mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala => protocol-issue-credential/src/test/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/IssueCredentialSpec.scala (89%)
rename mercury/{mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala => protocol-issue-credential/src/test/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/OfferCredentialSpec.scala (89%)
rename mercury/{mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala => protocol-issue-credential/src/test/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/ProposeCredentialSpec.scala (87%)
rename mercury/{mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala => protocol-issue-credential/src/test/scala/org/hyperledger/identus}/mercury/protocol/issuecredential/RequestCredentialSpec.scala (86%)
rename mercury/{mercury-library => }/protocol-outofband-login/OutOfBand-Login-Protocol.md (100%)
rename mercury/{mercury-library/protocol-outofband-login/src/main/scala/io/iohk/atala => protocol-outofband-login/src/main/scala/org/hyperledger/identus}/mercury/protocol/outofbandlogin/OutOfBandLogin.scala (85%)
rename mercury/{mercury-library/protocol-outofband-login/src/main/scala/io/iohk/atala => protocol-outofband-login/src/main/scala/org/hyperledger/identus}/mercury/protocol/outofbandlogin/Utils.scala (86%)
rename mercury/{mercury-library => }/protocol-present-proof/Present-Proof-Protocol.md (100%)
rename mercury/{mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala => protocol-present-proof/src/main/scala/org/hyperledger/identus}/mercury/protocol/presentproof/PresentFormats.scala (98%)
rename mercury/{mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala => protocol-present-proof/src/main/scala/org/hyperledger/identus}/mercury/protocol/presentproof/Presentation.scala (95%)
rename mercury/{mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala => protocol-present-proof/src/main/scala/org/hyperledger/identus}/mercury/protocol/presentproof/ProofType.scala (77%)
rename mercury/{mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala => protocol-present-proof/src/main/scala/org/hyperledger/identus}/mercury/protocol/presentproof/ProposePresentation.scala (94%)
rename mercury/{mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala => protocol-present-proof/src/main/scala/org/hyperledger/identus}/mercury/protocol/presentproof/RequestPresentation.scala (95%)
rename mercury/{mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala => protocol-present-proof/src/test/scala/org/hyperledger/identus}/mercury/protocol/presentproof/PresentationSpec.scala (79%)
rename mercury/{mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala => protocol-present-proof/src/test/scala/org/hyperledger/identus}/mercury/protocol/presentproof/ProposePresentationProofSpec.scala (82%)
rename mercury/{mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala => protocol-present-proof/src/test/scala/org/hyperledger/identus}/mercury/protocol/presentproof/RequestPresentationSpec.scala (83%)
rename mercury/{mercury-library => }/protocol-report-problem/Report-Problem-Protocol.md (100%)
rename mercury/{mercury-library/protocol-report-problem/src/main/scala/io/iohk/atala => protocol-report-problem/src/main/scala/org/hyperledger/identus}/mercury/protocol/reportproblem/v1/ReportProblem.scala (94%)
rename mercury/{mercury-library/protocol-report-problem/src/main/scala/io/iohk/atala => protocol-report-problem/src/main/scala/org/hyperledger/identus}/mercury/protocol/reportproblem/v2/ReportProblem.scala (98%)
rename mercury/{mercury-library/protocol-report-problem/src/test/scala/io/iohk => protocol-report-problem/src/test/scala/org/hyperledger/identus}/mercury/protocol/reportproblem/v2/ReportProblemSpec.scala (93%)
rename mercury/{mercury-library => }/protocol-revocation-notification/Revocation-notification-protocol.md (100%)
rename mercury/{mercury-library/protocol-revocation-notification/src/main/scala/io/iohk/atala => protocol-revocation-notification/src/main/scala/org/hyperledger/identus}/mercury/protocol/revocationnotificaiton/RevocationNotification.scala (93%)
rename mercury/{mercury-library => }/protocol-routing/Routing-Protocol.md (100%)
rename mercury/{mercury-library/protocol-routing/src/main/scala/io/iohk/atala => protocol-routing/src/main/scala/org/hyperledger/identus}/mercury/protocol/routing/ForwardMessage.scala (95%)
rename mercury/{mercury-library/protocol-trust-ping/src/main/scala/io/iohk/atala => protocol-trust-ping/src/main/scala/org/hyperledger/identus}/mercury/protocol/trustping/TrustPing.scala (94%)
rename mercury/{mercury-library/protocol-trust-ping/src/main/scala/io/iohk/atala => protocol-trust-ping/src/main/scala/org/hyperledger/identus}/mercury/protocol/trustping/TrustPingResponse.scala (92%)
rename mercury/{mercury-library/resolver/src/main/scala/io/iohk/atala => resolver/src/main/scala/org/hyperledger/identus}/resolvers/DidValidator.scala (94%)
rename mercury/{mercury-library/resolver/src/main/scala/io/iohk/atala => resolver/src/main/scala/org/hyperledger/identus}/resolvers/PeerDidResolver.scala (99%)
rename mercury/{mercury-library/resolver/src/main/scala/io/iohk/atala => resolver/src/main/scala/org/hyperledger/identus}/resolvers/UniversalDidResolver.scala (91%)
rename mercury/{mercury-library/resolver/src/test/scala/io/iohk/atala => resolver/src/test/scala/org/hyperledger/identus}/resolvers/AliceDidDoc.scala (97%)
rename mercury/{mercury-library/resolver/src/test/scala/io/iohk/atala => resolver/src/test/scala/org/hyperledger/identus}/resolvers/BobDidDoc.scala (96%)
rename mercury/{mercury-library/resolver/src/test/scala/io/iohk/atala => resolver/src/test/scala/org/hyperledger/identus}/resolvers/DidValidatorSpec.scala (90%)
rename mercury/{mercury-library/resolver/src/test/scala/io/iohk/atala => resolver/src/test/scala/org/hyperledger/identus}/resolvers/MediatorDidDoc.scala (97%)
rename mercury/{mercury-library/resolver/src/test/scala/io/iohk/atala => resolver/src/test/scala/org/hyperledger/identus}/resolvers/PeerDidResolverSpec.scala (99%)
delete mode 100644 mercury/roots-id-mediator/Dockerfile
delete mode 100644 mercury/roots-id-mediator/REAMDE-ROOTS-ID-mediator.md
delete mode 100644 mercury/roots-id-mediator/docker-compose.yaml
delete mode 100644 mercury/roots-id-mediator/notebooks/.gitignore
delete mode 100644 mercury/roots-id-mediator/notebooks/Alice.ipynb
delete mode 100644 mercury/roots-id-mediator/notebooks/Bob.ipynb
delete mode 100644 mercury/roots-id-mediator/notebooks/test_mediator.ipynb
rename mercury/{mercury-library => }/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFilterFormat.scala (78%)
rename mercury/{mercury-library => }/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFormat.scala (81%)
rename mercury/{mercury-library => }/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialOfferFormat.scala (85%)
rename mercury/{mercury-library => }/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialRequestFormat.scala (77%)
rename mercury/{mercury-library => }/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofFormat.scala (80%)
rename mercury/{mercury-library => }/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofRequestFormat.scala (88%)
rename mercury/{mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/jwt => vc/src/main/scala/io/iohk/atala/mercury/vc/dif}/ProposeCredential.scala (98%)
rename mercury/{mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/dif => vc/src/main/scala/io/iohk/atala/mercury/vc/jwt}/ProposeCredential.scala (98%)
rename pollux/{lib => }/CHANGELOG.md (100%)
rename pollux/{lib => }/README.md (100%)
rename pollux/{lib => }/anoncreds/README_anoncreds.md (100%)
rename pollux/{lib => }/anoncreds/anoncreds-jvm-1.0-SNAPSHOT.jar (100%)
rename pollux/{lib => }/anoncreds/native-lib/NATIVE/darwin-aarch64/libuniffi_anoncreds_wrapper.dylib (100%)
rename pollux/{lib => }/anoncreds/native-lib/NATIVE/darwin-x86-64/libuniffi_anoncreds_wrapper.dylib (100%)
rename pollux/{lib => }/anoncreds/native-lib/NATIVE/linux-aarch64/libuniffi_anoncreds_wrapper.so (100%)
rename pollux/{lib => }/anoncreds/native-lib/NATIVE/linux-x86-64/libuniffi_anoncreds_wrapper.so (100%)
rename pollux/{lib => }/anoncreds/native-lib/helper_script_to_update.sh (100%)
rename pollux/{lib/anoncreds/src/main/scala/io/iohk/atala => anoncreds/src/main/scala/org/hyperledger/identus}/pollux/anoncreds/AnoncredLib.scala (99%)
rename pollux/{lib/anoncreds/src/main/scala/io/iohk/atala => anoncreds/src/main/scala/org/hyperledger/identus}/pollux/anoncreds/Models.scala (99%)
rename pollux/{lib => }/anoncredsTest/src/test/scala/Uniffy.scala (100%)
rename pollux/{lib/anoncredsTest/src/test/scala/io/iohk/atala => anoncredsTest/src/test/scala/org/hyperledger/identus}/pollux/anoncreds/PoCNewLib.scala (94%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/CredentialFormat.scala (86%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/CredentialOfferAttachment.scala (68%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/CredentialStatusList.scala (83%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/DidCommID.scala (83%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/IssueCredentialRecord.scala (93%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/PresentationRecord.scala (94%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/VerificationPolicy.scala (95%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/error/CredentialRepositoryError.scala (94%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/error/CredentialSchemaError.scala (80%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/error/CredentialServiceError.scala (92%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/error/CredentialStatusListServiceError.scala (89%)
create mode 100644 pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/LinkSecretError.scala
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/error/PresentationError.scala (93%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/error/VerificationPolicyError.scala (85%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/presentation/PresentationAttachment.scala (97%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/CredentialDefinition.scala (95%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/CredentialSchema.scala (92%)
create mode 100644 pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/AnoncredSchemaType.scala
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/type/CredentialJsonSchemaSerDesV1.scala (98%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/type/CredentialJsonSchemaType.scala (61%)
create mode 100644 pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialSchemaType.scala
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/type/anoncred/AnoncredSchemaSerDesV1.scala (89%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/validator/JsonSchemaError.scala (86%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/validator/JsonSchemaUtils.scala (92%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/validator/JsonSchemaValidator.scala (79%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/validator/JsonSchemaValidatorImpl.scala (78%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/schema/validator/SchemaSerDes.scala (91%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/model/secret/CredentialDefinitionSecret.scala (80%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/CredentialDefinitionRepository.scala (71%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/CredentialDefinitionRepositoryInMemory.scala (92%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/CredentialRepository.scala (85%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/CredentialRepositoryInMemory.scala (95%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/CredentialSchemaRepository.scala (65%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/CredentialStatusListRepository.scala (81%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/CredentialStatusListRepositoryInMemory.scala (94%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/PresentationRepository.scala (87%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/PresentationRepositoryInMemory.scala (95%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/VerificationPolicyRepository.scala (82%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/repository/repository.scala (77%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/CredentialDefinitionService.scala (83%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/CredentialDefinitionServiceImpl.scala (77%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/CredentialSchemaService.scala (83%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/CredentialSchemaServiceImpl.scala (86%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/CredentialService.scala (90%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/CredentialServiceImpl.scala (96%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/CredentialServiceNotifier.scala (92%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/CredentialStatusListService.scala (67%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/CredentialStatusListServiceImpl.scala (78%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/HttpURIDereferencerImpl.scala (88%)
create mode 100644 pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/LinkSecretService.scala
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/LinkSecretServiceImpl.scala (80%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/MockCredentialService.scala (93%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/MockPresentationService.scala (91%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/PresentationService.scala (87%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/PresentationServiceImpl.scala (96%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/PresentationServiceNotifier.scala (90%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/ResourceURIDereferencerImpl.scala (88%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/URIDereferencer.scala (90%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/VerificationPolicyService.scala (77%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/VerificationPolicyServiceImpl.scala (85%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/serdes/AnoncredCredentialProofsV1.scala (93%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/serdes/AnoncredPresentationRequestV1.scala (96%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/serdes/AnoncredPresentationV1.scala (99%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/serdes/PrivateCredentialDefinitionSchemaSerDesV1.scala (95%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/serdes/ProofKeyCredentialDefinitionSchemaSerDesV1.scala (90%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesV1.scala (97%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/verification/VcVerification.scala (92%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/verification/VcVerificationService.scala (85%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/verification/VcVerificationServiceError.scala (74%)
rename pollux/{lib/core/src/main/scala/io/iohk/atala => core/src/main/scala/org/hyperledger/identus}/pollux/core/service/verification/VcVerificationServiceImpl.scala (96%)
rename pollux/{lib => }/core/src/test/resources/anoncred-presentation-schema-example.json (100%)
rename pollux/{lib => }/core/src/test/resources/anoncred-schema-example.json (100%)
rename pollux/{lib => }/core/src/test/resources/logback.xml (100%)
rename {prism-agent/service/server => pollux/core}/src/test/resources/vc-schema-example.json (100%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/model/presentation/PresentationAttachmentSpec.scala (98%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/model/schema/AnoncredSchemaTypeSpec.scala (95%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/model/schema/CredentialSchemaSpec.scala (94%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/repository/CredentialRepositoryInMemorySpec.scala (70%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/repository/CredentialRepositorySpecSuite.scala (97%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/repository/PresentationRepositoryInMemorySpec.scala (87%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/repository/PresentationRepositorySpecSuite.scala (97%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/CredentialDefinitionServiceImplSpec.scala (96%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/CredentialDefinitionServiceSpecHelper.scala (74%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/CredentialServiceImplSpec.scala (96%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/CredentialServiceNotifierSpec.scala (92%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/CredentialServiceSpecHelper.scala (86%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/LinkSecretServiceImplSpec.scala (74%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/PresentationServiceNotifierSpec.scala (92%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/PresentationServiceSpec.scala (96%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/PresentationServiceSpecHelper.scala (86%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/serdes/AnoncredPresentationRequestSpec.scala (97%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/serdes/AnoncredPresentationSpec.scala (97%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesSpec.scala (98%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/verification/VcVerificationServiceImplSpec.scala (98%)
rename pollux/{lib/core/src/test/scala/io/iohk/atala => core/src/test/scala/org/hyperledger/identus}/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala (72%)
rename pollux/{lib => }/issue-protocol-state.md (100%)
delete mode 100644 pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/LinkSecretError.scala
delete mode 100644 pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/AnoncredSchemaType.scala
delete mode 100644 pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialSchemaType.scala
delete mode 100644 pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/LinkSecretService.scala
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V10__presentation_records_add_thid_unique_constraint.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V11__issue_credential_extend_schema_id.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V12__verification_policies_reset_nonce.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V13__credential_schema_tables.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V14__add_rls_policy.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V15__add_anoncreds_columns.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V16__revocation_status_lists_table_and_columns.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V17__add_anoncred_credentials_to_use_columns.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V18__issue_credential_rename_schema_id.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V19__update_revocation_status_list_table_and_columns.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V1__init_tables.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V3__schema_registry_tables.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V5__create_protocol_state_index.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V6__verification_policy_tables.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V8__credential_schema_tables.sql (100%)
rename pollux/{lib => }/sql-doobie/src/main/resources/sql/pollux/V9__issue_credential_drop_subjectId_not_null.sql (100%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/model/JWTCredentialRow.scala (70%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/model/db/CredentialDefinition.scala (92%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/model/db/CredentialSchema.scala (91%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/model/db/VerificationPolicy.scala (95%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/model/db/package.scala (68%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/repository/Implicits.scala (76%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/repository/JdbcCredentialDefinitionRepository.scala (83%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/repository/JdbcCredentialRepository.scala (95%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/repository/JdbcCredentialSchemaRepository.scala (83%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/repository/JdbcCredentialStatusListRepository.scala (92%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/repository/JdbcPresentationRepository.scala (96%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/repository/JdbcVerificationPolicyRepository.scala (89%)
rename pollux/{lib/sql-doobie/src/main/scala/io/iohk/atala => sql-doobie/src/main/scala/org/hyperledger/identus}/pollux/sql/repository/Migrations.scala (89%)
rename pollux/{lib => }/sql-doobie/src/test/resources/data/verifiableCredentialClaims.csv (100%)
rename pollux/{lib => }/sql-doobie/src/test/resources/data/verifiableCredentialTypes.csv (100%)
rename pollux/{lib/sql-doobie/src/test/scala/io/iohk/atala => sql-doobie/src/test/scala/org/hyperledger/identus}/pollux/sql/CredentialDefinitionSqlIntegrationSpec.scala (94%)
rename pollux/{lib/sql-doobie/src/test/scala/io/iohk/atala => sql-doobie/src/test/scala/org/hyperledger/identus}/pollux/sql/CredentialSchemaSqlIntegrationSpec.scala (94%)
rename pollux/{lib/sql-doobie/src/test/scala/io/iohk/atala => sql-doobie/src/test/scala/org/hyperledger/identus}/pollux/sql/VerificationPolicySqlIntegrationSpec.scala (93%)
rename pollux/{lib/sql-doobie/src/test/scala/io/iohk/atala => sql-doobie/src/test/scala/org/hyperledger/identus}/pollux/sql/repository/JdbcCredentialRepositorySpec.scala (79%)
rename pollux/{lib/sql-doobie/src/test/scala/io/iohk/atala => sql-doobie/src/test/scala/org/hyperledger/identus}/pollux/sql/repository/JdbcPresentationRepositorySpec.scala (79%)
rename {prism-agent/service/server/src/test/scala/io/iohk/atala/container/util => pollux/sql-doobie/src/test/scala/org/hyperledger/identus/test/container}/MigrationAspect.scala (96%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidJWT.scala (98%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidResolver.scala (97%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/InstantDecoderEncoder.scala (89%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala (98%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiBaseString.scala (94%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiKey.scala (95%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Proof.scala (97%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/ValidationUtils.scala (88%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Verifiable.scala (94%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala (99%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiablePresentationPayload.scala (98%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/CredentialDemo.scala (95%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialDIDDocumentValidationDemo.scala (97%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialEncodingDemo.scala (95%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialTemporalVerificationDemo.scala (97%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationCredentialDemo.scala (95%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationTemporalVerificationDemo.scala (97%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationVerificationDemo.scala (97%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/SchemaDemo.scala (97%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitString.scala (95%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021.scala (94%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/PlaceholderSchemaValidator.scala (88%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/ReactiveCoreSchemaValidator.scala (93%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaResolver.scala (53%)
rename pollux/{lib => }/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaValidator.scala (73%)
rename pollux/{lib => }/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ECDSAVerifierTest.scala (94%)
rename pollux/{lib => }/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ES256KSignerTest.scala (94%)
rename pollux/{lib => }/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/JWTVerificationTest.scala (98%)
rename pollux/{lib => }/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitStringSpec.scala (95%)
rename pollux/{lib => }/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021Spec.scala (95%)
delete mode 100755 prism-agent/client/generator/generate-clients.sh
delete mode 100755 prism-agent/client/generator/publish-clients.sh
delete mode 100644 prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/PeerDIDRecord.scala
delete mode 100644 prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/WalletSecretStorage.scala
delete mode 100644 prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcDIDNonSecretStorageSpec.scala
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/db/ContextAwareTask.scala (90%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/db/DbConfig.scala (74%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/db/TransactorLayer.scala (98%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/http/GenericUriResolver.scala (97%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/models/Base64UrlString.scala (83%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/models/Failure.scala (86%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/models/HexString.scala (80%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/models/MultiTenancy.scala (96%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/utils/Base64Utils.scala (92%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/utils/BytesOps.scala (94%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/utils/DurationOps.scala (75%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/utils/Json.scala (91%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/utils/Traverse.scala (91%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/utils/aspects/CustomMetricsAspect.scala (92%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/utils/proto/Path.scala (86%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/utils/proto/ValidationError.scala (94%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/utils/proto/package.scala (95%)
rename shared/core/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/validation/ValidationUtils.scala (90%)
rename shared/crypto/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/crypto/Apollo.scala (97%)
rename shared/crypto/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/crypto/KmpApollo.scala (99%)
rename shared/crypto/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/crypto/Prism14Apollo.scala (98%)
rename shared/crypto/src/main/scala/{io/iohk/atala => org/hyperledger/identus}/shared/crypto/jwk/JWK.scala (95%)
rename shared/crypto/src/test/scala/{io/iohk/atala => org/hyperledger/identus}/shared/crypto/ApolloSpec.scala (99%)
rename shared/crypto/src/test/scala/{io/iohk/atala => org/hyperledger/identus}/shared/crypto/ApolloSpecHelper.scala (60%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/.babelrc (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/.env (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/.gitignore (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/.npmrc (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/.yarnrc (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/README.md (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/package.json (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/run.sh (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/actors/Actor.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/actors/Holder.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/actors/Issuer.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/actors/Verifier.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/actors/index.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/common/Config.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/common/ConnectionService.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/common/CredentialsService.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/common/DidService.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/common/HttpService.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/common/ProofsService.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/k6chaijs.js (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/scenarios/default.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/tests/common.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/tests/credentials/credential-definition-test.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/tests/credentials/credential-offer-test.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/tests/credentials/credential-schema-test.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/tests/dids/create-prism-did-test.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/tests/dids/did-publishing-test.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/tests/flows/connection-flow-test.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/tests/flows/issuance-flow-test.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/src/tests/flows/present-proof-flow-test.ts (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/tsconfig.json (100%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/webpack.config.js (96%)
rename tests/performance-tests/{atala-performance-tests-k6 => agent-performance-tests-k6}/yarn.lock (100%)
rename tests/performance-tests/{prism-performance-tests => agent-performance-tests}/.gitignore (100%)
rename tests/performance-tests/{prism-performance-tests => agent-performance-tests}/README.md (100%)
rename tests/performance-tests/{prism-performance-tests/src/gatling/kotlin => agent-performance-tests/bin/gatling}/common/Configuration.kt (100%)
rename tests/performance-tests/{prism-performance-tests/src/gatling/kotlin => agent-performance-tests/bin/gatling}/common/Utils.kt (100%)
rename tests/performance-tests/{prism-performance-tests/src/gatling/resources => agent-performance-tests/bin/gatling}/gatling.conf (100%)
rename tests/performance-tests/{prism-performance-tests/src/gatling/kotlin => agent-performance-tests/bin/gatling}/simulations/ConnectionSimulation.kt (100%)
rename tests/performance-tests/{prism-performance-tests/src/gatling/kotlin => agent-performance-tests/bin/gatling}/simulations/IssuanceSimulation.kt (100%)
rename tests/performance-tests/{prism-performance-tests/src/gatling/kotlin => agent-performance-tests/bin/gatling}/steps/ConnectionSteps.kt (100%)
rename tests/performance-tests/{prism-performance-tests/src/gatling/kotlin => agent-performance-tests/bin/gatling}/steps/IssuanceSteps.kt (100%)
rename tests/performance-tests/{prism-performance-tests => agent-performance-tests}/build.gradle.kts (100%)
rename tests/performance-tests/{prism-performance-tests => agent-performance-tests}/gradle.properties (100%)
rename tests/performance-tests/{prism-performance-tests => agent-performance-tests}/gradle/wrapper/gradle-wrapper.jar (100%)
rename tests/performance-tests/{prism-performance-tests => agent-performance-tests}/gradle/wrapper/gradle-wrapper.properties (100%)
rename tests/performance-tests/{prism-performance-tests => agent-performance-tests}/gradlew (100%)
rename tests/performance-tests/{prism-performance-tests => agent-performance-tests}/gradlew.bat (100%)
create mode 100644 tests/performance-tests/agent-performance-tests/settings.gradle.kts
create mode 100644 tests/performance-tests/agent-performance-tests/src/gatling/kotlin/common/Configuration.kt
create mode 100644 tests/performance-tests/agent-performance-tests/src/gatling/kotlin/common/Utils.kt
create mode 100644 tests/performance-tests/agent-performance-tests/src/gatling/kotlin/simulations/ConnectionSimulation.kt
create mode 100644 tests/performance-tests/agent-performance-tests/src/gatling/kotlin/simulations/IssuanceSimulation.kt
create mode 100644 tests/performance-tests/agent-performance-tests/src/gatling/kotlin/steps/ConnectionSteps.kt
create mode 100644 tests/performance-tests/agent-performance-tests/src/gatling/kotlin/steps/IssuanceSteps.kt
create mode 100644 tests/performance-tests/agent-performance-tests/src/gatling/resources/gatling.conf
delete mode 100644 tests/performance-tests/prism-performance-tests/settings.gradle.kts
diff --git a/.github/ISSUE_TEMPLATE/1-bug-report.yaml b/.github/ISSUE_TEMPLATE/1-bug-report.yaml
index 3e62bb5cf5..9b651cb0b5 100644
--- a/.github/ISSUE_TEMPLATE/1-bug-report.yaml
+++ b/.github/ISSUE_TEMPLATE/1-bug-report.yaml
@@ -1,5 +1,5 @@
name: Bug Report
-description: Report a bug in the Atala PRISM Cloud Agent
+description: Report a bug in the Identus Cloud Agent
body:
- type: dropdown
@@ -7,8 +7,8 @@ body:
attributes:
label: Is this a regression?
options:
- - 'Yes'
- - 'No'
+ - "Yes"
+ - "No"
validations:
required: true
@@ -23,13 +23,13 @@ body:
id: exception-or-error
attributes:
label: Please provide the exception or error you saw
- render: true
+ render: "Markdown"
- type: textarea
id: environment
attributes:
label: Please provide the environment you discovered this bug in
- render: true
+ render: "Markdown"
- type: textarea
id: other
diff --git a/.github/ISSUE_TEMPLATE/2-feature-request.yaml b/.github/ISSUE_TEMPLATE/2-feature-request.yaml
index 721be36b55..7a8b1c0ea6 100644
--- a/.github/ISSUE_TEMPLATE/2-feature-request.yaml
+++ b/.github/ISSUE_TEMPLATE/2-feature-request.yaml
@@ -1,5 +1,5 @@
name: 'Feature Request'
-description: Suggest a new feature for Atala PRISM Cloud Agent
+description: Suggest a new feature for Identus Cloud Agent
body:
- type: textarea
diff --git a/.github/workflows/integration-tests.yml b/.github/workflows/integration-tests.yml
index 445ad5003c..73121c15b6 100644
--- a/.github/workflows/integration-tests.yml
+++ b/.github/workflows/integration-tests.yml
@@ -49,15 +49,15 @@ jobs:
version: v2.12.2 # defaults to 'latest'
legacy: true # will also install in PATH as `docker-compose`
- - name: Build local version of PRISM Agent
- id: build_local_prism_agent
+ - name: Build local version of Cloud Agent
+ id: build_local_cloud_agent
env:
- PRISM_AGENT_PATH: "../.."
+ CLOUD_AGENT_PATH: "../.."
ENV_FILE: "infrastructure/local/.env"
GITHUB_ACTOR: ${{ secrets.ATALA_GITHUB_ACTOR }}
GITHUB_TOKEN: ${{ secrets.ATALA_GITHUB_TOKEN }}
run: |
- cd "${PRISM_AGENT_PATH}" || exit 129
+ cd "${CLOUD_AGENT_PATH}" || exit 129
sbt docker:publishLocal
echo "open_enterprise_agent_version=$(cut -d'=' -f2 version.sbt | tr -d '" ')" >> "${GITHUB_OUTPUT}"
echo "prism_node_version=$(grep PRISM_NODE_VERSION infrastructure/local/.env | cut -d'=' -f2 | tr -d ' ')" >> "${GITHUB_OUTPUT}"
@@ -69,8 +69,8 @@ jobs:
- name: Run integration tests
env:
- PRISM_NODE_VERSION: ${{ steps.build_local_prism_agent.outputs.prism_node_version }}
- OPEN_ENTERPRISE_AGENT_VERSION: ${{ steps.build_local_prism_agent.outputs.open_enterprise_agent_version }}
+ PRISM_NODE_VERSION: ${{ steps.build_local_cloud_agent.outputs.prism_node_version }}
+ OPEN_ENTERPRISE_AGENT_VERSION: ${{ steps.build_local_cloud_agent.outputs.open_enterprise_agent_version }}
ATALA_GITHUB_ACTOR: ${{ secrets.ATALA_GITHUB_ACTOR }}
ATALA_GITHUB_TOKEN: ${{ secrets.ATALA_GITHUB_TOKEN }}
continue-on-error: true
diff --git a/.github/workflows/performance-tests.yml b/.github/workflows/performance-tests.yml
index 1ad723a607..6a85eaaf81 100644
--- a/.github/workflows/performance-tests.yml
+++ b/.github/workflows/performance-tests.yml
@@ -12,7 +12,7 @@ on:
workflow_dispatch:
env:
- BENCHMARKING_DIR: "tests/performance-tests/atala-performance-tests-k6"
+ BENCHMARKING_DIR: "tests/performance-tests/agent-performance-tests-k6"
NODE_AUTH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
GITHUB_ACTOR: ${{ github.actor }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
@@ -45,13 +45,13 @@ jobs:
with:
version: "2.14.2"
- - name: Build local version of PRISM Agent
+ - name: Build local version of Cloud Agent
env:
ENV_FILE: "infrastructure/local/.env"
run: |
sbt docker:publishLocal
- PRISM_AGENT_VERSION=$(cut version.sbt -d '=' -f2 | tr -d '" ')
- sed -i.bak "s/PRISM_AGENT_VERSION=.*/PRISM_AGENT_VERSION=${PRISM_AGENT_VERSION}/" "${ENV_FILE}" && rm -f "${ENV_FILE}.bak"
+ AGENT_VERSION=$(cut version.sbt -d '=' -f2 | tr -d '" ')
+ sed -i.bak "s/AGENT_VERSION=.*/AGENT_VERSION=${AGENT_VERSION}/" "${ENV_FILE}" && rm -f "${ENV_FILE}.bak"
cat "${ENV_FILE}"
- name: Start services for issuer
diff --git a/.mega-linter.yml b/.mega-linter.yml
index 67433327e0..9c6e9cd614 100644
--- a/.mega-linter.yml
+++ b/.mega-linter.yml
@@ -47,7 +47,7 @@ PRE_COMMANDS:
MARKDOWN_MARKDOWN_LINK_CHECK_FILTER_REGEX_EXCLUDE: "CHANGELOG.md"
MARKDOWN_MARKDOWNLINT_FILTER_REGEX_EXCLUDE: "CHANGELOG.md"
SQL_SQL_LINT_ARGUMENTS: -d postgres --ignore-errors=postgres-invalid-alter-option,postgres-invalid-create-option,postgres-invalid-drop-option
-YAML_YAMLLINT_FILTER_REGEX_EXCLUDE: "infrastructure/charts/agent/*"
-YAML_PRETTIER_FILTER_REGEX_EXCLUDE: "infrastructure/charts/agent/*"
+YAML_YAMLLINT_FILTER_REGEX_EXCLUDE: "infrastructure/charts/agent/*|cloud-agent/service/api/http/*"
+YAML_PRETTIER_FILTER_REGEX_EXCLUDE: "infrastructure/charts/agent/*|cloud-agent/service/api/http/*"
YAML_V8R_FILTER_REGEX_EXCLUDE: "infrastructure/charts/agent/*"
-JAVASCRIPT_STANDARD_FILTER_REGEX_EXCLUDE: "tests/performance-tests/atala-performance-tests-k6/src/k6chaijs.js"
+JAVASCRIPT_STANDARD_FILTER_REGEX_EXCLUDE: "tests/performance-tests/agent-performance-tests-k6/src/k6chaijs.js"
diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md
index 9fc08ec88a..7b208b8e3e 100644
--- a/CODE_OF_CONDUCT.md
+++ b/CODE_OF_CONDUCT.md
@@ -1,6 +1,6 @@
Code of Conduct
===============
-Atala PRISM follows Hyperledger [Code of Conduct](https://wiki.hyperledger.org/community/hyperledger-project-code-of-conduct).
+Identus follows Hyperledger [Code of Conduct](https://wiki.hyperledger.org/community/hyperledger-project-code-of-conduct).
Please, read before contributing to the project.
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 480ca729d4..a4f3e52535 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -1,6 +1,6 @@
-# Contributing to Atala PRISM
+# Contributing to Identus
-We would love for you to contribute to Atala PRISM and help make it even better than it is today!
+We would love for you to contribute to Identus and help make it even better than it is today!
As a contributor, here are the guidelines we would like you to follow:
- [DCO](#dco)
@@ -13,7 +13,7 @@ As a contributor, here are the guidelines we would like you to follow:
## Developer Certificate of Origin (DCO)
-PRISM Cloud Agent enforces the Developer Certificate of Origin (DCO). It requires all commit messages to contain the `Signed-off-by` line with an email address that matches the commit author and the name on your GitHub account.
+Cloud Agent enforces the Developer Certificate of Origin (DCO). It requires all commit messages to contain the `Signed-off-by` line with an email address that matches the commit author and the name on your GitHub account.
Please read and follow set up [DCO](./DCO.md).
@@ -43,13 +43,13 @@ If you would like to *implement* a new feature, please consider the size of the
Before you submit an issue, please search the issue tracker. An issue for your problem might already exist and the discussion might inform you of workarounds readily available.
-You can file new issues by selecting a `Bug Report` template on our [Issues submition page](https://github.com/input-output-hk/atala-prism-building-blocks/issues/new/choose).
+You can file new issues by selecting a `Bug Report` template on our [Issues submition page](https://github.com/hyperledger/identus-cloud-agent/issues/new/choose).
### Submitting a Pull Request (PR)
Before you submit your Pull Request (PR) consider the following guidelines:
-1. Search [GitHub](https://github.com/input-output-hk/atala-prism-building-blocks/pulls) for an open or closed PR that relates to your submission.
+1. Search [GitHub](https://github.com/hyperledger/identus-cloud-agent/pulls) for an open or closed PR that relates to your submission.
You don't want to duplicate existing efforts.
2. Be sure that an issue describes the problem you're fixing, or documents the design for the feature you'd like to add.
@@ -57,7 +57,7 @@ Before you submit your Pull Request (PR) consider the following guidelines:
3. Make sure all your commits have DCO sign-off line with an email address that matches the commit author and the name on your GitHub account.
-4. [Fork](https://docs.github.com/en/github/getting-started-with-github/fork-a-repo) the https://github.com/input-output-hk/atala-prism-building-blocks repo.
+4. [Fork](https://docs.github.com/en/github/getting-started-with-github/fork-a-repo) the https://github.com/hyperledger/identus-cloud-agent repo.
5. In your forked repository, make your changes in a new git branch:
@@ -85,7 +85,7 @@ Before you submit your Pull Request (PR) consider the following guidelines:
git push origin my-fix-branch
```
-11. In GitHub, send a pull request to `atala-prism-building-blocks:main`.
+11. In GitHub, send a pull request to `identus-cloud-agent:main`.
That's it! Thank you for your contribution!
diff --git a/DCO.md b/DCO.md
index 243038c4f9..e1b90b53b7 100644
--- a/DCO.md
+++ b/DCO.md
@@ -1,6 +1,6 @@
# Developer Certificate of Origin (DCO)
-PRISM Cloud Agent enforces the Developer Certificate of Origin (DCO). It requires all commit messages to contain the `Signed-off-by` line with an email address that matches the commit author and the name on your GitHub account.
+Identus Cloud Agent enforces the Developer Certificate of Origin (DCO). It requires all commit messages to contain the `Signed-off-by` line with an email address that matches the commit author and the name on your GitHub account.
The Developer Certificate of Origin (DCO) is a lightweight way for contributors to certify that they wrote or otherwise have the right to submit the code they are contributing to the project. Here is the full text of the DCO, reformatted for readability:
diff --git a/README.md b/README.md
index 9c899610f8..b86d7c505d 100644
--- a/README.md
+++ b/README.md
@@ -7,17 +7,17 @@
-
-
-
+
+
+
## Overview
-The Enterprise Cloud Agent is a W3C/Aries standards-based cloud agent written in Scala that provides self-sovereign identity services to build products and solutions based on it. The term "cloud" indicates that it operates on servers and is not intended for use on mobile devices.
+The Cloud Agent is a W3C/Aries standards-based cloud agent written in Scala that provides self-sovereign identity services to build products and solutions based on it. The term "cloud" indicates that it operates on servers and is not intended for use on mobile devices.
-Enterprise Cloud Agent supports standard-based protocols built on top of DIDComm V2 for issuing, verifying, and holding verifiable credentials using both JWT and Hyperledger AnonCreds (coming soon) formats.
+Cloud Agent supports standard-based protocols built on top of DIDComm V2 for issuing, verifying, and holding verifiable credentials using both JWT and Hyperledger AnonCreds (coming soon) formats.
In order to use the Cloud Agent, you establish a business logic controller responsible for communicating with the agent (initiating HTTP requests and processing webhook notifications). This controller can be created using any programming language capable of sending and receiving HTTP requests.
@@ -48,15 +48,15 @@ As a result, you can concentrate on crafting self-sovereign identity solutions u
Before starting to use the Cloud Agent, it is important to understand the basic concepts of self-sovereign identity (SSI). The following resources provide a good introduction to SSI:
-* [Atala PRISM SSI introduction](https://docs.atalaprism.io/docs/category/concepts/)
+* [Identus SSI introduction](https://docs.atalaprism.io/docs/category/concepts/)
* [Linux Foundation Course: Getting Started with SSI](https://www.edx.org/learn/computer-programming/the-linux-foundation-getting-started-with-self-sovereign-identity)
### Architecture
The next diagram offers a concise architectural overview, depicting a Cloud Agent instance, a controller, the interconnections linking the controller and agent, as well as the external routes to other agents and public ledgers across the Internet.
-![Enterprise Cloud Agent architecture](docs/images/cloud-agent-architecture-dark.png#gh-dark-mode-only)
-![Enterprise Cloud Agent architecture](docs/images/cloud-agent-architecture-light.png#gh-light-mode-only)
+![Cloud Agent architecture](docs/images/cloud-agent-architecture-dark.png#gh-dark-mode-only)
+![Cloud Agent architecture](docs/images/cloud-agent-architecture-light.png#gh-light-mode-only)
### Running the Cloud Agent locally on MacOS or Linux
#### Prerequisites
@@ -64,7 +64,7 @@ The next diagram offers a concise architectural overview, depicting a Cloud Agen
- Java (OpenJDK 21)
- SBT (latest version)
- Git (for cloning the repository)
-- Docker (for running the PostgreSQL database, Hashicorp Vault, APISIX, and PRISM Node)
+- Docker (for running the PostgreSQL database, Hashicorp Vault, APISIX, and PRISM Node)
- [GITHUB_TOKEN](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens) environment variable (required for SBT plugins and access to the GitHub packages)
#### Login to GitHub packages
@@ -87,23 +87,23 @@ sbt clean compile test docker:publishLocal
### Installation and usage
-Enterprise Cloud Agent is distributed as a Docker image to be run in a containerized environment. All versions can be found [here](https://github.com/orgs/input-output-hk/packages/container/package/prism-agent).
+Cloud Agent is distributed as a Docker image to be run in a containerized environment. All versions can be found [here](https://github.com/orgs/input-output-hk/packages/container/package/cloud-agent).
-The following sections describe how to run the Enterprise Cloud Agent in different configurations.
+The following sections describe how to run the Cloud Agent in different configurations.
#### Configuration
-The Enterprise Cloud Agent can be configured to use different types of ledger, secret storage and DID persistence. Any combination of options is available, but the most common configurations are:
+The Cloud Agent can be configured to use different types of ledger, secret storage and DID persistence. Any combination of options is available, but the most common configurations are:
-| Configuration | Secret Storage | DIDs persistence | VDR |
-| -------------- | -------------- | ---------------- | ------------------------------------ |
-| Dev | PostgreSQL | No | In-memory |
-| Pre-production | PostgreSQL | Yes | Cardano testnet (preview or preprod) |
-| Production | Hashicorp | Yes | Cardano mainnet |
+| Configuration | Secret Storage | DIDs persistence | Prism Node |
+| -------------- | -------------- | ---------------- |-------------------------------------------------|
+| Dev | PostgreSQL | No | In-memory |
+| Pre-production | PostgreSQL | Yes | Distributed Ledger testnet (preview or preprod) |
+| Production | Hashicorp | Yes | Distributed Ledger mainnet |
-To start playing with Cloud Agent, we recommend using the Dev configuration. Pre-production and production configurations are intended for real-world use cases and require additional more complex configurations of the Cardano stack setup.
+To start playing with Cloud Agent, we recommend using the Dev configuration. Pre-production and production configurations are intended for real-world use cases and require additional more complex configurations of the Distributed Ledger stack setup.
-> If you're interested in a hosted version of Enterprise Cloud Agent, please, contact us at [atalaprism.io](https://atalaprism.io).
+> If you're interested in a hosted version of Cloud Agent, please, contact us at [atalaprism.io](https://atalaprism.io).
#### System requirements
@@ -118,19 +118,19 @@ System requirements can vary depending on the use case. The following are the mi
Here is a general example of running a Cloud Agent locally:
```bash
-PORT=${PORT} PRISM_AGENT_VERSION=${PRISM_AGENT_VERSION} PRISM_NODE_VERSION=${PRISM_NODE_VERSION} \
+PORT=${PORT} AGENT_VERSION=${AGENT_VERSION} PRISM_NODE_VERSION=${PRISM_NODE_VERSION} \
docker compose \
-p "${AGENT_ROLE}" \
-f ./infrastructure/shared/docker-compose-demo.yml \
up --wait
```
-The `PORT` variable is used to specify the port number for the Cloud Agent to listen on. The `PRISM_AGENT_VERSION` and `PRISM_NODE_VERSION` variables are used to specify the versions of the Cloud Agent and PRISM Node to use. The `AGENT_ROLE` variable is used to specify the role of the Cloud Agent. The `AGENT_ROLE` variable can be set to `issuer`, `verifier` or `holder`.
+The `PORT` variable is used to specify the port number for the Cloud Agent to listen on. The `AGENT_VERSION` and `PRISM_NODE_VERSION` variables are used to specify the versions of the Cloud Agent and PRISM Node to use. The `AGENT_ROLE` variable is used to specify the role of the Cloud Agent. The `AGENT_ROLE` variable can be set to `issuer`, `verifier` or `holder`.
In real life, you will need to start at least two Cloud Agent instances with different roles. For example, you can start one instance with the `issuer` role and another one with the `holder` role. The `issuer` instance will be used to issue verifiable credentials (VCs) and the `holder` instance will be used to hold VCs. Here is an example of how you can do this:
-
+
```bash
-PORT=8080 PRISM_AGENT_VERSION=${PRISM_AGENT_VERSION} PRISM_NODE_VERSION=2.2.1 \
+PORT=8080 AGENT_VERSION=${AGENT_VERSION} PRISM_NODE_VERSION=2.2.1 \
docker compose \
-p "issuer" \
-f ./infrastructure/shared/docker-compose-demo.yml \
@@ -138,7 +138,7 @@ PORT=8080 PRISM_AGENT_VERSION=${PRISM_AGENT_VERSION} PRISM_NODE_VERSION=2.2.1 \
```
```bash
-PORT=8090 PRISM_AGENT_VERSION=${PRISM_AGENT_VERSION} PRISM_NODE_VERSION=2.2.1 \
+PORT=8090 AGENT_VERSION=${AGENT_VERSION} PRISM_NODE_VERSION=2.2.1 \
docker compose \
-p "holder" \
-f ./infrastructure/shared/docker-compose-demo.yml \
@@ -146,29 +146,29 @@ PORT=8090 PRISM_AGENT_VERSION=${PRISM_AGENT_VERSION} PRISM_NODE_VERSION=2.2.1 \
```
If the Cloud Agent is started successfully, all the running containers should achieve `Healthy` state, and Cloud Agent Rest API should be available at the specified port, for example:
-* `http://localhost:8080/prism-agent` for the `issuer` instance
-* `http://localhost:8090/prism-agent` for the `holder` instance
+* `http://localhost:8080/cloud-agent` for the `issuer` instance
+* `http://localhost:8090/cloud-agent` for the `holder` instance
You can check the status of the running containers using the [health endpoint](https://docs.atalaprism.io/agent-api/#tag/System/operation/systemHealth):
```bash
-$ curl http://localhost:8080/prism-agent/_system/health
+$ curl http://localhost:8080/cloud-agent/_system/health
{"version":"1.19.1"}
```
> For more information about all available configuration parameters, please, check [Cloud Agent configuration](https://docs.atalaprism.io/docs/atala-prism/prism-cloud-agent/environment-variables) section at the documentation portal and edit the `docker-compose-demo.yml` file accordingly.
-#### Compatibility between Cloud Agent and PRISM Node
+#### Compatibility between Cloud Agent and PRISM Node
-There could be some incompatibilities between the most latest versions of Enterprise Cloud Agent and PRISM Node. Please, use the following table to check the compatibility between the versions:
+There could be some incompatibilities between the most latest versions of Cloud Agent and PRISM Node. Please, use the following table to check the compatibility between the versions:
| Cloud Agent | PRISM Node |
|-------------|------------|
| >=1.9.2 | 2.2.1 |
| <1.9.2 | 2.1.1 |
-> Please note: it is not guaranteed that the latest version of Enterprise Cloud Agent will work with the latest version of PRISM Node. We recommend using the versions from the table above.
+> Please note: it is not guaranteed that the latest version of Cloud Agent will work with the latest version of PRISM Node. We recommend using the versions from the table above.
-### Following the Enterprise Cloud Agent tutorials
+### Following the Cloud Agent tutorials
The following tutorials will help you get started with the Cloud Agent and issue your first credentials:
@@ -179,13 +179,13 @@ The following tutorials will help you get started with the Cloud Agent and issue
## User documentation
-All extended documentation, tutorials and API references for the PRISM ecosystem can be found at https://docs.atalaprism.io/
+All extended documentation, tutorials and API references for the Identus ecosystem can be found at https://docs.atalaprism.io/
## Contributing
Please read our [contributions guidelines](./CONTRIBUTING.md) and submit your PRs. We enforce [developer certificate of origin (DCO) commit signing](./DCO.md).
-We also welcome issues submitted about problems you encounter in using Enterprise Cloud Agent.
+We also welcome issues submitted about problems you encounter in using Cloud Agent.
## License
diff --git a/SECURITY.md b/SECURITY.md
index a0bac7350f..1edd6ab1b2 100644
--- a/SECURITY.md
+++ b/SECURITY.md
@@ -2,7 +2,7 @@
# Reporting Security Issues
-The Open Enterprise Agent (OEA) team and community take security bugs in the components of the OEA ecosystem seriously. We appreciate your efforts to responsibly disclose your findings, and will make every effort to acknowledge your contributions.
+The Identus Cloud Agent (ICA) team and community take security bugs in the components of the OEA ecosystem seriously. We appreciate your efforts to disclose your findings responsibly and will make every effort to acknowledge your contributions.
To report a security issue, please use the GitHub Security Advisory ["Report a Vulnerability"](https://github.com/hyperledger/identus-cloud-agent/security/advisories/new) tab.
@@ -12,4 +12,4 @@ Report security bugs in third-party modules to the person or team maintaining th
## Security Notification Process
-Security notifications will be sent to the dedicated [open-enterprise-agent-security-notices](https://discordapp.com/channels/905194001349627914/1199354196944748614) channel in the Hyper Ledger discord server
+Security notifications will be sent to the dedicated [open-cloud-agent-security-notices](https://discordapp.com/channels/905194001349627914/1199354196944748614) channel in the Hyper Ledger discord server
diff --git a/build.sbt b/build.sbt
index a4bde4d552..63d0843fd5 100644
--- a/build.sbt
+++ b/build.sbt
@@ -6,7 +6,7 @@ import sbtbuildinfo.BuildInfoPlugin.autoImport.*
inThisBuild(
Seq(
organization := "org.hyperledger",
- scalaVersion := "3.3.1",
+ scalaVersion := "3.3.3",
fork := true,
run / connectInput := true,
releaseUseGlobalVersion := false,
@@ -352,7 +352,7 @@ lazy val D_Pollux_AnonCreds = new {
val baseDependencies: Seq[ModuleID] = Seq(D.zio, D.zioJson)
}
-lazy val D_PrismAgent = new {
+lazy val D_CloudAgent = new {
val logback = "ch.qos.logback" % "logback-classic" % V.logback
val tapirSwaggerUiBundle = "com.softwaremill.sttp.tapir" %% "tapir-swagger-ui-bundle" % V.tapir
@@ -467,8 +467,6 @@ val commonSetttings = Seq(
lazy val shared = (project in file("shared/core"))
.settings(commonSetttings)
.settings(
- organization := "io.iohk.atala",
- organizationName := "Input Output Global",
name := "shared",
crossPaths := false,
libraryDependencies ++= D_Shared.dependencies
@@ -477,8 +475,6 @@ lazy val shared = (project in file("shared/core"))
lazy val sharedCrypto = (project in file("shared/crypto"))
.settings(commonSetttings)
.settings(
- organization := "io.iohk.atala",
- organizationName := "Input Output Global",
name := "shared-crypto",
crossPaths := false,
libraryDependencies ++= D_SharedCrypto.dependencies
@@ -488,8 +484,6 @@ lazy val sharedCrypto = (project in file("shared/crypto"))
lazy val sharedTest = (project in file("shared/test"))
.settings(commonSetttings)
.settings(
- organization := "io.iohk.atala",
- organizationName := "Input Output Global",
name := "shared-test",
crossPaths := false,
libraryDependencies ++= D_SharedTest.dependencies
@@ -505,7 +499,7 @@ lazy val sharedTest = (project in file("shared/test"))
* This module must not depend on external libraries!
*/
lazy val models = project
- .in(file("mercury/mercury-library/models"))
+ .in(file("mercury/models"))
.settings(name := "mercury-data-models")
.settings(
libraryDependencies ++= Seq(D.zio),
@@ -531,7 +525,7 @@ models implementation for didcommx () */
// #################
lazy val protocolConnection = project
- .in(file("mercury/mercury-library/protocol-connection"))
+ .in(file("mercury/protocol-connection"))
.settings(name := "mercury-protocol-connection")
.settings(libraryDependencies += D.zio)
.settings(libraryDependencies ++= Seq(D.circeCore, D.circeGeneric, D.circeParser))
@@ -539,7 +533,7 @@ lazy val protocolConnection = project
.dependsOn(models, protocolInvitation)
lazy val protocolCoordinateMediation = project
- .in(file("mercury/mercury-library/protocol-coordinate-mediation"))
+ .in(file("mercury/protocol-coordinate-mediation"))
.settings(name := "mercury-protocol-coordinate-mediation")
.settings(libraryDependencies += D.zio)
.settings(libraryDependencies ++= Seq(D.circeCore, D.circeGeneric, D.circeParser))
@@ -547,14 +541,14 @@ lazy val protocolCoordinateMediation = project
.dependsOn(models)
lazy val protocolDidExchange = project
- .in(file("mercury/mercury-library/protocol-did-exchange"))
+ .in(file("mercury/protocol-did-exchange"))
.settings(name := "mercury-protocol-did-exchange")
.settings(libraryDependencies += D.zio)
.settings(libraryDependencies ++= Seq(D.circeCore, D.circeGeneric, D.circeParser))
.dependsOn(models, protocolInvitation)
lazy val protocolInvitation = project
- .in(file("mercury/mercury-library/protocol-invitation"))
+ .in(file("mercury/protocol-invitation"))
.settings(name := "mercury-protocol-invitation")
.settings(libraryDependencies += D.zio)
.settings(
@@ -569,13 +563,13 @@ lazy val protocolInvitation = project
.dependsOn(models)
lazy val protocolMercuryMailbox = project
- .in(file("mercury/mercury-library/protocol-mercury-mailbox"))
+ .in(file("mercury/protocol-mercury-mailbox"))
.settings(name := "mercury-protocol-mailbox")
.settings(libraryDependencies += D.zio)
.dependsOn(models, protocolInvitation, protocolRouting)
lazy val protocolLogin = project
- .in(file("mercury/mercury-library/protocol-outofband-login"))
+ .in(file("mercury/protocol-outofband-login"))
.settings(name := "mercury-protocol-outofband-login")
.settings(libraryDependencies += D.zio)
.settings(libraryDependencies += D.zio)
@@ -584,19 +578,19 @@ lazy val protocolLogin = project
.dependsOn(models)
lazy val protocolReportProblem = project
- .in(file("mercury/mercury-library/protocol-report-problem"))
+ .in(file("mercury/protocol-report-problem"))
.settings(name := "mercury-protocol-report-problem")
.settings(libraryDependencies += D.munitZio)
.dependsOn(models)
lazy val protocolRouting = project
- .in(file("mercury/mercury-library/protocol-routing"))
+ .in(file("mercury/protocol-routing"))
.settings(name := "mercury-protocol-routing-2-0")
.settings(libraryDependencies += D.zio)
.dependsOn(models)
lazy val protocolIssueCredential = project
- .in(file("mercury/mercury-library/protocol-issue-credential"))
+ .in(file("mercury/protocol-issue-credential"))
.settings(name := "mercury-protocol-issue-credential")
.settings(libraryDependencies += D.zio)
.settings(libraryDependencies ++= Seq(D.circeCore, D.circeGeneric, D.circeParser))
@@ -604,7 +598,7 @@ lazy val protocolIssueCredential = project
.dependsOn(models)
lazy val protocolRevocationNotification = project
- .in(file("mercury/mercury-library/protocol-revocation-notification"))
+ .in(file("mercury/protocol-revocation-notification"))
.settings(name := "mercury-protocol-revocation-notification")
.settings(libraryDependencies += D.zio)
.settings(libraryDependencies ++= Seq(D.circeCore, D.circeGeneric, D.circeParser))
@@ -612,7 +606,7 @@ lazy val protocolRevocationNotification = project
.dependsOn(models)
lazy val protocolPresentProof = project
- .in(file("mercury/mercury-library/protocol-present-proof"))
+ .in(file("mercury/protocol-present-proof"))
.settings(name := "mercury-protocol-present-proof")
.settings(libraryDependencies += D.zio)
.settings(libraryDependencies ++= Seq(D.circeCore, D.circeGeneric, D.circeParser))
@@ -620,12 +614,12 @@ lazy val protocolPresentProof = project
.dependsOn(models)
lazy val vc = project
- .in(file("mercury/mercury-library/vc"))
+ .in(file("mercury/vc"))
.settings(name := "mercury-verifiable-credentials")
.dependsOn(protocolIssueCredential, protocolPresentProof) //TODO merge those two modules into this one
lazy val protocolTrustPing = project
- .in(file("mercury/mercury-library/protocol-trust-ping"))
+ .in(file("mercury/protocol-trust-ping"))
.settings(name := "mercury-protocol-trust-ping")
.settings(libraryDependencies += D.zio)
.settings(libraryDependencies ++= Seq(D.circeCore, D.circeGeneric, D.circeParser))
@@ -638,7 +632,7 @@ lazy val protocolTrustPing = project
// TODO move stuff to the models module
lazy val resolver = project // maybe merge into models
- .in(file("mercury/mercury-library/resolver"))
+ .in(file("mercury/resolver"))
.settings(name := "mercury-resolver")
.settings(
libraryDependencies ++= Seq(
@@ -657,7 +651,7 @@ lazy val resolver = project // maybe merge into models
// ##############
lazy val agent = project // maybe merge into models
- .in(file("mercury/mercury-library/agent"))
+ .in(file("mercury/agent"))
.settings(name := "mercury-agent-core")
.settings(libraryDependencies ++= Seq(D.zioLog, D.zioSLF4J))
.dependsOn(
@@ -679,7 +673,7 @@ lazy val agent = project // maybe merge into models
/** agents implementation with didcommx */
lazy val agentDidcommx = project
- .in(file("mercury/mercury-library/agent-didcommx"))
+ .in(file("mercury/agent-didcommx"))
.settings(name := "mercury-agent-didcommx")
.settings(libraryDependencies += D.didcommx)
.settings(libraryDependencies += D.munitZio)
@@ -688,13 +682,13 @@ lazy val agentDidcommx = project
// ///** TODO Demos agents and services implementation with did-scala */
// lazy val agentDidScala =
// project
-// .in(file("mercury/mercury-library/agent-did-scala"))
+// .in(file("mercury/agent-did-scala"))
// .settings(name := "mercury-agent-didscala")
// .settings(skip / publish := true)
// .dependsOn(agent)
// ####################
-// ### prismNode ####
+// ### Prism Node ####
// ####################
val prismNodeClient = project
.in(file("prism-node/client/scala-client"))
@@ -715,7 +709,7 @@ val prismNodeClient = project
// #####################
lazy val castorCore = project
- .in(file("castor/lib/core"))
+ .in(file("castor"))
.settings(commonSetttings)
.settings(
name := "castor-core",
@@ -729,7 +723,7 @@ lazy val castorCore = project
// #####################
lazy val polluxVcJWT = project
- .in(file("pollux/lib/vc-jwt"))
+ .in(file("pollux/vc-jwt"))
.settings(commonSetttings)
.settings(
name := "pollux-vc-jwt",
@@ -738,19 +732,19 @@ lazy val polluxVcJWT = project
.dependsOn(castorCore)
lazy val polluxCore = project
- .in(file("pollux/lib/core"))
+ .in(file("pollux/core"))
.settings(commonSetttings)
.settings(
name := "pollux-core",
libraryDependencies ++= D_Pollux.coreDependencies
)
.dependsOn(shared)
- .dependsOn(prismAgentWalletAPI)
+ .dependsOn(agentWalletAPI)
.dependsOn(polluxVcJWT)
.dependsOn(vc, resolver, agentDidcommx, eventNotification, polluxAnoncreds)
lazy val polluxDoobie = project
- .in(file("pollux/lib/sql-doobie"))
+ .in(file("pollux/sql-doobie"))
.settings(commonSetttings)
.settings(
name := "pollux-sql-doobie",
@@ -765,7 +759,7 @@ lazy val polluxDoobie = project
// ########################
lazy val polluxAnoncreds = project
- .in(file("pollux/lib/anoncreds"))
+ .in(file("pollux/anoncreds"))
.enablePlugins(BuildInfoPlugin)
.enablePlugins(JavaAppPackaging)
.settings(
@@ -774,12 +768,11 @@ lazy val polluxAnoncreds = project
Compile / unmanagedResourceDirectories ++= Seq(
baseDirectory.value / "native-lib" / "NATIVE"
),
- // libraryDependencies += "io.iohk.atala.prism.anoncredskmp" % "anoncreds-kmp-jvm" % "0.3.5-M2",
libraryDependencies ++= D_Pollux_AnonCreds.baseDependencies
)
lazy val polluxAnoncredsTest = project
- .in(file("pollux/lib/anoncredsTest"))
+ .in(file("pollux/anoncredsTest"))
.settings(libraryDependencies ++= Seq("org.scalatest" %% "scalatest" % "3.2.15" % Test))
.dependsOn(polluxAnoncreds % "compile->test")
@@ -788,7 +781,7 @@ lazy val polluxAnoncredsTest = project
// #####################
lazy val connectCore = project
- .in(file("connect/lib/core"))
+ .in(file("connect/core"))
.settings(commonSetttings)
.settings(
name := "connect-core",
@@ -799,7 +792,7 @@ lazy val connectCore = project
.dependsOn(protocolConnection, protocolReportProblem, eventNotification)
lazy val connectDoobie = project
- .in(file("connect/lib/sql-doobie"))
+ .in(file("connect/sql-doobie"))
.settings(commonSetttings)
.settings(
name := "connect-sql-doobie",
@@ -822,18 +815,18 @@ lazy val eventNotification = project
.dependsOn(shared)
// #####################
-// #### Prism Agent ####
+// #### Cloud Agent ####
// #####################
-lazy val prismAgentWalletAPI = project
- .in(file("prism-agent/service/wallet-api"))
+lazy val agentWalletAPI = project
+ .in(file("cloud-agent/service/wallet-api"))
.settings(commonSetttings)
.settings(
- name := "prism-agent-wallet-api",
+ name := "cloud-agent-wallet-api",
libraryDependencies ++=
- D_PrismAgent.keyManagementDependencies ++
- D_PrismAgent.iamDependencies ++
- D_PrismAgent.postgresDependencies ++
+ D_CloudAgent.keyManagementDependencies ++
+ D_CloudAgent.iamDependencies ++
+ D_CloudAgent.postgresDependencies ++
Seq(D.zioMock)
)
.dependsOn(
@@ -844,32 +837,32 @@ lazy val prismAgentWalletAPI = project
.dependsOn(sharedTest % "test->test")
.dependsOn(sharedCrypto % "compile->compile;test->test")
-lazy val prismAgentServer = project
- .in(file("prism-agent/service/server"))
+lazy val cloudAgentServer = project
+ .in(file("cloud-agent/service/server"))
.settings(commonSetttings)
.settings(
name := "identus-cloud-agent",
fork := true,
- libraryDependencies ++= D_PrismAgent.serverDependencies,
+ libraryDependencies ++= D_CloudAgent.serverDependencies,
excludeDependencies ++= Seq(
// Exclude `protobuf-javalite` from all dependencies since we're using scalapbRuntime which already include `protobuf-java`
// Having both may introduce conflict on some api https://github.com/protocolbuffers/protobuf/issues/8104
ExclusionRule("com.google.protobuf", "protobuf-javalite")
),
- Compile / mainClass := Some("io.iohk.atala.agent.server.MainApp"),
+ Compile / mainClass := Some("org.hyperledger.identus.agent.server.MainApp"),
Docker / maintainer := "atala-coredid@iohk.io",
- Docker / dockerUsername := Some("hyperledger"),
+ Docker / dockerUsername := Some("hyperledger"), // https://github.com/hyperledger
Docker / dockerRepository := Some("ghcr.io"),
dockerExposedPorts := Seq(8080, 8085, 8090),
// Official docker image for openjdk 21 with curl and bash
dockerBaseImage := "openjdk:21-jdk",
buildInfoKeys := Seq[BuildInfoKey](name, version, scalaVersion, sbtVersion),
- buildInfoPackage := "io.iohk.atala.agent.server.buildinfo",
+ buildInfoPackage := "org.hyperledger.identus.agent.server.buildinfo",
Compile / packageDoc / publishArtifact := false
)
.enablePlugins(JavaAppPackaging, DockerPlugin)
.enablePlugins(BuildInfoPlugin)
- .dependsOn(prismAgentWalletAPI % "compile->compile;test->test")
+ .dependsOn(agentWalletAPI % "compile->compile;test->test")
.dependsOn(
agent,
polluxCore,
@@ -892,7 +885,7 @@ releaseProcess := Seq[ReleaseStep](
runClean,
runTest,
setReleaseVersion,
- ReleaseStep(releaseStepTask(prismAgentServer / Docker / stage)),
+ ReleaseStep(releaseStepTask(cloudAgentServer / Docker / stage)),
setNextVersion
)
@@ -925,8 +918,8 @@ lazy val aggregatedProjects: Seq[ProjectReference] = Seq(
polluxAnoncredsTest,
connectCore,
connectDoobie,
- prismAgentWalletAPI,
- prismAgentServer,
+ agentWalletAPI,
+ cloudAgentServer,
eventNotification,
)
diff --git a/castor/lib/CHANGELOG.md b/castor/CHANGELOG.md
similarity index 100%
rename from castor/lib/CHANGELOG.md
rename to castor/CHANGELOG.md
diff --git a/castor/lib/README.md b/castor/README.md
similarity index 100%
rename from castor/lib/README.md
rename to castor/README.md
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/repository/DIDOperationRepository.scala b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/repository/DIDOperationRepository.scala
deleted file mode 100644
index 2606066f36..0000000000
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/repository/DIDOperationRepository.scala
+++ /dev/null
@@ -1,7 +0,0 @@
-package io.iohk.atala.castor.core.repository
-
-import io.iohk.atala.castor.core.model.did.PrismDID
-
-trait DIDOperationRepository[F[_]] {
- def getConfirmedPublishedDIDOperations(did: PrismDID): F[Unit]
-}
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/ProtoModelHelper.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/ProtoModelHelper.scala
similarity index 98%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/ProtoModelHelper.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/ProtoModelHelper.scala
index 067d8ba4a9..ab19920c9d 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/ProtoModelHelper.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/ProtoModelHelper.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.castor.core.model
+package org.hyperledger.identus.castor.core.model
import com.google.protobuf.ByteString
import io.circe.Json
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
-import io.iohk.atala.castor.core.model.did.{
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
+import org.hyperledger.identus.castor.core.model.did.{
DIDData,
EllipticCurve,
InternalKeyPurpose,
@@ -25,8 +25,8 @@ import io.iohk.atala.prism.protos.common_models.OperationStatus
import io.iohk.atala.prism.protos.node_models.KeyUsage
import io.iohk.atala.prism.protos.node_models.PublicKey.KeyData
import io.iohk.atala.prism.protos.{common_models, node_api, node_models}
-import io.iohk.atala.shared.models.Base64UrlString
-import io.iohk.atala.shared.utils.Traverse.*
+import org.hyperledger.identus.shared.models.Base64UrlString
+import org.hyperledger.identus.shared.utils.Traverse.*
import java.time.Instant
import scala.language.implicitConversions
import zio.*
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/DID.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/DID.scala
similarity index 96%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/DID.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/DID.scala
index 2976308135..9d71ae4f5f 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/DID.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/DID.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
import scala.util.matching.Regex
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/DIDData.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/DIDData.scala
similarity index 89%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/DIDData.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/DIDData.scala
index ce00f8c8c4..30d5d4bbdb 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/DIDData.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/DIDData.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
import java.time.Instant
import scala.collection.immutable.ArraySeq
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/DIDUrl.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/DIDUrl.scala
similarity index 71%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/DIDUrl.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/DIDUrl.scala
index e7db8524ef..c28e443897 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/DIDUrl.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/DIDUrl.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
final case class DIDUrl(
did: DID,
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/EllipticCurve.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/EllipticCurve.scala
similarity index 91%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/EllipticCurve.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/EllipticCurve.scala
index a45986022f..49e9dd05d8 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/EllipticCurve.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/EllipticCurve.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
// EC Name is used in JWK https://w3c-ccg.github.io/security-vocab/#publicKeyJwk
// It MUST match the curve name in https://www.iana.org/assignments/jose/jose.xhtml
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PrismDID.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PrismDID.scala
similarity index 95%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PrismDID.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PrismDID.scala
index eaa88d7e16..a929f65bc0 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PrismDID.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PrismDID.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
-import io.iohk.atala.castor.core.model.ProtoModelHelper
+import org.hyperledger.identus.castor.core.model.ProtoModelHelper
import io.iohk.atala.prism.crypto.{Sha256, Sha256Digest}
import io.iohk.atala.prism.protos.node_models
import io.iohk.atala.prism.protos.node_models.AtalaOperation.Operation
-import io.iohk.atala.shared.models.Base64UrlString
-import io.iohk.atala.shared.models.HexString
+import org.hyperledger.identus.shared.models.Base64UrlString
+import org.hyperledger.identus.shared.models.HexString
import scala.util.Try
import scala.util.matching.Regex
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PrismDIDOperation.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PrismDIDOperation.scala
similarity index 95%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PrismDIDOperation.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PrismDIDOperation.scala
index 43f2c18c1c..42cb8ec1e3 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PrismDIDOperation.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PrismDIDOperation.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
-import io.iohk.atala.castor.core.model.ProtoModelHelper
+import org.hyperledger.identus.castor.core.model.ProtoModelHelper
import io.iohk.atala.prism.crypto.Sha256
import scala.collection.compat.immutable.ArraySeq
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PublicKey.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PublicKey.scala
similarity index 85%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PublicKey.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PublicKey.scala
index 5dd050b589..496b71abb3 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PublicKey.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PublicKey.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
-import io.iohk.atala.shared.models.Base64UrlString
+import org.hyperledger.identus.shared.models.Base64UrlString
final case class PublicKey(
id: String,
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/Service.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/Service.scala
similarity index 79%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/Service.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/Service.scala
index d2ce528890..36fe203d6e 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/Service.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/Service.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
final case class Service(
id: String,
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/ServiceEndpoint.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/ServiceEndpoint.scala
similarity index 93%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/ServiceEndpoint.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/ServiceEndpoint.scala
index 3120dcd06e..56167dca22 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/ServiceEndpoint.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/ServiceEndpoint.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
import io.circe.JsonObject
-import io.iohk.atala.castor.core.util.UriUtils
+import org.hyperledger.identus.castor.core.util.UriUtils
sealed trait ServiceEndpoint {
def normalize(): ServiceEndpoint
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/ServiceType.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/ServiceType.scala
similarity index 92%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/ServiceType.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/ServiceType.scala
index 159bc52f89..b9f9314d49 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/ServiceType.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/ServiceType.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
sealed trait ServiceType
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/VerificationRelationship.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/VerificationRelationship.scala
similarity index 92%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/VerificationRelationship.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/VerificationRelationship.scala
index 797ee0d51b..7fc04d18fc 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/VerificationRelationship.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/VerificationRelationship.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
enum VerificationRelationship(val name: String) {
case Authentication extends VerificationRelationship("authentication")
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/DIDDocumentRepr.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/DIDDocumentRepr.scala
similarity index 93%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/DIDDocumentRepr.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/DIDDocumentRepr.scala
index 37dc1d23ff..4bdaca0c71 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/DIDDocumentRepr.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/DIDDocumentRepr.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model.did.w3c
+package org.hyperledger.identus.castor.core.model.did.w3c
import io.circe.Json
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/DIDMetadata.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/DIDMetadata.scala
similarity index 94%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/DIDMetadata.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/DIDMetadata.scala
index a2e5cdb72b..89b84d3711 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/DIDMetadata.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/DIDMetadata.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model.did.w3c
+package org.hyperledger.identus.castor.core.model.did.w3c
// errors are based on https://www.w3.org/TR/did-spec-registries/#error
enum DIDResolutionErrorRepr(val value: String, val errorMessage: Option[String]) {
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelper.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/W3CModelHelper.scala
similarity index 94%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelper.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/W3CModelHelper.scala
index 45dd3bd47c..ff1e4210b9 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelper.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/W3CModelHelper.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.castor.core.model.did.w3c
+package org.hyperledger.identus.castor.core.model.did.w3c
import io.circe.Json
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.models.Base64UrlString
-import io.iohk.atala.shared.models.HexString
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.models.Base64UrlString
+import org.hyperledger.identus.shared.models.HexString
import java.time.Instant
import java.time.ZoneOffset
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/package.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/package.scala
similarity index 87%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/package.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/package.scala
index a32f1aaa1d..af2ffbd8a8 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/w3c/package.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/w3c/package.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
-import io.iohk.atala.castor.core.model.error.DIDResolutionError
-import io.iohk.atala.castor.core.service.DIDService
+import org.hyperledger.identus.castor.core.model.error.DIDResolutionError
+import org.hyperledger.identus.castor.core.service.DIDService
import zio.*
package object w3c {
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/error/package.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/error/package.scala
similarity index 96%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/error/package.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/model/error/package.scala
index 5bd17373f9..e0f5297fd9 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/error/package.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/error/package.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.model
+package org.hyperledger.identus.castor.core.model
package object error {
diff --git a/castor/src/main/scala/org/hyperledger/identus/castor/core/repository/DIDOperationRepository.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/repository/DIDOperationRepository.scala
new file mode 100644
index 0000000000..9c82b74a6d
--- /dev/null
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/repository/DIDOperationRepository.scala
@@ -0,0 +1,7 @@
+package org.hyperledger.identus.castor.core.repository
+
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+
+trait DIDOperationRepository[F[_]] {
+ def getConfirmedPublishedDIDOperations(did: PrismDID): F[Unit]
+}
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/DIDService.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/service/DIDService.scala
similarity index 93%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/DIDService.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/service/DIDService.scala
index 9e865be572..0b069c0e69 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/DIDService.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/service/DIDService.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.castor.core.service
+package org.hyperledger.identus.castor.core.service
-import io.iohk.atala.castor.core.model.ProtoModelHelper
-import io.iohk.atala.castor.core.model.did.{
+import org.hyperledger.identus.castor.core.model.ProtoModelHelper
+import org.hyperledger.identus.castor.core.model.did.{
CanonicalPrismDID,
DIDData,
DIDMetadata,
@@ -13,13 +13,13 @@ import io.iohk.atala.castor.core.model.did.{
ScheduledDIDOperationDetail,
SignedPrismDIDOperation
}
-import io.iohk.atala.castor.core.model.error.OperationValidationError
-import io.iohk.atala.castor.core.model.error.{DIDOperationError, DIDResolutionError}
-import io.iohk.atala.castor.core.util.DIDOperationValidator
+import org.hyperledger.identus.castor.core.model.error.OperationValidationError
+import org.hyperledger.identus.castor.core.model.error.{DIDOperationError, DIDResolutionError}
+import org.hyperledger.identus.castor.core.util.DIDOperationValidator
import io.iohk.atala.prism.protos.node_api.NodeServiceGrpc.NodeService
import io.iohk.atala.prism.protos.node_models.OperationOutput.OperationMaybe
import io.iohk.atala.prism.protos.{node_api, node_models}
-import io.iohk.atala.shared.models.HexString
+import org.hyperledger.identus.shared.models.HexString
import java.time.Instant
import scala.collection.immutable.ArraySeq
import zio.*
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/MockDIDService.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/service/MockDIDService.scala
similarity index 91%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/MockDIDService.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/service/MockDIDService.scala
index 1da4d59758..890a2e209b 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/service/MockDIDService.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/service/MockDIDService.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.castor.core.service
+package org.hyperledger.identus.castor.core.service
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.castor.core.model.error
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.crypto.Secp256k1KeyPair
-import io.iohk.atala.shared.models.Base64UrlString
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.castor.core.model.error
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.crypto.Secp256k1KeyPair
+import org.hyperledger.identus.shared.models.Base64UrlString
import zio.mock.{Expectation, Mock, Proxy}
import zio.test.Assertion
import zio.{IO, URLayer, ZIO, ZLayer, mock}
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/DIDOperationValidator.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/util/DIDOperationValidator.scala
similarity index 97%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/DIDOperationValidator.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/util/DIDOperationValidator.scala
index 80b0a6a557..33401840e2 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/DIDOperationValidator.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/util/DIDOperationValidator.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.castor.core.util
+package org.hyperledger.identus.castor.core.util
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.castor.core.model.error.OperationValidationError
-import io.iohk.atala.castor.core.util.DIDOperationValidator.Config
-import io.iohk.atala.castor.core.util.Prelude.*
-import io.iohk.atala.shared.crypto.Apollo
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.castor.core.model.error.OperationValidationError
+import org.hyperledger.identus.castor.core.util.DIDOperationValidator.Config
+import org.hyperledger.identus.castor.core.util.Prelude.*
+import org.hyperledger.identus.shared.crypto.Apollo
import zio.*
import scala.collection.immutable.ArraySeq
@@ -319,7 +319,7 @@ private trait BaseOperationValidator {
protected def validateServiceTypeLength[T <: PrismDIDOperation](
config: Config
)(operation: T, serviceTypeExtractor: ServiceTypeExtractor[T]): Either[OperationValidationError, Unit] = {
- import io.iohk.atala.castor.core.model.ProtoModelHelper.*
+ import org.hyperledger.identus.castor.core.model.ProtoModelHelper.*
val serviceTypes = serviceTypeExtractor(operation)
val invalidServiceTypes = serviceTypes.filter(_._2.toProto.length > config.maxServiceTypeSize)
if (invalidServiceTypes.isEmpty) Right(())
@@ -334,7 +334,7 @@ private trait BaseOperationValidator {
protected def validateServiceEndpointLength[T <: PrismDIDOperation](
config: Config
)(operation: T, serviceEndpointExtractor: ServiceEndpointExtractor[T]): Either[OperationValidationError, Unit] = {
- import io.iohk.atala.castor.core.model.ProtoModelHelper.*
+ import org.hyperledger.identus.castor.core.model.ProtoModelHelper.*
val serviceEndpoints = serviceEndpointExtractor(operation)
val invalidServiceEndpoints = serviceEndpoints.filter(_._2.toProto.length > config.maxServiceEndpointSize)
if (invalidServiceEndpoints.isEmpty) Right(())
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/Prelude.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/util/Prelude.scala
similarity index 76%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/Prelude.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/util/Prelude.scala
index 5414dce4d3..4f05098950 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/Prelude.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/util/Prelude.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.util
+package org.hyperledger.identus.castor.core.util
// consider moving this to shared library
object Prelude {
diff --git a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/UriUtils.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/util/UriUtils.scala
similarity index 99%
rename from castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/UriUtils.scala
rename to castor/src/main/scala/org/hyperledger/identus/castor/core/util/UriUtils.scala
index 4fe0f0eda0..06ee467f47 100644
--- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/util/UriUtils.scala
+++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/util/UriUtils.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.core.util
+package org.hyperledger.identus.castor.core.util
import io.lemonlabs.uri.{Uri, Url, Urn, QueryString}
import io.lemonlabs.uri.config.UriConfig
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/ProtoModelHelperSpec.scala b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/ProtoModelHelperSpec.scala
similarity index 97%
rename from castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/ProtoModelHelperSpec.scala
rename to castor/src/test/scala/org/hyperledger/identus/castor/core/model/ProtoModelHelperSpec.scala
index 7d2bd094e3..91475c86ce 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/ProtoModelHelperSpec.scala
+++ b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/ProtoModelHelperSpec.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.castor.core.model
+package org.hyperledger.identus.castor.core.model
import com.google.protobuf.timestamp.Timestamp
import io.circe.Json
import io.circe.JsonObject
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriValue
-import io.iohk.atala.castor.core.model.did.ServiceType
-import io.iohk.atala.castor.core.util.GenUtils
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint.UriValue
+import org.hyperledger.identus.castor.core.model.did.ServiceType
+import org.hyperledger.identus.castor.core.util.GenUtils
import io.iohk.atala.prism.protos.common_models.Ledger
import io.iohk.atala.prism.protos.node_models
import java.time.Instant
@@ -15,6 +15,7 @@ import scala.language.implicitConversions
import zio.*
import zio.test.*
import zio.test.Assertion.*
+import org.hyperledger.identus.castor.core.model.ProtoModelHelper
object ProtoModelHelperSpec extends ZIOSpecDefault {
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/DIDSpec.scala b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/DIDSpec.scala
similarity index 98%
rename from castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/DIDSpec.scala
rename to castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/DIDSpec.scala
index b5cbb49104..90781225e2 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/DIDSpec.scala
+++ b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/DIDSpec.scala
@@ -1,9 +1,10 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
import zio.*
import zio.test.*
import zio.test.Assertion.*
-import io.iohk.atala.castor.core.util.GenUtils
+import org.hyperledger.identus.castor.core.util.GenUtils
+import org.hyperledger.identus.castor.core.model.did.{DID, PrismDID}
object DIDSpec extends ZIOSpecDefault {
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/PrismDIDSpec.scala b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/PrismDIDSpec.scala
similarity index 95%
rename from castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/PrismDIDSpec.scala
rename to castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/PrismDIDSpec.scala
index 71dfdb5e4e..54a18c23ed 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/PrismDIDSpec.scala
+++ b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/PrismDIDSpec.scala
@@ -1,12 +1,13 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
import com.google.protobuf.ByteString
import io.iohk.atala.prism.crypto.{Sha256, Sha256Digest}
import io.iohk.atala.prism.protos.node_models
-import io.iohk.atala.shared.models.Base64UrlString
+import org.hyperledger.identus.shared.models.Base64UrlString
import zio.*
import zio.test.*
import zio.test.Assertion.*
+import org.hyperledger.identus.castor.core.model.did.PrismDID
object PrismDIDSpec extends ZIOSpecDefault {
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/ServiceEndpointSpec.scala b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/ServiceEndpointSpec.scala
similarity index 88%
rename from castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/ServiceEndpointSpec.scala
rename to castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/ServiceEndpointSpec.scala
index 4c73a9871b..5a2bc72bb2 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/ServiceEndpointSpec.scala
+++ b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/ServiceEndpointSpec.scala
@@ -1,8 +1,9 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
import zio.*
import zio.test.*
import zio.test.Assertion.*
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint
object ServiceEndpointSpec extends ZIOSpecDefault {
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/ServiceTypeSpec.scala b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/ServiceTypeSpec.scala
similarity index 93%
rename from castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/ServiceTypeSpec.scala
rename to castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/ServiceTypeSpec.scala
index 844f9945dc..f1868c8fed 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/ServiceTypeSpec.scala
+++ b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/ServiceTypeSpec.scala
@@ -1,8 +1,9 @@
-package io.iohk.atala.castor.core.model.did
+package org.hyperledger.identus.castor.core.model.did
import zio.*
import zio.test.*
import zio.test.Assertion.*
+import org.hyperledger.identus.castor.core.model.did.ServiceType
object ServiceTypeSpec extends ZIOSpecDefault {
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelperSpec.scala b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/w3c/W3CModelHelperSpec.scala
similarity index 95%
rename from castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelperSpec.scala
rename to castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/w3c/W3CModelHelperSpec.scala
index f24a54f88f..57f874f451 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/model/did/w3c/W3CModelHelperSpec.scala
+++ b/castor/src/test/scala/org/hyperledger/identus/castor/core/model/did/w3c/W3CModelHelperSpec.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.castor.core.model.did.w3c
+package org.hyperledger.identus.castor.core.model.did.w3c
-import io.iohk.atala.castor.core.model.did.{
+import org.hyperledger.identus.castor.core.model.did.{
CanonicalPrismDID,
DIDData,
InternalKeyPurpose,
@@ -8,10 +8,11 @@ import io.iohk.atala.castor.core.model.did.{
PrismDIDOperation,
VerificationRelationship
}
-import io.iohk.atala.castor.core.util.GenUtils
+import org.hyperledger.identus.castor.core.util.GenUtils
import zio.*
import zio.test.*
import zio.test.Assertion.*
+import org.hyperledger.identus.castor.core.model.did.w3c.W3CModelHelper
object W3CModelHelperSpec extends ZIOSpecDefault {
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/service/DIDServiceSpec.scala b/castor/src/test/scala/org/hyperledger/identus/castor/core/service/DIDServiceSpec.scala
similarity index 93%
rename from castor/lib/core/src/test/scala/io/iohk/atala/castor/core/service/DIDServiceSpec.scala
rename to castor/src/test/scala/org/hyperledger/identus/castor/core/service/DIDServiceSpec.scala
index ed5259dd76..3935bff5f5 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/service/DIDServiceSpec.scala
+++ b/castor/src/test/scala/org/hyperledger/identus/castor/core/service/DIDServiceSpec.scala
@@ -1,9 +1,10 @@
-package io.iohk.atala.castor.core.service
+package org.hyperledger.identus.castor.core.service
import com.google.protobuf.ByteString
-import io.iohk.atala.castor.core.model.did.{DIDData, PrismDID, PrismDIDOperation}
-import io.iohk.atala.castor.core.model.error.DIDResolutionError
-import io.iohk.atala.castor.core.util.{DIDOperationValidator, GenUtils}
+import org.hyperledger.identus.castor.core.model.did.{DIDData, PrismDID, PrismDIDOperation}
+import org.hyperledger.identus.castor.core.model.error.DIDResolutionError
+import org.hyperledger.identus.castor.core.util.{GenUtils}
+import org.hyperledger.identus.castor.core.util.DIDOperationValidator
import io.iohk.atala.prism.protos.common_models.{HealthCheckRequest, HealthCheckResponse}
import io.iohk.atala.prism.protos.node_api
import io.iohk.atala.prism.protos.node_models
@@ -31,6 +32,7 @@ import zio.test.*
import zio.test.Assertion.*
import scala.concurrent.Future
+import org.hyperledger.identus.castor.core.service.{DIDService, DIDServiceImpl}
object DIDServiceSpec extends ZIOSpecDefault {
@@ -43,7 +45,7 @@ object DIDServiceSpec extends ZIOSpecDefault {
private def mockNodeService(
createOperation: PrismDIDOperation.Create
): ULayer[node_api.NodeServiceGrpc.NodeService] = {
- import io.iohk.atala.castor.core.model.ProtoModelHelper.*
+ import org.hyperledger.identus.castor.core.model.ProtoModelHelper.*
val operationProto = createOperation.toProto
val didData = node_models.DIDData(
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/DIDOperationValidatorSpec.scala b/castor/src/test/scala/org/hyperledger/identus/castor/core/util/DIDOperationValidatorSpec.scala
similarity index 98%
rename from castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/DIDOperationValidatorSpec.scala
rename to castor/src/test/scala/org/hyperledger/identus/castor/core/util/DIDOperationValidatorSpec.scala
index a4477f4df5..12fb2cf02a 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/DIDOperationValidatorSpec.scala
+++ b/castor/src/test/scala/org/hyperledger/identus/castor/core/util/DIDOperationValidatorSpec.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.castor.core.util
+package org.hyperledger.identus.castor.core.util
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.castor.core.model.error.OperationValidationError
-import io.iohk.atala.castor.core.util.DIDOperationValidator.Config
-import io.iohk.atala.shared.models.Base64UrlString
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.castor.core.model.error.OperationValidationError
+import org.hyperledger.identus.castor.core.util.DIDOperationValidator.Config
+import org.hyperledger.identus.shared.models.Base64UrlString
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/GenUtils.scala b/castor/src/test/scala/org/hyperledger/identus/castor/core/util/GenUtils.scala
similarity index 90%
rename from castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/GenUtils.scala
rename to castor/src/test/scala/org/hyperledger/identus/castor/core/util/GenUtils.scala
index f1e911498b..5113a2f015 100644
--- a/castor/lib/core/src/test/scala/io/iohk/atala/castor/core/util/GenUtils.scala
+++ b/castor/src/test/scala/org/hyperledger/identus/castor/core/util/GenUtils.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.castor.core.util
+package org.hyperledger.identus.castor.core.util
import io.circe.Json
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriValue
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.models.Base64UrlString
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint.UriValue
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.models.Base64UrlString
import zio.*
import zio.test.Gen
diff --git a/prism-agent/client/.gitignore b/cloud-agent/client/.gitignore
similarity index 100%
rename from prism-agent/client/.gitignore
rename to cloud-agent/client/.gitignore
diff --git a/prism-agent/client/README.md b/cloud-agent/client/README.md
similarity index 100%
rename from prism-agent/client/README.md
rename to cloud-agent/client/README.md
diff --git a/prism-agent/client/generator/clean.sh b/cloud-agent/client/generator/clean.sh
similarity index 100%
rename from prism-agent/client/generator/clean.sh
rename to cloud-agent/client/generator/clean.sh
diff --git a/cloud-agent/client/generator/generate-clients.sh b/cloud-agent/client/generator/generate-clients.sh
new file mode 100755
index 0000000000..c937a2a9c6
--- /dev/null
+++ b/cloud-agent/client/generator/generate-clients.sh
@@ -0,0 +1,20 @@
+#!/bin/bash
+set -e
+
+# generate kotlin models
+yarn openapi-generator-cli generate \
+ -g kotlin \
+ -i ../../service/api/http/cloud-agent-openapi-spec.yaml \
+ -o ../kotlin \
+ --ignore-file-override ../kotlin/.openapi-generator-ignore \
+ --additional-properties=packageName=io.iohk.atala.prism,serializationLibrary=gson,enumPropertyNaming=UPPERCASE
+
+# generate typescript models
+yarn openapi-generator-cli generate \
+ -g typescript \
+ -i ../../service/api/http/cloud-agent-openapi-spec.yaml \
+ -o ../typescript \
+ --ignore-file-override ../typescript/.openapi-generator-ignore
+
+# generate python models
+# yarn openapi-generator-cli generate -g python -i oas.yml --skip-validate-spec -o ../python --ignore-file-override ../python/.openapi-generator-ignore
diff --git a/prism-agent/client/generator/openapitools.json b/cloud-agent/client/generator/openapitools.json
similarity index 100%
rename from prism-agent/client/generator/openapitools.json
rename to cloud-agent/client/generator/openapitools.json
diff --git a/prism-agent/client/generator/package.json b/cloud-agent/client/generator/package.json
similarity index 92%
rename from prism-agent/client/generator/package.json
rename to cloud-agent/client/generator/package.json
index 12a07a2520..79c2bf504e 100644
--- a/prism-agent/client/generator/package.json
+++ b/cloud-agent/client/generator/package.json
@@ -1,5 +1,5 @@
{
- "name": "prism-agent-clients-generator",
+ "name": "cloud-agent-clients-generator",
"version": "1.0.0",
"description": "Generates the clients based on the OAS for many languages",
"author": "Allain Magyar",
diff --git a/cloud-agent/client/generator/publish-clients.sh b/cloud-agent/client/generator/publish-clients.sh
new file mode 100755
index 0000000000..820e5aa3e2
--- /dev/null
+++ b/cloud-agent/client/generator/publish-clients.sh
@@ -0,0 +1,16 @@
+#!/bin/bash
+set -e
+
+AGENT_VERSION=${VERSION_TAG:13}
+
+# install dependencies
+yarn
+
+# kotlin
+gradle -p ../kotlin -Pversion=${AGENT_VERSION} publish
+
+# typescript
+yarn --cwd ../typescript
+yarn --cwd ../typescript publish --new-version ${AGENT_VERSION} --no-git-tag-version
+
+# python
diff --git a/prism-agent/client/generator/yarn.lock b/cloud-agent/client/generator/yarn.lock
similarity index 100%
rename from prism-agent/client/generator/yarn.lock
rename to cloud-agent/client/generator/yarn.lock
diff --git a/prism-agent/client/kotlin/.openapi-generator-ignore b/cloud-agent/client/kotlin/.openapi-generator-ignore
similarity index 100%
rename from prism-agent/client/kotlin/.openapi-generator-ignore
rename to cloud-agent/client/kotlin/.openapi-generator-ignore
diff --git a/prism-agent/client/kotlin/build.gradle b/cloud-agent/client/kotlin/build.gradle
similarity index 100%
rename from prism-agent/client/kotlin/build.gradle
rename to cloud-agent/client/kotlin/build.gradle
diff --git a/prism-agent/client/kotlin/gradle.properties b/cloud-agent/client/kotlin/gradle.properties
similarity index 100%
rename from prism-agent/client/kotlin/gradle.properties
rename to cloud-agent/client/kotlin/gradle.properties
diff --git a/prism-agent/client/kotlin/gradle/wrapper/gradle-wrapper.jar b/cloud-agent/client/kotlin/gradle/wrapper/gradle-wrapper.jar
similarity index 100%
rename from prism-agent/client/kotlin/gradle/wrapper/gradle-wrapper.jar
rename to cloud-agent/client/kotlin/gradle/wrapper/gradle-wrapper.jar
diff --git a/prism-agent/client/kotlin/gradle/wrapper/gradle-wrapper.properties b/cloud-agent/client/kotlin/gradle/wrapper/gradle-wrapper.properties
similarity index 100%
rename from prism-agent/client/kotlin/gradle/wrapper/gradle-wrapper.properties
rename to cloud-agent/client/kotlin/gradle/wrapper/gradle-wrapper.properties
diff --git a/prism-agent/client/kotlin/gradlew b/cloud-agent/client/kotlin/gradlew
similarity index 100%
rename from prism-agent/client/kotlin/gradlew
rename to cloud-agent/client/kotlin/gradlew
diff --git a/prism-agent/client/kotlin/gradlew.bat b/cloud-agent/client/kotlin/gradlew.bat
similarity index 100%
rename from prism-agent/client/kotlin/gradlew.bat
rename to cloud-agent/client/kotlin/gradlew.bat
diff --git a/prism-agent/client/kotlin/settings.gradle b/cloud-agent/client/kotlin/settings.gradle
similarity index 100%
rename from prism-agent/client/kotlin/settings.gradle
rename to cloud-agent/client/kotlin/settings.gradle
diff --git a/prism-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/CredentialSubject.kt b/cloud-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/CredentialSubject.kt
similarity index 96%
rename from prism-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/CredentialSubject.kt
rename to cloud-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/CredentialSubject.kt
index ecd87cc164..dc0ae8c901 100644
--- a/prism-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/CredentialSubject.kt
+++ b/cloud-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/CredentialSubject.kt
@@ -13,7 +13,7 @@
"UnusedImport"
)
-package io.iohk.atala.prism.models
+package org.hyperledger.identus.prism.models
import com.google.gson.annotations.SerializedName
diff --git a/prism-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/Service.kt b/cloud-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/Service.kt
similarity index 91%
rename from prism-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/Service.kt
rename to cloud-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/Service.kt
index 95592cba35..806e3d4025 100644
--- a/prism-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/Service.kt
+++ b/cloud-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/Service.kt
@@ -13,9 +13,9 @@
"UnusedImport"
)
-package io.iohk.atala.prism.models
+package org.hyperledger.identus.prism.models
-import io.iohk.atala.prism.models.Json
+import org.hyperledger.identus.prism.models.Json
import com.google.gson.annotations.SerializedName
diff --git a/prism-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/UpdateManagedDIDServiceAction.kt b/cloud-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/UpdateManagedDIDServiceAction.kt
similarity index 89%
rename from prism-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/UpdateManagedDIDServiceAction.kt
rename to cloud-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/UpdateManagedDIDServiceAction.kt
index f9c1c5e2b4..494146bcf1 100644
--- a/prism-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/UpdateManagedDIDServiceAction.kt
+++ b/cloud-agent/client/kotlin/src/main/kotlin/io/iohk/atala/prism/models/UpdateManagedDIDServiceAction.kt
@@ -13,9 +13,9 @@
"UnusedImport"
)
-package io.iohk.atala.prism.models
+package org.hyperledger.identus.prism.models
-import io.iohk.atala.prism.models.Json
+import org.hyperledger.identus.prism.models.Json
import com.google.gson.annotations.SerializedName
diff --git a/prism-agent/client/python/.openapi-generator-ignore b/cloud-agent/client/python/.openapi-generator-ignore
similarity index 100%
rename from prism-agent/client/python/.openapi-generator-ignore
rename to cloud-agent/client/python/.openapi-generator-ignore
diff --git a/prism-agent/client/python/setup.py b/cloud-agent/client/python/setup.py
similarity index 100%
rename from prism-agent/client/python/setup.py
rename to cloud-agent/client/python/setup.py
diff --git a/prism-agent/client/typescript/.openapi-generator-ignore b/cloud-agent/client/typescript/.openapi-generator-ignore
similarity index 100%
rename from prism-agent/client/typescript/.openapi-generator-ignore
rename to cloud-agent/client/typescript/.openapi-generator-ignore
diff --git a/prism-agent/client/typescript/models/Service.ts b/cloud-agent/client/typescript/models/Service.ts
similarity index 100%
rename from prism-agent/client/typescript/models/Service.ts
rename to cloud-agent/client/typescript/models/Service.ts
diff --git a/prism-agent/client/typescript/models/UpdateManagedDIDServiceAction.ts b/cloud-agent/client/typescript/models/UpdateManagedDIDServiceAction.ts
similarity index 100%
rename from prism-agent/client/typescript/models/UpdateManagedDIDServiceAction.ts
rename to cloud-agent/client/typescript/models/UpdateManagedDIDServiceAction.ts
diff --git a/prism-agent/client/typescript/package.json b/cloud-agent/client/typescript/package.json
similarity index 100%
rename from prism-agent/client/typescript/package.json
rename to cloud-agent/client/typescript/package.json
diff --git a/prism-agent/service/CHANGELOG.md b/cloud-agent/service/CHANGELOG.md
similarity index 100%
rename from prism-agent/service/CHANGELOG.md
rename to cloud-agent/service/CHANGELOG.md
diff --git a/prism-agent/service/README.md b/cloud-agent/service/README.md
similarity index 100%
rename from prism-agent/service/README.md
rename to cloud-agent/service/README.md
diff --git a/prism-agent/service/api/http/prism-agent-openapi-spec.yaml b/cloud-agent/service/api/http/cloud-agent-openapi-spec.yaml
similarity index 64%
rename from prism-agent/service/api/http/prism-agent-openapi-spec.yaml
rename to cloud-agent/service/api/http/cloud-agent-openapi-spec.yaml
index e21bba00ee..d0076a76b7 100644
--- a/prism-agent/service/api/http/prism-agent-openapi-spec.yaml
+++ b/cloud-agent/service/api/http/cloud-agent-openapi-spec.yaml
@@ -1,24 +1,24 @@
openapi: 3.0.3
info:
- title: Open Enterprise Agent API Reference
+ title: Identus Cloud Agent API Reference
version: 1.31.0
description: |2
- The Open Enterprise Agent API facilitates the integration and management of self-sovereign identity capabilities within applications.
+ The Identus Cloud Agent API facilitates the integration and management of self-sovereign identity capabilities within applications.
It supports DID (Decentralized Identifiers) management, verifiable credential exchange, and secure messaging based on DIDComm standards.
The API is designed to be interoperable with various blockchain and DLT (Distributed Ledger Technology) platforms, ensuring wide compatibility and flexibility.
Key features include connection management, credential issuance and verification, and secure, privacy-preserving communication between entities.
- Additional information and the full list of capabilities can be found in the [Open Enterprise Agent documentation](https://docs.atalaprism.io/docs/category/prism-cloud-agent)
+ Additional information and the full list of capabilities can be found in the [Identus Cloud Agent documentation](https://docs.atalaprism.io/docs/category/prism-cloud-agent)
termsOfService: |2
- Users of the Open Enterprise Agent API must adhere to the terms and conditions outlined in [Link to Terms of Service](/).
+ Users of the Identus Cloud Agent API must adhere to the terms and conditions outlined in [Link to Terms of Service](/).
This includes compliance with relevant data protection regulations, responsible usage policies, and adherence to the principles of decentralized identity management.
license:
name: Apache 2.0
url: https://www.apache.org/licenses/LICENSE-2.0
tags:
-- name: Connections Management
- description: |2
+ - name: Connections Management
+ description: |2
The __Connections Management__ endpoints facilitate the initiation of connection flows between the current Agent and peer Agents, regardless of whether they reside in Cloud Agent or edge environments.
This implementation adheres to the DIDComm Messaging v2.0 - [Out of Band Messages](https://identity.foundation/didcomm-messaging/spec/v2.0/#out-of-band-messages) specification [section 9.5.4](https://identity.foundation/didcomm-messaging/spec/v2.0/#invitation) - to generate invitations.
@@ -27,9 +27,9 @@ tags:
Upon accepting an invitation, the invitee sends a connection request to the inviter's DIDComm messaging service endpoint.
The connection request's 'type' attribute must be specified as "https://atalaprism.io/mercury/connections/1.0/request".
The inviter agent responds with a connection response message, indicated by a 'type' attribute of "https://atalaprism.io/mercury/connections/1.0/response".
- Both request and response types are proprietary to the Open Enterprise Agent ecosystem.
-- name: Issue Credentials Protocol
- description: |2
+ Both request and response types are proprietary to the Identus Cloud Agent ecosystem.
+ - name: Issue Credentials Protocol
+ description: |2
The __Issue Credentials Protocol__ endpoints facilitate the initiation of credential issuance flows between the current Agent and peer Agents, regardless of whether they reside in Cloud Agent or edge environments.
This implementation adheres to the [Issue Credential Protocol 3.0](https://github.com/decentralized-identity/waci-didcomm/tree/main/issue_credential) specification to execute credential issuance flows.
@@ -37,8 +37,8 @@ tags:
Upon accepting the received offer, the holder sends a [credential request](https://github.com/decentralized-identity/waci-didcomm/tree/main/issue_credential#request-credential) to the issuer.
The issuer agent will then issue the credential (JWT or AnonCreds) and send an [issue credential](https://github.com/decentralized-identity/waci-didcomm/tree/main/issue_credential#issue-credential) message containing the verifiable credential to the holder.
The current implementation only supports one of the three alternative beginnings proposed in the spec, which is "the Issuer begin with an offer".
-- name: Verification
- description: |2-
+ - name: Verification
+ description: |2-
The __Verification__ endpoints enable the management and lookup of verification policies,which are applied to W3C Verifiable Credentials in JWT format.
@@ -49,8 +49,8 @@ tags:
This functionality ensures the system's integrity and adherence to specific verification requirements.
Endpoints are secured by __apiKeyAuth__ or __jwtAuth__ authentication.
-- name: Schema Registry
- description: |2
+ - name: Schema Registry
+ description: |2
The __Schema Registry__ is a REST API that allows to publish and lookup credential schemas in [W3C](https://w3c.github.io/vc-json-schema/) and [AnonCreds](https://hyperledger.github.io/anoncreds-spec/#term:schema) formats.
@@ -72,11 +72,11 @@ tags:
The __Credential Schema__ is referenced via `schemaId` field in the issuance and verification flows.
Endpoints are secured by __apiKeyAuth__ or __jwtAuth__ authentication.
- externalDocs:
- url: https://docs.atalaprism.io/tutorials/schemas/credential-schema
- description: Credential Schema documentation
-- name: Credential Definition Registry
- description: |2
+ externalDocs:
+ url: https://docs.atalaprism.io/tutorials/schemas/credential-schema
+ description: Credential Schema documentation
+ - name: Credential Definition Registry
+ description: |2
The __Credential Definition Registry__ is a REST API that allows to publish and lookup [Anoncreds Credential Definition](https://hyperledger.github.io/anoncreds-spec/#term:credential-definition) entities.
@@ -85,19 +85,19 @@ tags:
The secret data includes the private keys necessary to generate signed verifiable credentials that can be presented and verified using the published credential definition.
Endpoints are secured by __apiKeyAuth__ or __jwtAuth__ authentication.
- externalDocs:
- url: https://docs.atalaprism.io/tutorials/category/credential-definition
- description: Credential Definition documentation
-- name: DID
- description: |2
+ externalDocs:
+ url: https://docs.atalaprism.io/tutorials/category/credential-definition
+ description: Credential Definition documentation
+ - name: DID
+ description: |2
The __DID__ endpoints expose publicly available DID operations.
The key distinction from the __DID Registrar__ endpoints is that it directly exposes the DID resources interfacing with the [VDR](https://www.w3.org/TR/did-core/#dfn-verifiable-data-registry).
It is independent of the key management and the exposed operations are not part of the tenancy within the Agent.
It serves as a proxy for interacting with the VDR, facilitating actions like resolving DIDs.
-- name: DID Registrar
- description: |2
+ - name: DID Registrar
+ description: |2
The __DID Registrar__ endpoints facilitate the management of [PRISM DIDs](https://github.com/input-output-hk/prism-did-method-spec) hosted in the cloud agent.
@@ -107,8 +107,8 @@ tags:
These DIDs can be utilized for various operations during issuance and verification processes.
More examples and tutorials can be found in this [documentation](https://docs.atalaprism.io/tutorials/category/dids/).
-- name: Wallet Management
- description: |2
+ - name: Wallet Management
+ description: |2
The __Wallet Management__ endpoints enable both users and administrators to manage [wallets](https://docs.atalaprism.io/docs/concepts/multi-tenancy#wallet).
@@ -121,8 +121,8 @@ tags:
Wallet permissions are controlled by [UMA](https://docs.atalaprism.io/docs/concepts/glossary#uma) configuration which the agent
exposes endpoints to easily configure wallet access using `uma-permissions` resource.
The permissions can also be configured out-of-band directly on the external IAM provider that supports the UMA standard.
-- name: System
- description: |2
+ - name: System
+ description: |2
The __System__ is a REST API that allows to check the system health and scrap the runtime metrics.
@@ -132,94 +132,98 @@ tags:
The __metrics__ endpoint returns the runtime metrics of the running service scraped from the internal prometheus registry.
This information is collected by the prometheus server and can be used to monitor the running service.
servers:
-- url: http://localhost:8085
- description: Local Prism Agent
-- url: http://localhost/prism-agent
- description: Local Prism Agent with APISIX proxy
-- url: https://k8s-dev.atalaprism.io/prism-agent
- description: Prism Agent on the Staging Environment
+ - url: http://localhost:8085
+ description: Local Prism Agent
+ - url: http://localhost/prism-agent
+ description: Local Prism Agent with APISIX proxy
+ - url: https://k8s-dev.atalaprism.io/prism-agent
+ description: Prism Agent on the Staging Environment
paths:
/credential-definition-registry/definitions:
get:
tags:
- - Credential Definition Registry
+ - Credential Definition Registry
summary: Lookup credential definitions by indexed fields
- description: 'Lookup credential definitions by `author`, `name`, `tag` parameters
- and control the pagination by `offset` and `limit` parameters '
+ description:
+ "Lookup credential definitions by `author`, `name`, `tag` parameters
+ and control the pagination by `offset` and `limit` parameters "
operationId: lookupCredentialDefinitionsByQuery
parameters:
- - name: author
- in: query
- required: false
- schema:
- type: string
- example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
- - name: name
- in: query
- required: false
- schema:
- type: string
- example: DrivingLicense
- - name: version
- in: query
- required: false
- schema:
- type: string
- example: 1.0.0
- - name: tag
- in: query
- required: false
- schema:
- type: string
- example: licence
- - name: offset
- in: query
- description: The number of items to skip before returning results. Default
- is 0 if not specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: limit
- in: query
- description: The maximum number of items to return. Defaults to 100 if not
- specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: order
- in: query
- required: false
- schema:
- type: string
+ - name: author
+ in: query
+ required: false
+ schema:
+ type: string
+ example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
+ - name: name
+ in: query
+ required: false
+ schema:
+ type: string
+ example: DrivingLicense
+ - name: version
+ in: query
+ required: false
+ schema:
+ type: string
+ example: 1.0.0
+ - name: tag
+ in: query
+ required: false
+ schema:
+ type: string
+ example: licence
+ - name: offset
+ in: query
+ description:
+ The number of items to skip before returning results. Default
+ is 0 if not specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: limit
+ in: query
+ description:
+ The maximum number of items to return. Defaults to 100 if not
+ specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: order
+ in: query
+ required: false
+ schema:
+ type: string
responses:
- '200':
+ "200":
description: Collection of CredentialDefinitions records.
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialDefinitionResponsePage'
- '400':
+ $ref: "#/components/schemas/CredentialDefinitionResponsePage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
post:
tags:
- - Credential Definition Registry
+ - Credential Definition Registry
summary: Publish new definition to the definition registry
- description: Create the new credential definition record with metadata and internal
+ description:
+ Create the new credential definition record with metadata and internal
JSON Schema on behalf of Cloud Agent. The credential definition will be signed
by the keys of Cloud Agent and issued by the DID that corresponds to it.
operationId: createCredentialDefinition
@@ -228,209 +232,215 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialDefinitionInput'
+ $ref: "#/components/schemas/CredentialDefinitionInput"
required: true
responses:
- '201':
+ "201":
description: The new credential definition record is successfully created
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialDefinitionResponse'
- '400':
+ $ref: "#/components/schemas/CredentialDefinitionResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/credential-definition-registry/definitions/{guid}:
get:
tags:
- - Credential Definition Registry
+ - Credential Definition Registry
summary: Fetch the credential definition from the registry by `guid`
description: Fetch the credential definition by the unique identifier
operationId: getCredentialDefinitionById
parameters:
- - name: guid
- in: path
- description: Globally unique identifier of the credential definition record
- required: true
- schema:
- type: string
- format: uuid
+ - name: guid
+ in: path
+ description: Globally unique identifier of the credential definition record
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: CredentialDefinition found by `guid`
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialDefinitionResponse'
- '400':
+ $ref: "#/components/schemas/CredentialDefinitionResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
/credential-definition-registry/definitions/{guid}/definition:
get:
tags:
- - Credential Definition Registry
- summary: Fetch the inner definition field of the credential definition from
+ - Credential Definition Registry
+ summary:
+ Fetch the inner definition field of the credential definition from
the registry by `guid`
- description: Fetch the inner definition fields of the credential definition
+ description:
+ Fetch the inner definition fields of the credential definition
by the unique identifier
operationId: getCredentialDefinitionInnerDefinitionById
parameters:
- - name: guid
- in: path
- required: true
- schema:
- type: string
- format: uuid
+ - name: guid
+ in: path
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: CredentialDefinition found by `guid`
content:
application/json:
schema: {}
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
/schema-registry/schemas:
get:
tags:
- - Schema Registry
+ - Schema Registry
summary: Lookup schemas by indexed fields
- description: 'Lookup schemas by `author`, `name`, `tags` parameters and control
- the pagination by `offset` and `limit` parameters '
+ description:
+ "Lookup schemas by `author`, `name`, `tags` parameters and control
+ the pagination by `offset` and `limit` parameters "
operationId: lookupSchemasByQuery
parameters:
- - name: author
- in: query
- required: false
- schema:
- type: string
- example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
- - name: name
- in: query
- required: false
- schema:
- type: string
- example: DrivingLicense
- - name: version
- in: query
- required: false
- schema:
- type: string
- example: 1.0.0
- - name: tags
- in: query
- required: false
- schema:
- type: string
- example: driving
- - name: offset
- in: query
- description: The number of items to skip before returning results. Default
- is 0 if not specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: limit
- in: query
- description: The maximum number of items to return. Defaults to 100 if not
- specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: order
- in: query
- required: false
- schema:
- type: string
+ - name: author
+ in: query
+ required: false
+ schema:
+ type: string
+ example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
+ - name: name
+ in: query
+ required: false
+ schema:
+ type: string
+ example: DrivingLicense
+ - name: version
+ in: query
+ required: false
+ schema:
+ type: string
+ example: 1.0.0
+ - name: tags
+ in: query
+ required: false
+ schema:
+ type: string
+ example: driving
+ - name: offset
+ in: query
+ description:
+ The number of items to skip before returning results. Default
+ is 0 if not specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: limit
+ in: query
+ description:
+ The maximum number of items to return. Defaults to 100 if not
+ specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: order
+ in: query
+ required: false
+ schema:
+ type: string
responses:
- '200':
+ "200":
description: Collection of CredentialSchema records.
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialSchemaResponsePage'
- '400':
+ $ref: "#/components/schemas/CredentialSchemaResponsePage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
post:
tags:
- - Schema Registry
+ - Schema Registry
summary: Publish new schema to the schema registry
- description: Create the new credential schema record with metadata and internal
+ description:
+ Create the new credential schema record with metadata and internal
JSON Schema on behalf of Cloud Agent. The credential schema will be signed
by the keys of Cloud Agent and issued by the DID that corresponds to it.
operationId: createSchema
@@ -439,251 +449,256 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialSchemaInput'
+ $ref: "#/components/schemas/CredentialSchemaInput"
required: true
responses:
- '201':
+ "201":
description: The new credential schema record is successfully created
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialSchemaResponse'
- '400':
+ $ref: "#/components/schemas/CredentialSchemaResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/schema-registry/{author}/{id}:
put:
tags:
- - Schema Registry
+ - Schema Registry
summary: Publish the new version of the credential schema to the schema registry
- description: Publish the new version of the credential schema record with metadata
+ description:
+ Publish the new version of the credential schema record with metadata
and internal JSON Schema on behalf of Cloud Agent. The credential schema will
be signed by the keys of Cloud Agent and issued by the DID that corresponds
to it.
operationId: updateSchema
parameters:
- - name: author
- in: path
- description: DID of the identity which authored the credential schema. A piece
- of Metadata.
- required: true
- schema:
- type: string
- - name: id
- in: path
- description: A locally unique identifier to address the schema. UUID is generated
- by the backend.
- required: true
- schema:
- type: string
- format: uuid
+ - name: author
+ in: path
+ description:
+ DID of the identity which authored the credential schema. A piece
+ of Metadata.
+ required: true
+ schema:
+ type: string
+ - name: id
+ in: path
+ description:
+ A locally unique identifier to address the schema. UUID is generated
+ by the backend.
+ required: true
+ schema:
+ type: string
+ format: uuid
requestBody:
description: JSON object required for the credential schema update
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialSchemaInput'
+ $ref: "#/components/schemas/CredentialSchemaInput"
required: true
responses:
- '200':
+ "200":
description: The credential schema record is successfully updated
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialSchemaResponse'
- '400':
+ $ref: "#/components/schemas/CredentialSchemaResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/schema-registry/schemas/{guid}:
get:
tags:
- - Schema Registry
+ - Schema Registry
summary: Fetch the schema from the registry by `guid`
description: Fetch the credential schema by the unique identifier
operationId: getSchemaById
parameters:
- - name: guid
- in: path
- description: Globally unique identifier of the credential schema record
- required: true
- schema:
- type: string
- format: uuid
+ - name: guid
+ in: path
+ description: Globally unique identifier of the credential schema record
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: CredentialSchema found by `guid`
content:
application/json:
schema:
- $ref: '#/components/schemas/CredentialSchemaResponse'
- '400':
+ $ref: "#/components/schemas/CredentialSchemaResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
/schema-registry/schemas/{guid}/schema:
get:
tags:
- - Schema Registry
+ - Schema Registry
summary: Fetch the schema from the registry by `guid`
description: Fetch the credential schema by the unique identifier
operationId: getRawSchemaById
parameters:
- - name: guid
- in: path
- required: true
- schema:
- type: string
- format: uuid
+ - name: guid
+ in: path
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: Raw JSON response of the CredentialSchema
content:
application/json:
schema: {}
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
/verification/policies:
get:
tags:
- - Verification
+ - Verification
summary: Lookup verification policies by query
- description: Lookup verification policies by `name`, and control the pagination
+ description:
+ Lookup verification policies by `name`, and control the pagination
by `offset` and `limit` parameters
operationId: lookupVerificationPoliciesByQuery
parameters:
- - name: name
- in: query
- description: A human-readable name for the verification policy. The `name`
- cannot be empty.
- required: false
- schema:
- type: string
- - name: offset
- in: query
- required: false
- schema:
- type: integer
- format: int32
- - name: limit
- in: query
- required: false
- schema:
- type: integer
- format: int32
- - name: order
- in: query
- required: false
- schema:
- type: string
+ - name: name
+ in: query
+ description:
+ A human-readable name for the verification policy. The `name`
+ cannot be empty.
+ required: false
+ schema:
+ type: string
+ - name: offset
+ in: query
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: limit
+ in: query
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: order
+ in: query
+ required: false
+ schema:
+ type: string
responses:
- '200':
- description: ''
+ "200":
+ description: ""
content:
application/json:
schema:
- $ref: '#/components/schemas/VerificationPolicyResponsePage'
- '400':
+ $ref: "#/components/schemas/VerificationPolicyResponsePage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
post:
tags:
- - Verification
+ - Verification
summary: Create the new verification policy
description: Create the new verification policy
operationId: createVerificationPolicy
@@ -692,195 +707,196 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/VerificationPolicyInput'
+ $ref: "#/components/schemas/VerificationPolicyInput"
required: true
responses:
- '201':
+ "201":
description: Created verification policy entity
content:
application/json:
schema:
- $ref: '#/components/schemas/VerificationPolicyResponse'
- '400':
+ $ref: "#/components/schemas/VerificationPolicyResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/verification/policies/{id}:
get:
tags:
- - Verification
+ - Verification
summary: Fetch the verification policy by id
description: Get the verification policy by id
operationId: getVerificationPolicyById
parameters:
- - name: id
- in: path
- description: Get the verification policy by id
- required: true
- schema:
- type: string
- format: uuid
+ - name: id
+ in: path
+ description: Get the verification policy by id
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
- description: ''
+ "200":
+ description: ""
content:
application/json:
schema:
- $ref: '#/components/schemas/VerificationPolicyResponse'
- '400':
+ $ref: "#/components/schemas/VerificationPolicyResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
put:
tags:
- - Verification
+ - Verification
summary: Update the verification policy object by id
description: Update the verification policy entry
operationId: updateVerificationPolicy
parameters:
- - name: id
- in: path
- required: true
- schema:
- type: string
- format: uuid
- - name: nonce
- in: query
- description: Nonce of the previous VerificationPolicy
- required: true
- schema:
- type: integer
- format: int32
+ - name: id
+ in: path
+ required: true
+ schema:
+ type: string
+ format: uuid
+ - name: nonce
+ in: query
+ description: Nonce of the previous VerificationPolicy
+ required: true
+ schema:
+ type: integer
+ format: int32
requestBody:
description: Update verification policy object
content:
application/json:
schema:
- $ref: '#/components/schemas/VerificationPolicyInput'
+ $ref: "#/components/schemas/VerificationPolicyInput"
required: true
responses:
- '200':
- description: ''
+ "200":
+ description: ""
content:
application/json:
schema:
- $ref: '#/components/schemas/VerificationPolicyResponse'
- '400':
+ $ref: "#/components/schemas/VerificationPolicyResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
delete:
tags:
- - Verification
+ - Verification
summary: Deleted the verification policy by id
description: Delete the verification policy by id
operationId: deleteVerificationPolicyById
parameters:
- - name: id
- in: path
- description: Delete the verification policy by id
- required: true
- schema:
- type: string
- format: uuid
+ - name: id
+ in: path
+ description: Delete the verification policy by id
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: Verification policy deleted successfully
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/connections:
get:
tags:
- - Connections Management
- summary: Retrieves the list of connection flow records available from the Agent's
+ - Connections Management
+ summary:
+ Retrieves the list of connection flow records available from the Agent's
database.
description: |2
@@ -890,62 +906,67 @@ paths:
Pagination support is available, allowing for efficient handling of large datasets.
operationId: getConnections
parameters:
- - name: offset
- in: query
- description: The number of items to skip before returning results. Default
- is 0 if not specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: limit
- in: query
- description: The maximum number of items to return. Defaults to 100 if not
- specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: thid
- in: query
- description: The `thid`, shared between the inviter and the invitee, that
- uniquely identifies a connection flow.
- required: false
- schema:
- type: string
+ - name: offset
+ in: query
+ description:
+ The number of items to skip before returning results. Default
+ is 0 if not specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: limit
+ in: query
+ description:
+ The maximum number of items to return. Defaults to 100 if not
+ specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: thid
+ in: query
+ description:
+ The `thid`, shared between the inviter and the invitee, that
+ uniquely identifies a connection flow.
+ required: false
+ schema:
+ type: string
responses:
- '200':
- description: The list of connection flow records available from the Agent's
+ "200":
+ description:
+ The list of connection flow records available from the Agent's
database
content:
application/json:
schema:
- $ref: '#/components/schemas/ConnectionsPage'
- '400':
+ $ref: "#/components/schemas/ConnectionsPage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
post:
tags:
- - Connections Management
- summary: Create a new connection invitation that can be delivered out-of-band
+ - Connections Management
+ summary:
+ Create a new connection invitation that can be delivered out-of-band
to a peer Agent.
description: |2
@@ -961,42 +982,44 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/CreateConnectionRequest'
+ $ref: "#/components/schemas/CreateConnectionRequest"
required: true
responses:
- '201':
- description: The connection record was created successfully, and is returned
+ "201":
+ description:
+ The connection record was created successfully, and is returned
in the response body.
content:
application/json:
schema:
- $ref: '#/components/schemas/Connection'
- '400':
+ $ref: "#/components/schemas/Connection"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/connections/{connectionId}:
get:
tags:
- - Connections Management
- summary: Retrieves a specific connection flow record from the Agent's database
+ - Connections Management
+ summary:
+ Retrieves a specific connection flow record from the Agent's database
based on its unique `connectionId`.
description: |2
@@ -1004,52 +1027,53 @@ paths:
The returned item includes essential metadata such as connection ID, thread ID, state, role, participant information, and other relevant details.
operationId: getConnection
parameters:
- - name: connectionId
- in: path
- description: The `connectionId` uniquely identifying the connection flow record.
- required: true
- schema:
- type: string
- format: uuid
+ - name: connectionId
+ in: path
+ description: The `connectionId` uniquely identifying the connection flow record.
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: The specific connection flow record.
content:
application/json:
schema:
- $ref: '#/components/schemas/Connection'
- '400':
+ $ref: "#/components/schemas/Connection"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/connection-invitations:
post:
tags:
- - Connections Management
- summary: Accept a new connection invitation received out-of-band from another
+ - Connections Management
+ summary:
+ Accept a new connection invitation received out-of-band from another
peer Agent.
description: |2
@@ -1060,45 +1084,46 @@ paths:
A connection request will then be sent to the peer Agent to actually establish the connection, moving the record state to `ConnectionRequestSent`, and waiting the connection response from the peer Agent.
operationId: acceptConnectionInvitation
requestBody:
- description: The request used by an invitee to accept a connection invitation
+ description:
+ The request used by an invitee to accept a connection invitation
received from an inviter, using out-of-band mechanism.
content:
application/json:
schema:
- $ref: '#/components/schemas/AcceptConnectionInvitationRequest'
+ $ref: "#/components/schemas/AcceptConnectionInvitationRequest"
required: true
responses:
- '200':
+ "200":
description: The invitation was successfully accepted.
content:
application/json:
schema:
- $ref: '#/components/schemas/Connection'
- '400':
+ $ref: "#/components/schemas/Connection"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/dids/{didRef}:
get:
tags:
- - DID
+ - DID
summary: Resolve Prism DID to a W3C representation
description: |
Resolve Prism DID to a W3C DID document representation.
@@ -1107,141 +1132,143 @@ paths:
The response is implemented according to [resolver HTTP binding](https://w3c-ccg.github.io/did-resolution/#bindings-https) in the DID resolution spec.
operationId: getDID
parameters:
- - name: didRef
- in: path
- description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
- required: true
- schema:
- type: string
- example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
+ - name: didRef
+ in: path
+ description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
+ required: true
+ schema:
+ type: string
+ example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
responses:
- '200':
- description: ''
+ "200":
+ description: ""
content:
application/ld+json; profile=https://w3id.org/did-resolution:
schema:
- $ref: '#/components/schemas/DIDResolutionResult'
+ $ref: "#/components/schemas/DIDResolutionResult"
application/did+ld+json:
schema:
- $ref: '#/components/schemas/DIDDocument'
- '400':
+ $ref: "#/components/schemas/DIDDocument"
+ "400":
description: Invalid value
content:
text/plain:
schema:
type: string
- '404':
- description: ''
+ "404":
+ description: ""
content:
application/ld+json; profile=https://w3id.org/did-resolution:
schema:
- $ref: '#/components/schemas/DIDResolutionResult'
+ $ref: "#/components/schemas/DIDResolutionResult"
application/did+ld+json:
schema:
type: string
description: Empty representation
- example: ''
- '406':
- description: ''
+ example: ""
+ "406":
+ description: ""
content:
application/ld+json; profile=https://w3id.org/did-resolution:
schema:
- $ref: '#/components/schemas/DIDResolutionResult'
+ $ref: "#/components/schemas/DIDResolutionResult"
application/did+ld+json:
schema:
type: string
description: Empty representation
- example: ''
- '410':
- description: ''
+ example: ""
+ "410":
+ description: ""
content:
application/ld+json; profile=https://w3id.org/did-resolution:
schema:
- $ref: '#/components/schemas/DIDResolutionResult'
+ $ref: "#/components/schemas/DIDResolutionResult"
application/did+ld+json:
schema:
type: string
description: Empty representation
- example: ''
- '500':
- description: ''
+ example: ""
+ "500":
+ description: ""
content:
application/ld+json; profile=https://w3id.org/did-resolution:
schema:
- $ref: '#/components/schemas/DIDResolutionResult'
+ $ref: "#/components/schemas/DIDResolutionResult"
application/did+ld+json:
schema:
type: string
description: Empty representation
- example: ''
- '501':
- description: ''
+ example: ""
+ "501":
+ description: ""
content:
application/ld+json; profile=https://w3id.org/did-resolution:
schema:
- $ref: '#/components/schemas/DIDResolutionResult'
+ $ref: "#/components/schemas/DIDResolutionResult"
application/did+ld+json:
schema:
type: string
description: Empty representation
- example: ''
+ example: ""
/did-registrar/dids:
get:
tags:
- - DID Registrar
+ - DID Registrar
summary: List all DIDs stored in the agent's wallet
description: |-
List all DIDs stored in the agent's wallet.
Return a paginated items ordered by created timestamp.
operationId: getDid-registrarDids
parameters:
- - name: offset
- in: query
- description: The number of items to skip before returning results. Default
- is 0 if not specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: limit
- in: query
- description: The maximum number of items to return. Defaults to 100 if not
- specified.
- required: false
- schema:
- type: integer
- format: int32
+ - name: offset
+ in: query
+ description:
+ The number of items to skip before returning results. Default
+ is 0 if not specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: limit
+ in: query
+ description:
+ The maximum number of items to return. Defaults to 100 if not
+ specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
responses:
- '200':
+ "200":
description: List the agent managed DIDs in the wallet
content:
application/json:
schema:
- $ref: '#/components/schemas/ManagedDIDPage'
- '400':
+ $ref: "#/components/schemas/ManagedDIDPage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
post:
tags:
- - DID Registrar
+ - DID Registrar
summary: Create an unpublished PRISM DID and store it in the agent's wallet
description: |-
Create an unpublished PRISM DID and store it in the agent's wallet.
@@ -1253,101 +1280,101 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/CreateManagedDidRequest'
+ $ref: "#/components/schemas/CreateManagedDidRequest"
required: true
responses:
- '201':
+ "201":
description: Created an unpublished PRISM DID
content:
application/json:
schema:
- $ref: '#/components/schemas/CreateManagedDIDResponse'
- '400':
+ $ref: "#/components/schemas/CreateManagedDIDResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '422':
+ $ref: "#/components/schemas/ErrorResponse"
+ "422":
description: Unable to process the request
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/did-registrar/dids/{didRef}:
get:
tags:
- - DID Registrar
+ - DID Registrar
summary: Get a specific DID stored in the agent's wallet
description: Get a specific DID stored in the agent's wallet
operationId: getDid-registrarDidsDidref
parameters:
- - name: didRef
- in: path
- description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
- required: true
- schema:
- type: string
- example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
+ - name: didRef
+ in: path
+ description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
+ required: true
+ schema:
+ type: string
+ example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
responses:
- '200':
+ "200":
description: Get a DID in the agent's wallet
content:
application/json:
schema:
- $ref: '#/components/schemas/ManagedDID'
- '400':
+ $ref: "#/components/schemas/ManagedDID"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/did-registrar/dids/{didRef}/publications:
post:
tags:
- - DID Registrar
+ - DID Registrar
summary: Publish the DID stored in the agent's wallet to the VDR
description: |
Initiate the publication of the DID stored in the agent's wallet to the VDR.
@@ -1358,51 +1385,51 @@ paths:
In case of a failed DID publication, the status is reverted to `CREATED`.
operationId: postDid-registrarDidsDidrefPublications
parameters:
- - name: didRef
- in: path
- description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
- required: true
- schema:
- type: string
- example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
+ - name: didRef
+ in: path
+ description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
+ required: true
+ schema:
+ type: string
+ example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
responses:
- '202':
+ "202":
description: Publishing DID to the VDR initiated
content:
application/json:
schema:
- $ref: '#/components/schemas/DIDOperationResponse'
- '400':
+ $ref: "#/components/schemas/DIDOperationResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/did-registrar/dids/{didRef}/updates:
post:
tags:
- - DID Registrar
+ - DID Registrar
summary: Update DID in the agent's wallet and post update operation to the VDR
description: |-
Update DID in the agent's wallet and post the update operation to the VDR.
@@ -1412,70 +1439,71 @@ paths:
a new update request if the previous operation is not yet comfirmed.
operationId: postDid-registrarDidsDidrefUpdates
parameters:
- - name: didRef
- in: path
- description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
- required: true
- schema:
- type: string
- example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
+ - name: didRef
+ in: path
+ description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
+ required: true
+ schema:
+ type: string
+ example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
requestBody:
content:
application/json:
schema:
- $ref: '#/components/schemas/UpdateManagedDIDRequest'
+ $ref: "#/components/schemas/UpdateManagedDIDRequest"
required: true
responses:
- '202':
+ "202":
description: DID update operation accepted
content:
application/json:
schema:
- $ref: '#/components/schemas/DIDOperationResponse'
- '400':
+ $ref: "#/components/schemas/DIDOperationResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '409':
+ $ref: "#/components/schemas/ErrorResponse"
+ "409":
description: Cannot process due to conflict with current state of the resource
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '422':
+ $ref: "#/components/schemas/ErrorResponse"
+ "422":
description: Unable to process the request
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/did-registrar/dids/{didRef}/deactivations:
post:
tags:
- - DID Registrar
- summary: Deactivate DID in the agent's wallet and post deactivate operation
+ - DID Registrar
+ summary:
+ Deactivate DID in the agent's wallet and post deactivate operation
to the VDR
description: |-
Deactivate DID in the agent's wallet and post deactivate operation to the VDR.
@@ -1484,58 +1512,59 @@ paths:
a new deactivate request if the previous operation is not yet comfirmed.
operationId: postDid-registrarDidsDidrefDeactivations
parameters:
- - name: didRef
- in: path
- description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
- required: true
- schema:
- type: string
- example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
+ - name: didRef
+ in: path
+ description: Prism DID according to [the Prism DID method syntax](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#prism-did-method-syntax)
+ required: true
+ schema:
+ type: string
+ example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
responses:
- '202':
+ "202":
description: DID deactivation operation accepted
content:
application/json:
schema:
- $ref: '#/components/schemas/DIDOperationResponse'
- '400':
+ $ref: "#/components/schemas/DIDOperationResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '422':
+ $ref: "#/components/schemas/ErrorResponse"
+ "422":
description: Unable to process the request
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/issue-credentials/credential-offers:
post:
tags:
- - Issue Credentials Protocol
- summary: As a credential issuer, create a new credential offer that will be
+ - Issue Credentials Protocol
+ summary:
+ As a credential issuer, create a new credential offer that will be
sent to a holder Agent.
description: |2
@@ -1548,46 +1577,46 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/CreateIssueCredentialRecordRequest'
+ $ref: "#/components/schemas/CreateIssueCredentialRecordRequest"
required: true
responses:
- '201':
+ "201":
description: The issue credential record.
content:
application/json:
schema:
- $ref: '#/components/schemas/IssueCredentialRecord'
- '400':
+ $ref: "#/components/schemas/IssueCredentialRecord"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/issue-credentials/records:
get:
tags:
- - Issue Credentials Protocol
+ - Issue Credentials Protocol
summary: Retrieves the list of issue credential records from the Agent's database.
description: |2
@@ -1596,63 +1625,68 @@ paths:
The returned items include essential metadata such as record ID, thread ID, state, role, issued credential, and other relevant details.
operationId: getCredentialRecords
parameters:
- - name: offset
- in: query
- description: The number of items to skip before returning results. Default
- is 0 if not specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: limit
- in: query
- description: The maximum number of items to return. Defaults to 100 if not
- specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: thid
- in: query
- description: The thread ID associated with a specific credential issue flow
- execution.
- required: false
- schema:
- type: string
+ - name: offset
+ in: query
+ description:
+ The number of items to skip before returning results. Default
+ is 0 if not specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: limit
+ in: query
+ description:
+ The maximum number of items to return. Defaults to 100 if not
+ specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: thid
+ in: query
+ description:
+ The thread ID associated with a specific credential issue flow
+ execution.
+ required: false
+ schema:
+ type: string
responses:
- '200':
- description: The list of issue credential records available found in the
+ "200":
+ description:
+ The list of issue credential records available found in the
Agent's database.
content:
application/json:
schema:
- $ref: '#/components/schemas/IssueCredentialRecordPage'
- '400':
+ $ref: "#/components/schemas/IssueCredentialRecordPage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/issue-credentials/records/{recordId}:
get:
tags:
- - Issue Credentials Protocol
- summary: Retrieves a specific issue credential flow record from the Agent's
+ - Issue Credentials Protocol
+ summary:
+ Retrieves a specific issue credential flow record from the Agent's
database based on its unique `recordId`.
description: |2
@@ -1661,52 +1695,54 @@ paths:
The returned items include essential metadata such as record ID, thread ID, state, role, issued credential, and other relevant details.
operationId: getCredentialRecord
parameters:
- - name: recordId
- in: path
- description: The `recordId` uniquely identifying the issue credential flow
- record.
- required: true
- schema:
- type: string
+ - name: recordId
+ in: path
+ description:
+ The `recordId` uniquely identifying the issue credential flow
+ record.
+ required: true
+ schema:
+ type: string
responses:
- '200':
+ "200":
description: The specific issue credential flow record.
content:
application/json:
schema:
- $ref: '#/components/schemas/IssueCredentialRecord'
- '400':
+ $ref: "#/components/schemas/IssueCredentialRecord"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/issue-credentials/records/{recordId}/accept-offer:
post:
tags:
- - Issue Credentials Protocol
- summary: As a holder, accept a new credential offer received from another issuer
+ - Issue Credentials Protocol
+ summary:
+ As a holder, accept a new credential offer received from another issuer
Agent.
description: |2
@@ -1714,60 +1750,63 @@ paths:
The subsequent credential request message sent to the issuer adheres to the [Issue Credential Protocol 3.0 - Request Credential](https://github.com/decentralized-identity/waci-didcomm/tree/main/issue_credential#request-credential) specification.
operationId: acceptCredentialOffer
parameters:
- - name: recordId
- in: path
- description: The `recordId` uniquely identifying the issue credential flow
- record.
- required: true
- schema:
- type: string
+ - name: recordId
+ in: path
+ description:
+ The `recordId` uniquely identifying the issue credential flow
+ record.
+ required: true
+ schema:
+ type: string
requestBody:
description: The accept credential offer request object.
content:
application/json:
schema:
- $ref: '#/components/schemas/AcceptCredentialOfferRequest'
+ $ref: "#/components/schemas/AcceptCredentialOfferRequest"
required: true
responses:
- '200':
- description: The issue credential offer was successfully accepted, and the
+ "200":
+ description:
+ The issue credential offer was successfully accepted, and the
updated record is returned in the response body.
content:
application/json:
schema:
- $ref: '#/components/schemas/IssueCredentialRecord'
- '400':
+ $ref: "#/components/schemas/IssueCredentialRecord"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/issue-credentials/records/{recordId}/issue-credential:
post:
tags:
- - Issue Credentials Protocol
- summary: As an issuer, issues the verifiable credential related the identified
+ - Issue Credentials Protocol
+ summary:
+ As an issuer, issues the verifiable credential related the identified
issuance flow record.
description: |2
@@ -1776,15 +1815,16 @@ paths:
Note that this endpoint should only be called when automatic issuance is disabled for this record (i.e. `automaticIssuance` attribute set to `false` at offer creation time).
operationId: issueCredential
parameters:
- - name: recordId
- in: path
- description: The `recordId` uniquely identifying the issue credential flow
- record.
- required: true
- schema:
- type: string
+ - name: recordId
+ in: path
+ description:
+ The `recordId` uniquely identifying the issue credential flow
+ record.
+ required: true
+ schema:
+ type: string
responses:
- '200':
+ "200":
description: |2
The issue credential request was successfully processed, and the updated record is returned in the response body.
@@ -1792,176 +1832,181 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/IssueCredentialRecord'
- '400':
+ $ref: "#/components/schemas/IssueCredentialRecord"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/credential-status/{id}:
get:
tags:
- - Credential status list
+ - Credential status list
summary: Fetch credential status list by its ID
description: Fetch credential status list by its ID
operationId: getCredentialStatusListEndpoint
parameters:
- - name: id
- in: path
- description: Globally unique identifier of the credential status list
- required: true
- schema:
- type: string
- format: uuid
+ - name: id
+ in: path
+ description: Globally unique identifier of the credential status list
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: Status List credential with embedded proof found by ID
content:
application/json:
schema:
- $ref: '#/components/schemas/StatusListCredential'
- '400':
+ $ref: "#/components/schemas/StatusListCredential"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
/credential-status/revoke-credential/{id}:
patch:
tags:
- - Credential status list
+ - Credential status list
summary: Revoke a credential by its ID
- description: Marks credential to be ready for revocation, it will be revoked
+ description:
+ Marks credential to be ready for revocation, it will be revoked
automatically
operationId: patchCredential-statusRevoke-credentialId
parameters:
- - name: id
- in: path
- description: Revoke a credential by its ID
- required: true
- schema:
- type: string
+ - name: id
+ in: path
+ description: Revoke a credential by its ID
+ required: true
+ schema:
+ type: string
responses:
- '200':
- description: ''
- '400':
+ "200":
+ description: ""
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/present-proof/presentations:
get:
tags:
- - Present Proof
+ - Present Proof
summary: Gets the list of proof presentation records.
description: list of presentation statuses
operationId: getAllPresentation
parameters:
- - name: offset
- in: query
- description: The number of items to skip before returning results. Default
- is 0 if not specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: limit
- in: query
- description: The maximum number of items to return. Defaults to 100 if not
- specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: thid
- in: query
- required: false
- schema:
- type: string
+ - name: offset
+ in: query
+ description:
+ The number of items to skip before returning results. Default
+ is 0 if not specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: limit
+ in: query
+ description:
+ The maximum number of items to return. Defaults to 100 if not
+ specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: thid
+ in: query
+ required: false
+ schema:
+ type: string
responses:
- '200':
+ "200":
description: The list of proof presentation records.
content:
application/json:
schema:
- $ref: '#/components/schemas/PresentationStatusPage'
- '400':
+ $ref: "#/components/schemas/PresentationStatusPage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
post:
tags:
- - Present Proof
- summary: As a Verifier, create a new proof presentation request and send it
+ - Present Proof
+ summary:
+ As a Verifier, create a new proof presentation request and send it
to the Prover.
- description: Holder presents proof derived from the verifiable credential to
+ description:
+ Holder presents proof derived from the verifiable credential to
verifier.
operationId: requestPresentation
requestBody:
@@ -1969,259 +2014,266 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/RequestPresentationInput'
+ $ref: "#/components/schemas/RequestPresentationInput"
required: true
responses:
- '201':
- description: The proof presentation request was created successfully and
+ "201":
+ description:
+ The proof presentation request was created successfully and
will be sent asynchronously to the Prover.
content:
application/json:
schema:
- $ref: '#/components/schemas/PresentationStatus'
- '400':
+ $ref: "#/components/schemas/PresentationStatus"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/present-proof/presentations/{presentationId}:
get:
tags:
- - Present Proof
- summary: Gets an existing proof presentation record by its unique identifier.
+ - Present Proof
+ summary:
+ Gets an existing proof presentation record by its unique identifier.
More information on the error can be found in the response body.
description: Returns an existing presentation record by id.
operationId: getPresentation
parameters:
- - name: presentationId
- in: path
- description: The unique identifier of the presentation record.
- required: true
- schema:
- type: string
- format: uuid
+ - name: presentationId
+ in: path
+ description: The unique identifier of the presentation record.
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: The proof presentation record.
content:
application/json:
schema:
- $ref: '#/components/schemas/PresentationStatus'
- '400':
+ $ref: "#/components/schemas/PresentationStatus"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
patch:
tags:
- - Present Proof
- summary: Updates the proof presentation record matching the unique identifier,
+ - Present Proof
+ summary:
+ Updates the proof presentation record matching the unique identifier,
with the specific action to perform.
description: Accept or reject presentation of proof request.
operationId: updatePresentation
parameters:
- - name: presentationId
- in: path
- description: The unique identifier of the presentation record.
- required: true
- schema:
- type: string
- format: uuid
+ - name: presentationId
+ in: path
+ description: The unique identifier of the presentation record.
+ required: true
+ schema:
+ type: string
+ format: uuid
requestBody:
description: The action to perform on the proof presentation record.
content:
application/json:
schema:
- $ref: '#/components/schemas/RequestPresentationAction'
+ $ref: "#/components/schemas/RequestPresentationAction"
required: true
responses:
- '200':
+ "200":
description: The proof presentation record was successfully updated.
content:
application/json:
schema:
- $ref: '#/components/schemas/PresentationStatus'
- '400':
+ $ref: "#/components/schemas/PresentationStatus"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/_system/health:
get:
tags:
- - System
+ - System
summary: Check the health status of the running service
description: Returns the health info object of the running service
operationId: systemHealth
responses:
- '200':
+ "200":
description: The health info object.
content:
application/json:
schema:
- $ref: '#/components/schemas/HealthInfo'
- '400':
+ $ref: "#/components/schemas/HealthInfo"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
/_system/metrics:
get:
tags:
- - System
+ - System
summary: Collect the runtime metrics of the running service
- description: Returns the metrics of the running service from the internal Prometheus
+ description:
+ Returns the metrics of the running service from the internal Prometheus
registry
operationId: systemMetrics
responses:
- '200':
+ "200":
description: The metrics as plain strings.
content:
text/plain:
schema:
type: string
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
/iam/entities:
get:
tags:
- - Identity and Access Management
+ - Identity and Access Management
summary: Get all entities
- description: 'Get all entities with the pagination by `offset` and `limit` parameters '
+ description: "Get all entities with the pagination by `offset` and `limit` parameters "
operationId: getAllEntities
parameters:
- - name: offset
- in: query
- description: The number of items to skip before returning results. Default
- is 0 if not specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: limit
- in: query
- description: The maximum number of items to return. Defaults to 100 if not
- specified.
- required: false
- schema:
- type: integer
- format: int32
+ - name: offset
+ in: query
+ description:
+ The number of items to skip before returning results. Default
+ is 0 if not specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: limit
+ in: query
+ description:
+ The maximum number of items to return. Defaults to 100 if not
+ specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
responses:
- '200':
+ "200":
description: Collection of Entity records
content:
application/json:
schema:
- $ref: '#/components/schemas/EntityResponsePage'
- '400':
+ $ref: "#/components/schemas/EntityResponsePage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - jwtAuth: []
post:
tags:
- - Identity and Access Management
+ - Identity and Access Management
summary: Create a new entity record
- description: Create the new entity record. The entity record is a representation
+ description:
+ Create the new entity record. The entity record is a representation
of the account in the system.
operationId: createEntity
requestBody:
@@ -2229,249 +2281,249 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/CreateEntityRequest'
+ $ref: "#/components/schemas/CreateEntityRequest"
required: true
responses:
- '201':
+ "201":
description: The new entity is successfully created
content:
application/json:
schema:
- $ref: '#/components/schemas/EntityResponse'
- '400':
+ $ref: "#/components/schemas/EntityResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - jwtAuth: []
/iam/entities/{id}/name:
put:
tags:
- - Identity and Access Management
+ - Identity and Access Management
summary: Update the entity record name by `id`
description: Update the entity record name by `id`
operationId: updateEntityName
parameters:
- - name: id
- in: path
- required: true
- schema:
- type: string
- format: uuid
+ - name: id
+ in: path
+ required: true
+ schema:
+ type: string
+ format: uuid
requestBody:
description: JSON object required for the entity name update
content:
application/json:
schema:
- $ref: '#/components/schemas/UpdateEntityNameRequest'
+ $ref: "#/components/schemas/UpdateEntityNameRequest"
required: true
responses:
- '200':
+ "200":
description: The entity record is successfully updated
content:
application/json:
schema:
- $ref: '#/components/schemas/EntityResponse'
- '400':
+ $ref: "#/components/schemas/EntityResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - jwtAuth: []
/iam/entities/{id}/walletId:
put:
tags:
- - Identity and Access Management
+ - Identity and Access Management
summary: Update the entity record `walletId` by `id`
description: Update the entity record `walletId` field by `id`
operationId: updateEntityWalletId
parameters:
- - name: id
- in: path
- required: true
- schema:
- type: string
- format: uuid
+ - name: id
+ in: path
+ required: true
+ schema:
+ type: string
+ format: uuid
requestBody:
description: JSON object required for the entity walletId update
content:
application/json:
schema:
- $ref: '#/components/schemas/UpdateEntityWalletIdRequest'
+ $ref: "#/components/schemas/UpdateEntityWalletIdRequest"
required: true
responses:
- '200':
+ "200":
description: The entity record is successfully updated
content:
application/json:
schema:
- $ref: '#/components/schemas/EntityResponse'
- '400':
+ $ref: "#/components/schemas/EntityResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - jwtAuth: []
/iam/entities/{id}:
get:
tags:
- - Identity and Access Management
+ - Identity and Access Management
summary: Get the entity by the `id`
description: Get the entity by the unique identifier
operationId: getEntityById
parameters:
- - name: id
- in: path
- description: Identifier of the entity
- required: true
- schema:
- type: string
- format: uuid
+ - name: id
+ in: path
+ description: Identifier of the entity
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: Entity found by `id`
content:
application/json:
schema:
- $ref: '#/components/schemas/EntityResponse'
- '400':
+ $ref: "#/components/schemas/EntityResponse"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - jwtAuth: []
delete:
tags:
- - Identity and Access Management
+ - Identity and Access Management
summary: Delete the entity by `id`
description: Delete the entity by the unique identifier
operationId: deleteEntityById
parameters:
- - name: id
- in: path
- description: Identifier of the entity
- required: true
- schema:
- type: string
- format: uuid
+ - name: id
+ in: path
+ description: Identifier of the entity
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: Entity deleted successfully
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - jwtAuth: []
/iam/apikey-authentication:
post:
tags:
- - Identity and Access Management
+ - Identity and Access Management
summary: Register the `apikey` for the entity
description: Register the `apikey` for the entity.
operationId: addEntityApiKeyAuthentication
@@ -2480,41 +2532,41 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/ApiKeyAuthenticationRequest'
+ $ref: "#/components/schemas/ApiKeyAuthenticationRequest"
required: true
responses:
- '201':
+ "201":
description: The new `apikey` is successfully registered for the entity
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - jwtAuth: []
delete:
tags:
- - Identity and Access Management
+ - Identity and Access Management
summary: Unregister the `apikey` for the entity
description: Unregister the `apikey` for the entity.
operationId: deleteEntityApiKeyAuthentication
@@ -2523,97 +2575,101 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/ApiKeyAuthenticationRequest'
+ $ref: "#/components/schemas/ApiKeyAuthenticationRequest"
required: true
responses:
- '200':
+ "200":
description: The new `apikey` is successfully unregistered for the entity
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - jwtAuth: []
/wallets:
get:
tags:
- - Wallet Management
+ - Wallet Management
summary: List all permitted wallets
- description: List all permitted wallets. If the role is admin, returns all the
+ description:
+ List all permitted wallets. If the role is admin, returns all the
wallets. If the role is tenant, only return permitted wallets.
operationId: getWallets
parameters:
- - name: offset
- in: query
- description: The number of items to skip before returning results. Default
- is 0 if not specified.
- required: false
- schema:
- type: integer
- format: int32
- - name: limit
- in: query
- description: The maximum number of items to return. Defaults to 100 if not
- specified.
- required: false
- schema:
- type: integer
- format: int32
+ - name: offset
+ in: query
+ description:
+ The number of items to skip before returning results. Default
+ is 0 if not specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
+ - name: limit
+ in: query
+ description:
+ The maximum number of items to return. Defaults to 100 if not
+ specified.
+ required: false
+ schema:
+ type: integer
+ format: int32
responses:
- '200':
+ "200":
description: Successfully list all permitted wallets
content:
application/json:
schema:
- $ref: '#/components/schemas/WalletDetailPage'
- '400':
+ $ref: "#/components/schemas/WalletDetailPage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - apiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
post:
tags:
- - Wallet Management
+ - Wallet Management
summary: Create a new wallet
- description: "Create a new wallet with the option to provide the seed.\nThe\
+ description:
+ "Create a new wallet with the option to provide the seed.\nThe\
\ seed will be used for all PRISM DID keypair derivation within the wallet.\n\
\nIf the role is admin, a wallet can be created at any time.\nIf the role\
\ is tenant, a wallet can only be created if there is no existing wallet permission\
@@ -2624,312 +2680,317 @@ paths:
content:
application/json:
schema:
- $ref: '#/components/schemas/CreateWalletRequest'
+ $ref: "#/components/schemas/CreateWalletRequest"
required: true
responses:
- '201':
+ "201":
description: Successfully create a new wallet
content:
application/json:
schema:
- $ref: '#/components/schemas/WalletDetail'
- '400':
+ $ref: "#/components/schemas/WalletDetail"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - apiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/wallets/{walletId}:
get:
tags:
- - Wallet Management
+ - Wallet Management
summary: Get the wallet by ID
- description: Get the wallet by ID. If the role is tenant, only search the ID
+ description:
+ Get the wallet by ID. If the role is tenant, only search the ID
of permitted wallets.
operationId: getWalletsWalletid
parameters:
- - name: walletId
- in: path
- required: true
- schema:
- type: string
- format: uuid
+ - name: walletId
+ in: path
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: Successfully get the wallet
content:
application/json:
schema:
- $ref: '#/components/schemas/WalletDetail'
- '400':
+ $ref: "#/components/schemas/WalletDetail"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - apiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/wallets/{walletId}/uma-permissions:
post:
tags:
- - Wallet Management
- summary: Create a UMA resource permission on an authorization server for the
+ - Wallet Management
+ summary:
+ Create a UMA resource permission on an authorization server for the
wallet.
- description: "Create a UMA resource permission on an authorization server for\
+ description:
+ "Create a UMA resource permission on an authorization server for\
\ the wallet.\nThis grants the wallet permission to the specified `subject`,\
\ where the `subject` denotes the identity of the tenant on an authorization\
\ server.\n "
operationId: createWalletUmaPermission
parameters:
- - name: walletId
- in: path
- required: true
- schema:
- type: string
- format: uuid
+ - name: walletId
+ in: path
+ required: true
+ schema:
+ type: string
+ format: uuid
requestBody:
content:
application/json:
schema:
- $ref: '#/components/schemas/CreateWalletUmaPermissionRequest'
+ $ref: "#/components/schemas/CreateWalletUmaPermissionRequest"
required: true
responses:
- '200':
+ "200":
description: UMA resource permission is created on an authorization server
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - apiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
delete:
tags:
- - Wallet Management
- summary: Delete a UMA resource permission on an authorization server for the
+ - Wallet Management
+ summary:
+ Delete a UMA resource permission on an authorization server for the
wallet.
- description: "Remove a UMA resource permission on an authorization server for\
+ description:
+ "Remove a UMA resource permission on an authorization server for\
\ the wallet.\nThis remove the wallet permission to the specified `subject`,\
\ where the `subject` denotes the identity of the tenant on an authorization\
\ server.\n "
operationId: deleteWalletUmaPermission
parameters:
- - name: walletId
- in: path
- required: true
- schema:
- type: string
- format: uuid
- - name: subject
- in: query
- required: true
- schema:
- type: string
- format: uuid
+ - name: walletId
+ in: path
+ required: true
+ schema:
+ type: string
+ format: uuid
+ - name: subject
+ in: query
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: UMA resource permission is removed from an authorization server.
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - adminApiKeyAuth: []
- - apiKeyAuth: []
- - jwtAuth: []
+ - adminApiKeyAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/events/webhooks:
get:
tags:
- - Events
+ - Events
summary: List wallet webhook notifications
operationId: getEventsWebhooks
responses:
- '200':
+ "200":
description: List wallet webhook notifications
content:
application/json:
schema:
- $ref: '#/components/schemas/WebhookNotificationPage'
- '400':
+ $ref: "#/components/schemas/WebhookNotificationPage"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
post:
tags:
- - Events
+ - Events
summary: Create wallet webhook notifications
operationId: postEventsWebhooks
requestBody:
content:
application/json:
schema:
- $ref: '#/components/schemas/CreateWebhookNotification'
+ $ref: "#/components/schemas/CreateWebhookNotification"
required: true
responses:
- '200':
+ "200":
description: Webhook notification has been created successfully
content:
application/json:
schema:
- $ref: '#/components/schemas/WebhookNotification'
- '400':
+ $ref: "#/components/schemas/WebhookNotification"
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '409':
+ $ref: "#/components/schemas/ErrorResponse"
+ "409":
description: Cannot process due to conflict with current state of the resource
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
/events/webhooks/{id}:
delete:
tags:
- - Events
+ - Events
summary: Delete the wallet webhook notification by `id`
operationId: deleteEventsWebhooksId
parameters:
- - name: id
- in: path
- description: ID of the webhook notification to delete.
- required: true
- schema:
- type: string
- format: uuid
+ - name: id
+ in: path
+ description: ID of the webhook notification to delete.
+ required: true
+ schema:
+ type: string
+ format: uuid
responses:
- '200':
+ "200":
description: Webhook notification has been deleted.
- '400':
+ "400":
description: Invalid request parameters
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '403':
+ $ref: "#/components/schemas/ErrorResponse"
+ "403":
description: Forbidden
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '404':
+ $ref: "#/components/schemas/ErrorResponse"
+ "404":
description: Resource could not be found
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
- '500':
+ $ref: "#/components/schemas/ErrorResponse"
+ "500":
description: Internal server error
content:
application/json:
schema:
- $ref: '#/components/schemas/ErrorResponse'
+ $ref: "#/components/schemas/ErrorResponse"
security:
- - apiKeyAuth: []
- - jwtAuth: []
+ - apiKeyAuth: []
+ - jwtAuth: []
components:
schemas:
AcceptConnectionInvitationRequest:
required:
- - invitation
+ - invitation
type: object
properties:
invitation:
@@ -2949,15 +3010,15 @@ components:
ActionType:
type: string
enum:
- - ADD_KEY
- - ADD_SERVICE
- - PATCH_CONTEXT
- - REMOVE_KEY
- - REMOVE_SERVICE
- - UPDATE_SERVICE
+ - ADD_KEY
+ - ADD_SERVICE
+ - PATCH_CONTEXT
+ - REMOVE_KEY
+ - REMOVE_SERVICE
+ - UPDATE_SERVICE
AnoncredCredentialProofV1:
required:
- - credential
+ - credential
type: object
properties:
credential:
@@ -2976,8 +3037,9 @@ components:
credentialProofs:
type: array
items:
- $ref: '#/components/schemas/AnoncredCredentialProofV1'
- description: A list of proofs from the Anoncred library, each corresponding
+ $ref: "#/components/schemas/AnoncredCredentialProofV1"
+ description:
+ A list of proofs from the Anoncred library, each corresponding
to a credential.
AnoncredNonRevokedIntervalV1:
type: object
@@ -2990,17 +3052,17 @@ components:
format: int32
AnoncredPresentationRequestV1:
required:
- - requested_attributes
- - requested_predicates
- - name
- - nonce
- - version
+ - requested_attributes
+ - requested_predicates
+ - name
+ - nonce
+ - version
type: object
properties:
requested_attributes:
- $ref: '#/components/schemas/Map_AnoncredRequestedAttributeV1'
+ $ref: "#/components/schemas/Map_AnoncredRequestedAttributeV1"
requested_predicates:
- $ref: '#/components/schemas/Map_AnoncredRequestedPredicateV1'
+ $ref: "#/components/schemas/Map_AnoncredRequestedPredicateV1"
name:
type: string
nonce:
@@ -3008,15 +3070,16 @@ components:
version:
type: string
non_revoked:
- $ref: '#/components/schemas/AnoncredNonRevokedIntervalV1'
+ $ref: "#/components/schemas/AnoncredNonRevokedIntervalV1"
description: Anoncred Presentation Request
- example: AnoncredPresentationRequestV1(Map(attribute1 -> AnoncredRequestedAttributeV1(Attribute
+ example:
+ AnoncredPresentationRequestV1(Map(attribute1 -> AnoncredRequestedAttributeV1(Attribute
1,List(Map(cred_def_id -> credential_definition_id_of_attribute1)),Some(AnoncredNonRevokedIntervalV1(Some(1635734400),Some(1735734400))))),Map(predicate1
-> AnoncredRequestedPredicateV1(Predicate 1,>=,18,List(Map(schema_id -> schema_id_of_predicate1)),Some(AnoncredNonRevokedIntervalV1(Some(1635734400),None)))),Example
Presentation Request,1234567890,1.0,None)
AnoncredRequestedAttributeV1:
required:
- - name
+ - name
type: object
properties:
name:
@@ -3024,14 +3087,14 @@ components:
restrictions:
type: array
items:
- $ref: '#/components/schemas/Map_String'
+ $ref: "#/components/schemas/Map_String"
non_revoked:
- $ref: '#/components/schemas/AnoncredNonRevokedIntervalV1'
+ $ref: "#/components/schemas/AnoncredNonRevokedIntervalV1"
AnoncredRequestedPredicateV1:
required:
- - name
- - p_type
- - p_value
+ - name
+ - p_type
+ - p_value
type: object
properties:
name:
@@ -3044,13 +3107,13 @@ components:
restrictions:
type: array
items:
- $ref: '#/components/schemas/Map_String'
+ $ref: "#/components/schemas/Map_String"
non_revoked:
- $ref: '#/components/schemas/AnoncredNonRevokedIntervalV1'
+ $ref: "#/components/schemas/AnoncredNonRevokedIntervalV1"
ApiKeyAuthenticationRequest:
required:
- - entityId
- - apiKey
+ - entityId
+ - apiKey
type: object
properties:
entityId:
@@ -3072,22 +3135,22 @@ components:
items: {}
Bool:
required:
- - value
+ - value
type: object
properties:
value:
type: boolean
Connection:
required:
- - connectionId
- - thid
- - role
- - state
- - invitation
- - createdAt
- - metaRetries
- - self
- - kind
+ - connectionId
+ - thid
+ - role
+ - state
+ - invitation
+ - createdAt
+ - metaRetries
+ - self
+ - kind
type: object
properties:
connectionId:
@@ -3097,7 +3160,8 @@ components:
example: 0527aea1-d131-3948-a34d-03af39aba8b4
thid:
type: string
- description: The unique identifier of the thread this connection record
+ description:
+ The unique identifier of the thread this connection record
belongs to. The value will identical on both sides of the connection (inviter
and invitee)
example: 0527aea1-d131-3948-a34d-03af39aba8b4
@@ -3107,23 +3171,27 @@ components:
example: Peter
goalCode:
type: string
- description: A self-attested code the receiver may want to display to the
+ description:
+ A self-attested code the receiver may want to display to the
user or use in automatically deciding what to do with the out-of-band
message.
example: issue-vc
goal:
type: string
- description: A self-attested string that the receiver may want to display
+ description:
+ A self-attested string that the receiver may want to display
to the user about the context-specific goal of the out-of-band message.
example: To issue a Faber College Graduate credential
myDid:
type: string
- description: The DID representing me as the inviter or invitee in this specific
+ description:
+ The DID representing me as the inviter or invitee in this specific
connection.
example: did:peer:12345
theirDid:
type: string
- description: The DID representing the other peer as the an inviter or invitee
+ description:
+ The DID representing the other peer as the an inviter or invitee
in this specific connection.
example: did:peer:67890
role:
@@ -3131,26 +3199,26 @@ components:
description: The role played by the Prism agent in the connection flow.
example: Inviter
enum:
- - Inviter
- - Invitee
+ - Inviter
+ - Invitee
state:
type: string
description: The current state of the connection protocol execution.
example: InvitationGenerated
enum:
- - InvitationGenerated
- - InvitationReceived
- - ConnectionRequestPending
- - ConnectionRequestSent
- - ConnectionRequestReceived
- - ConnectionResponsePending
- - ConnectionResponseSent
- - ConnectionResponseReceived
- - ProblemReportPending
- - ProblemReportSent
- - ProblemReportReceived
+ - InvitationGenerated
+ - InvitationReceived
+ - ConnectionRequestPending
+ - ConnectionRequestSent
+ - ConnectionRequestReceived
+ - ConnectionResponsePending
+ - ConnectionResponseSent
+ - ConnectionResponseReceived
+ - ProblemReportPending
+ - ProblemReportSent
+ - ProblemReportReceived
invitation:
- $ref: '#/components/schemas/ConnectionInvitation'
+ $ref: "#/components/schemas/ConnectionInvitation"
createdAt:
type: string
description: The date and time the connection record was created.
@@ -3163,7 +3231,8 @@ components:
example: 2022-03-10T12:00Z
metaRetries:
type: integer
- description: The maximum background processing attempts remaining for this
+ description:
+ The maximum background processing attempts remaining for this
record
format: int32
example: 5
@@ -3177,74 +3246,84 @@ components:
example: Connection
ConnectionInvitation:
required:
- - id
- - type
- - from
- - invitationUrl
+ - id
+ - type
+ - from
+ - invitationUrl
type: object
properties:
id:
type: string
- description: The unique identifier of the invitation. It should be used
+ description:
+ The unique identifier of the invitation. It should be used
as parent thread ID (pthid) for the Connection Request message that follows.
format: uuid
example: 0527aea1-d131-3948-a34d-03af39aba8b4
type:
type: string
- description: The DIDComm Message Type URI (MTURI) the invitation message
+ description:
+ The DIDComm Message Type URI (MTURI) the invitation message
complies with.
example: https://didcomm.org/out-of-band/2.0/invitation
from:
type: string
- description: The DID representing the sender to be used by recipients for
+ description:
+ The DID representing the sender to be used by recipients for
future interactions.
example: did:peer:1234457
invitationUrl:
type: string
- description: The invitation message encoded as a URL. This URL follows the
+ description:
+ The invitation message encoded as a URL. This URL follows the
Out of [Band 2.0 protocol](https://identity.foundation/didcomm-messaging/spec/v2.0/#out-of-band-messages)
and can be used to generate a QR code for example.
example: https://my.domain.com/path?_oob=eyJAaWQiOiIzZmE4NWY2NC01NzE3LTQ1NjItYjNmYy0yYzk2M2Y2NmFmYTYiLCJAdHlwZSI6Imh0dHBzOi8vZGlkY29tbS5vcmcvbXktZmFtaWx5LzEuMC9teS1tZXNzYWdlLXR5cGUiLCJkaWQiOiJXZ1d4cXp0ck5vb0c5MlJYdnhTVFd2IiwiaW1hZ2VVcmwiOiJodHRwOi8vMTkyLjE2OC41Ni4xMDEvaW1nL2xvZ28uanBnIiwibGFiZWwiOiJCb2IiLCJyZWNpcGllbnRLZXlzIjpbIkgzQzJBVnZMTXY2Z21NTmFtM3VWQWpacGZrY0pDd0R3blpuNnozd1htcVBWIl0sInJvdXRpbmdLZXlzIjpbIkgzQzJBVnZMTXY2Z21NTmFtM3VWQWpacGZrY0pDd0R3blpuNnozd1htcVBWIl0sInNlcnZpY2VFbmRwb2ludCI6Imh0dHA6Ly8xOTIuMTY4LjU2LjEwMTo4MDIwIn0=
description: The invitation for this connection
ConnectionsPage:
required:
- - kind
- - self
- - pageOf
+ - kind
+ - self
+ - pageOf
type: object
properties:
contents:
type: array
items:
- $ref: '#/components/schemas/Connection'
- description: "\nArray of resources (Connection)\nA sequence of Connection\
+ $ref: "#/components/schemas/Connection"
+ description:
+ "\nArray of resources (Connection)\nA sequence of Connection\
\ resources representing the list of connections that the paginated response\
\ contains.\n "
example: []
kind:
type: string
- description: A string that identifies the type of resource being returned
+ description:
+ A string that identifies the type of resource being returned
in the response.
example: ConnectionsPage
self:
type: string
- description: The URL that uniquely identifies the resource being returned
+ description:
+ The URL that uniquely identifies the resource being returned
in the response.
example: /prism-agent/connections?offset=10&limit=10
pageOf:
type: string
- description: A string field indicating the type of resource that the contents
+ description:
+ A string field indicating the type of resource that the contents
field contains.
- example: ''
+ example: ""
next:
type: string
- description: An optional string field containing the URL of the next page
+ description:
+ An optional string field containing the URL of the next page
of results. If the API response does not contain any more pages, this
field should be set to None.
example: /prism-agent/connections?offset=20&limit=10
previous:
type: string
- description: An optional string field containing the URL of the previous
+ description:
+ An optional string field containing the URL of the previous
page of results. If the API response is the first page of results, this
field should be set to None.
example: /prism-agent/connections?offset=0&limit=10
@@ -3257,48 +3336,54 @@ components:
example: Peter
goalCode:
type: string
- description: A self-attested code the receiver may want to display to the
+ description:
+ A self-attested code the receiver may want to display to the
user or use in automatically deciding what to do with the out-of-band
message.
example: issue-vc
goal:
type: string
- description: A self-attested string that the receiver may want to display
+ description:
+ A self-attested string that the receiver may want to display
to the user about the context-specific goal of the out-of-band message.
example: To issue a Faber College Graduate credential
CreateEntityRequest:
required:
- - name
+ - name
type: object
properties:
id:
type: string
- description: The new `id` of the entity to be created. If this field is
+ description:
+ The new `id` of the entity to be created. If this field is
not provided, the server will generate a new UUID for the entity
format: uuid
example: 00000000-0000-0000-0000-000000000000
name:
type: string
- description: The new `name` of the entity to be created. If this field is
+ description:
+ The new `name` of the entity to be created. If this field is
not provided, the server will generate a random name for the entity
example: John Doe
minLength: 1
maxLength: 128
walletId:
type: string
- description: The new `walletId` of the entity to be created. If this field
+ description:
+ The new `walletId` of the entity to be created. If this field
is not provided, the server will set the default `walletId`
format: uuid
example: 00000000-0000-0000-0000-000000000000
CreateIssueCredentialRecordRequest:
required:
- - claims
- - connectionId
+ - claims
+ - connectionId
type: object
properties:
validityPeriod:
type: number
- description: The validity period in seconds of the verifiable credential
+ description:
+ The validity period in seconds of the verifiable credential
that will be issued.
format: double
example: 3600.0
@@ -3356,7 +3441,7 @@ components:
example: d9569cec-c81e-4779-aa86-0d5994d82676
CreateManagedDIDResponse:
required:
- - longFormDid
+ - longFormDid
type: object
properties:
longFormDid:
@@ -3365,22 +3450,22 @@ components:
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff:Cr4BCrsBElsKBmF1dGgtMRAEQk8KCXNlY3AyNTZrMRIg0opTuxu-zt6aRbT1tPniG4eu4CYsQPM3rrLzvzNiNgwaIIFTnyT2N4U7qCQ78qtWC3-p0el6Hvv8qxG5uuEw-WgMElwKB21hc3RlcjAQAUJPCglzZWNwMjU2azESIKhBU0eCOO6Vinz_8vhtFSAhYYqrkEXC8PHGxkuIUev8GiAydFHLXb7c22A1Uj_PR21NZp6BCDQqNq2xd244txRgsQ
CreateManagedDidRequest:
required:
- - documentTemplate
+ - documentTemplate
type: object
properties:
documentTemplate:
- $ref: '#/components/schemas/CreateManagedDidRequestDocumentTemplate'
+ $ref: "#/components/schemas/CreateManagedDidRequestDocumentTemplate"
CreateManagedDidRequestDocumentTemplate:
type: object
properties:
publicKeys:
type: array
items:
- $ref: '#/components/schemas/ManagedDIDKeyTemplate'
+ $ref: "#/components/schemas/ManagedDIDKeyTemplate"
services:
type: array
items:
- $ref: '#/components/schemas/Service'
+ $ref: "#/components/schemas/Service"
contexts:
type: array
items:
@@ -3389,12 +3474,13 @@ components:
example: https://didcomm.org/messaging/contexts/v2
CreateWalletRequest:
required:
- - name
+ - name
type: object
properties:
seed:
type: string
- description: A BIP32 seed encoded in hexadecimal string. It is expected
+ description:
+ A BIP32 seed encoded in hexadecimal string. It is expected
to represent 64-bytes binary seed (128 hex characters).
example: c9994785ce6d548134020f610b76102ca1075d3bb672a75ec8c9a27a7b8607e3b9b384e43b77bb08f8d5159651ae38b98573f7ecc79f2d7e1f1cc371ce60cf8a
name:
@@ -3410,68 +3496,75 @@ components:
example: 00000000-0000-0000-0000-000000000000
CreateWalletUmaPermissionRequest:
required:
- - subject
+ - subject
type: object
properties:
subject:
type: string
- description: The subject ID that should be granted the permission to the
+ description:
+ The subject ID that should be granted the permission to the
wallet. This can be found in the `sub` claim of a JWT token.
format: uuid
example: 00000000-0000-0000-0000-000000000000
CreateWebhookNotification:
required:
- - url
+ - url
type: object
properties:
url:
type: string
customHeaders:
- $ref: '#/components/schemas/Map_String'
+ $ref: "#/components/schemas/Map_String"
CredentialDefinitionInput:
required:
- - name
- - version
- - tag
- - author
- - schemaId
- - signatureType
- - supportRevocation
+ - name
+ - version
+ - tag
+ - author
+ - schemaId
+ - signatureType
+ - supportRevocation
type: object
properties:
name:
type: string
- description: A human-readable name for the credential definition. A piece
+ description:
+ A human-readable name for the credential definition. A piece
of Metadata.
example: DrivingLicense
minLength: 1
description:
type: string
description: A human-readable description of the credential definition
- example: Simple credential definition for the driving licence verifiable
+ example:
+ Simple credential definition for the driving licence verifiable
credential.
minLength: 1
version:
type: string
- description: Denotes the revision of a given Credential Definition. It should
+ description:
+ Denotes the revision of a given Credential Definition. It should
follow semantic version convention to describe the impact of the credential
definition evolution.
example: 1.0.0
pattern: ^(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$
tag:
type: string
- description: Token that allow to lookup and filter the credential definition
+ description:
+ Token that allow to lookup and filter the credential definition
records.
example: licence
author:
type: string
- description: DID of the identity which authored the credential definition.
+ description:
+ DID of the identity which authored the credential definition.
A piece of Metadata.
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
pattern: ^did:(?[a-z0-9]+(:[a-z0-9]+)*)\:(?[^#?]*)$
schemaId:
type: string
- description: The unique identifier of the schema used for this credential
+ description:
+ The unique identifier of the schema used for this credential
definition.
example: https://agent-host.com/prism-agent/schema-registry/schemas/d9569cec-c81e-4779-aa86-0d5994d82676
signatureType:
@@ -3480,95 +3573,108 @@ components:
example: CL
supportRevocation:
type: boolean
- description: Boolean flag indicating whether revocation is supported for
+ description:
+ Boolean flag indicating whether revocation is supported for
this CredentialDefinition.
example: false
CredentialDefinitionResponse:
required:
- - guid
- - id
- - name
- - version
- - tag
- - description
- - author
- - authored
- - schemaId
- - definition
- - keyCorrectnessProof
- - signatureType
- - supportRevocation
- - kind
- - self
+ - guid
+ - id
+ - name
+ - version
+ - tag
+ - description
+ - author
+ - authored
+ - schemaId
+ - definition
+ - keyCorrectnessProof
+ - signatureType
+ - supportRevocation
+ - kind
+ - self
type: object
properties:
guid:
type: string
- description: 'Globally unique id of the credential definition.It''s composed
+ description:
+ "Globally unique id of the credential definition.It's composed
from the bytes of the string that contain the `author`, `name`, and `version`
- values.The string format looks like the resource identifier: `author`/`id`?version=`version`'
+ values.The string format looks like the resource identifier: `author`/`id`?version=`version`"
format: uuid
example: 0527aea1-d131-3948-a34d-03af39aba8b4
id:
type: string
- description: A locally unique identifier to address the credential definition.
+ description:
+ A locally unique identifier to address the credential definition.
UUID is generated by the backend.
example: 0527aea1-d131-3948-a34d-03af39aba8b5
longId:
type: string
- description: Resource id of the credential definition. Contains the `author`'s
+ description:
+ Resource id of the credential definition. Contains the `author`'s
DID, `id` and `version` fields.
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff/0527aea1-d131-3948-a34d-03af39aba8b4?version=1.0.0
name:
type: string
- description: A human-readable name for the credential definition. A piece
+ description:
+ A human-readable name for the credential definition. A piece
of Metadata.
example: DrivingLicense
version:
type: string
- description: Denotes the revision of a given Credential Definition. It should
+ description:
+ Denotes the revision of a given Credential Definition. It should
follow semantic version convention to describe the impact of the credential
definition evolution.
example: 1.0.0
tag:
type: string
- description: Token that allow to lookup and filter the credential definition
+ description:
+ Token that allow to lookup and filter the credential definition
records.
example: licence
description:
type: string
description: A human-readable description of the credential definition
- example: Simple credential definition for the driving licence verifiable
+ example:
+ Simple credential definition for the driving licence verifiable
credential.
author:
type: string
- description: DID of the identity which authored the credential definition.
+ description:
+ DID of the identity which authored the credential definition.
A piece of Metadata.
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
authored:
type: string
- description: '[RFC3339](https://www.rfc-editor.org/rfc/rfc3339) date on
- which the credential definition was created. A piece of Metadata.'
+ description:
+ "[RFC3339](https://www.rfc-editor.org/rfc/rfc3339) date on
+ which the credential definition was created. A piece of Metadata."
format: date-time
example: 2022-03-10T12:00Z
schemaId:
type: string
- description: The unique identifier of the schema used for this credential
+ description:
+ The unique identifier of the schema used for this credential
definition.
example: https://agent-host.com/prism-agent/schema-registry/schemas/d9569cec-c81e-4779-aa86-0d5994d82676
definition:
- description: Definition object that represents the actual definition of
+ description:
+ Definition object that represents the actual definition of
the credential.
example:
credentialSubject:
emailAddress: alice@wonderland.com
givenName: Alice
familyName: Wonderland
- dateOfIssuance: '2000-01-01T10:00:00Z'
- drivingLicenseID: '12345'
+ dateOfIssuance: "2000-01-01T10:00:00Z"
+ drivingLicenseID: "12345"
drivingClass: 5
keyCorrectnessProof:
- description: A proof that validates the correctness of the key within the
+ description:
+ A proof that validates the correctness of the key within the
context of the credential definition.
signatureType:
type: string
@@ -3576,38 +3682,43 @@ components:
example: CL
supportRevocation:
type: boolean
- description: Boolean flag indicating whether revocation is supported for
+ description:
+ Boolean flag indicating whether revocation is supported for
this CredentialDefinition.
example: false
proof:
- $ref: '#/components/schemas/Proof'
+ $ref: "#/components/schemas/Proof"
kind:
type: string
- description: A string that identifies the type of resource being returned
+ description:
+ A string that identifies the type of resource being returned
in the response.
example: CredentialDefinition
self:
type: string
- description: The URL that uniquely identifies the resource being returned
+ description:
+ The URL that uniquely identifies the resource being returned
in the response.
example: /prism-agent/credential-definition-registry/schemas/0527aea1-d131-3948-a34d-03af39aba8b4
CredentialDefinitionResponsePage:
required:
- - kind
- - self
- - pageOf
+ - kind
+ - self
+ - pageOf
type: object
properties:
contents:
type: array
items:
- $ref: '#/components/schemas/CredentialDefinitionResponse'
- description: A sequence of CredentialSchemaResponse objects representing
+ $ref: "#/components/schemas/CredentialDefinitionResponse"
+ description:
+ A sequence of CredentialSchemaResponse objects representing
the list of credential schemas that the API response contains
example: []
kind:
type: string
- description: A string field indicating the type of the API response. In
+ description:
+ A string field indicating the type of the API response. In
this case, it will always be set to `CredentialSchemaPage`
example: CredentialSchemaPage
self:
@@ -3616,39 +3727,44 @@ components:
example: /prism-agent/schema-registry/schemas?skip=10&limit=10
pageOf:
type: string
- description: A string field indicating the type of resource that the contents
+ description:
+ A string field indicating the type of resource that the contents
field contains
example: /prism-agent/schema-registry/schemas
next:
type: string
- description: An optional string field containing the URL of the next page
+ description:
+ An optional string field containing the URL of the next page
of results. If the API response does not contain any more pages, this
field should be set to None.
example: /prism-agent/schema-registry/schemas?skip=20&limit=10
previous:
type: string
- description: An optional string field containing the URL of the previous
+ description:
+ An optional string field containing the URL of the previous
page of results. If the API response is the first page of results, this
field should be set to None.
example: /prism-agent/schema-registry/schemas?skip=0&limit=10
CredentialSchemaInput:
required:
- - name
- - version
- - type
- - schema
- - author
+ - name
+ - version
+ - type
+ - schema
+ - author
type: object
properties:
name:
type: string
- description: A human-readable name for the credential schema. A piece of
+ description:
+ A human-readable name for the credential schema. A piece of
Metadata.
example: DrivingLicense
minLength: 1
version:
type: string
- description: Denotes the revision of a given Credential Schema. It should
+ description:
+ Denotes the revision of a given Credential Schema. It should
follow semantic version convention to describe the impact of the schema
evolution.
example: 1.0.0
@@ -3660,11 +3776,13 @@ components:
minLength: 1
type:
type: string
- description: This field resolves to a JSON schema with details about the
+ description:
+ This field resolves to a JSON schema with details about the
schema metadata that applies to the schema. A piece of Metadata.
example: https://w3c-ccg.github.io/vc-json-schemas/schema/2.0/schema.json
schema:
- description: Valid JSON Schema where the Credential Schema data fields are
+ description:
+ Valid JSON Schema where the Credential Schema data fields are
defined. A piece of Metadata
example:
$id: https://example.com/driving-license-1.0
@@ -3687,68 +3805,75 @@ components:
drivingClass:
type: integer
required:
- - emailAddress
- - familyName
- - dateOfIssuance
- - drivingLicenseID
- - drivingClass
+ - emailAddress
+ - familyName
+ - dateOfIssuance
+ - drivingLicenseID
+ - drivingClass
additionalProperties: false
tags:
type: array
items:
type: string
- description: Tokens that allow to lookup and filter the credential schema
+ description:
+ Tokens that allow to lookup and filter the credential schema
records.
example:
- - driving
- - licence
- - id
+ - driving
+ - licence
+ - id
author:
type: string
- description: DID of the identity which authored the credential schema. A
+ description:
+ DID of the identity which authored the credential schema. A
piece of Metadata.
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
pattern: ^did:(?[a-z0-9]+(:[a-z0-9]+)*)\:(?[^#?]*)$
CredentialSchemaResponse:
required:
- - guid
- - id
- - name
- - version
- - description
- - type
- - schema
- - author
- - authored
- - kind
- - self
+ - guid
+ - id
+ - name
+ - version
+ - description
+ - type
+ - schema
+ - author
+ - authored
+ - kind
+ - self
type: object
properties:
guid:
type: string
- description: 'Globally unique id of the credential schema.It''s composed
+ description:
+ "Globally unique id of the credential schema.It's composed
from the bytes of the string that contain the `author`, `name`, and `version`
- values.The string format looks like the resource identifier: `author`/`id`?version=`version`'
+ values.The string format looks like the resource identifier: `author`/`id`?version=`version`"
format: uuid
example: 0527aea1-d131-3948-a34d-03af39aba8b4
id:
type: string
- description: A locally unique identifier to address the schema. UUID is
+ description:
+ A locally unique identifier to address the schema. UUID is
generated by the backend.
example: 0527aea1-d131-3948-a34d-03af39aba8b5
longId:
type: string
- description: Resource id of the credential schema. Contains the `author`'s
+ description:
+ Resource id of the credential schema. Contains the `author`'s
DID, `id` and `version` fields.
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff/0527aea1-d131-3948-a34d-03af39aba8b4?version=1.0.0
name:
type: string
- description: A human-readable name for the credential schema. A piece of
+ description:
+ A human-readable name for the credential schema. A piece of
Metadata.
example: DrivingLicense
version:
type: string
- description: Denotes the revision of a given Credential Schema. It should
+ description:
+ Denotes the revision of a given Credential Schema. It should
follow semantic version convention to describe the impact of the schema
evolution.
example: 1.0.0
@@ -3756,23 +3881,26 @@ components:
type: array
items:
type: string
- description: Tokens that allow to lookup and filter the credential schema
+ description:
+ Tokens that allow to lookup and filter the credential schema
records.
example:
- - driving
- - licence
- - id
+ - driving
+ - licence
+ - id
description:
type: string
description: A human-readable description of the credential schema
example: Simple credential schema for the driving licence verifiable credential.
type:
type: string
- description: This field resolves to a JSON schema with details about the
+ description:
+ This field resolves to a JSON schema with details about the
schema metadata that applies to the schema. A piece of Metadata.
example: https://w3c-ccg.github.io/vc-json-schemas/schema/2.0/schema.json
schema:
- description: Valid JSON Schema where the Credential Schema data fields are
+ description:
+ Valid JSON Schema where the Credential Schema data fields are
defined. A piece of Metadata
example:
$id: https://example.com/driving-license-1.0
@@ -3795,52 +3923,58 @@ components:
drivingClass:
type: integer
required:
- - emailAddress
- - familyName
- - dateOfIssuance
- - drivingLicenseID
- - drivingClass
+ - emailAddress
+ - familyName
+ - dateOfIssuance
+ - drivingLicenseID
+ - drivingClass
additionalProperties: false
author:
type: string
- description: DID of the identity which authored the credential schema. A
+ description:
+ DID of the identity which authored the credential schema. A
piece of Metadata.
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
authored:
type: string
- description: '[RFC3339](https://www.rfc-editor.org/rfc/rfc3339) date on
- which the credential schema was created. A piece of Metadata.'
+ description:
+ "[RFC3339](https://www.rfc-editor.org/rfc/rfc3339) date on
+ which the credential schema was created. A piece of Metadata."
format: date-time
example: 2022-03-10T12:00Z
proof:
- $ref: '#/components/schemas/Proof1'
+ $ref: "#/components/schemas/Proof1"
kind:
type: string
- description: A string that identifies the type of resource being returned
+ description:
+ A string that identifies the type of resource being returned
in the response.
example: CredentialSchema
self:
type: string
- description: The URL that uniquely identifies the resource being returned
+ description:
+ The URL that uniquely identifies the resource being returned
in the response.
example: /prism-agent/schema-registry/schemas/0527aea1-d131-3948-a34d-03af39aba8b4
CredentialSchemaResponsePage:
required:
- - kind
- - self
- - pageOf
+ - kind
+ - self
+ - pageOf
type: object
properties:
contents:
type: array
items:
- $ref: '#/components/schemas/CredentialSchemaResponse'
- description: A sequence of CredentialSchemaResponse objects representing
+ $ref: "#/components/schemas/CredentialSchemaResponse"
+ description:
+ A sequence of CredentialSchemaResponse objects representing
the list of credential schemas that the API response contains
example: []
kind:
type: string
- description: A string field indicating the type of the API response. In
+ description:
+ A string field indicating the type of the API response. In
this case, it will always be set to `CredentialSchemaPage`
example: CredentialSchemaPage
self:
@@ -3849,27 +3983,30 @@ components:
example: /prism-agent/schema-registry/schemas?skip=10&limit=10
pageOf:
type: string
- description: A string field indicating the type of resource that the contents
+ description:
+ A string field indicating the type of resource that the contents
field contains
example: /prism-agent/schema-registry/schemas
next:
type: string
- description: An optional string field containing the URL of the next page
+ description:
+ An optional string field containing the URL of the next page
of results. If the API response does not contain any more pages, this
field should be set to None.
example: /prism-agent/schema-registry/schemas?skip=20&limit=10
previous:
type: string
- description: An optional string field containing the URL of the previous
+ description:
+ An optional string field containing the URL of the previous
page of results. If the API response is the first page of results, this
field should be set to None.
example: /prism-agent/schema-registry/schemas?skip=0&limit=10
CredentialSubject:
required:
- - id
- - type
- - statusPurpose
- - encodedList
+ - id
+ - type
+ - statusPurpose
+ - encodedList
type: object
properties:
id:
@@ -3881,7 +4018,7 @@ components:
description: Always equals to constnat value - StatusList2021
example: StatusList2021
statusPurpose:
- $ref: '#/components/schemas/StatusPurpose'
+ $ref: "#/components/schemas/StatusPurpose"
encodedList:
type: string
description: base64 url encoded bitstring of credential statuses
@@ -3889,10 +4026,10 @@ components:
description: Object containing claims specific to status list credential
DIDDocument:
required:
- - id
+ - id
type: object
properties:
- '@context':
+ "@context":
type: array
items:
type: string
@@ -3906,12 +4043,12 @@ components:
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
controller:
type: string
- description: '[DID controller](https://www.w3.org/TR/did-core/#did-controller)'
+ description: "[DID controller](https://www.w3.org/TR/did-core/#did-controller)"
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
verificationMethod:
type: array
items:
- $ref: '#/components/schemas/VerificationMethod'
+ $ref: "#/components/schemas/VerificationMethod"
authentication:
type: array
items:
@@ -3935,14 +4072,15 @@ components:
service:
type: array
items:
- $ref: '#/components/schemas/Service'
+ $ref: "#/components/schemas/Service"
description: A W3C compliant Prism DID document representation.
DIDDocumentMetadata:
type: object
properties:
deactivated:
type: boolean
- description: If a DID has been deactivated, DID document metadata MUST include
+ description:
+ If a DID has been deactivated, DID document metadata MUST include
this property with the boolean value true. If a DID has not been deactivated,
this property is OPTIONAL, but if included, MUST have the boolean value
false.
@@ -3963,23 +4101,25 @@ components:
example: 4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
created:
type: string
- description: The timestamp of the Cardano block that contained the first
+ description:
+ The timestamp of the Cardano block that contained the first
valid SignedAtalaOperation with a CreateDIDOperation that created the
DID.
- example: '2023-02-04T13:52:10Z'
+ example: "2023-02-04T13:52:10Z"
updated:
type: string
- description: The timestamp of the Cardano block that contained the latest
+ description:
+ The timestamp of the Cardano block that contained the latest
valid SignedAtalaOperation that changed the DID's internal state.
- example: '2023-02-04T13:52:10Z'
- description: '[DID document metadata](https://www.w3.org/TR/did-core/#did-document-metadata)'
+ example: "2023-02-04T13:52:10Z"
+ description: "[DID document metadata](https://www.w3.org/TR/did-core/#did-document-metadata)"
DIDOperationResponse:
required:
- - scheduledOperation
+ - scheduledOperation
type: object
properties:
scheduledOperation:
- $ref: '#/components/schemas/DidOperationSubmission'
+ $ref: "#/components/schemas/DidOperationSubmission"
DIDResolutionMetadata:
type: object
properties:
@@ -3995,28 +4135,28 @@ components:
type: string
description: The media type of the returned DID document
example: application/did+ld+json
- description: '[DID resolution metadata](https://www.w3.org/TR/did-core/#did-resolution-metadata)'
+ description: "[DID resolution metadata](https://www.w3.org/TR/did-core/#did-resolution-metadata)"
DIDResolutionResult:
required:
- - '@context'
- - didDocumentMetadata
- - didResolutionMetadata
+ - "@context"
+ - didDocumentMetadata
+ - didResolutionMetadata
type: object
properties:
- '@context':
+ "@context":
type: string
description: The JSON-LD context describing the JSON document
example: https://didcomm.org/messaging/contexts/v2
didDocument:
- $ref: '#/components/schemas/DIDDocument'
+ $ref: "#/components/schemas/DIDDocument"
didDocumentMetadata:
- $ref: '#/components/schemas/DIDDocumentMetadata'
+ $ref: "#/components/schemas/DIDDocumentMetadata"
didResolutionMetadata:
- $ref: '#/components/schemas/DIDResolutionMetadata'
+ $ref: "#/components/schemas/DIDResolutionMetadata"
DidOperationSubmission:
required:
- - id
- - didRef
+ - id
+ - didRef
type: object
properties:
id:
@@ -4029,13 +4169,13 @@ components:
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
EntityResponse:
required:
- - kind
- - self
- - id
- - name
- - walletId
- - createdAt
- - updatedAt
+ - kind
+ - self
+ - id
+ - name
+ - walletId
+ - createdAt
+ - updatedAt
type: object
properties:
kind:
@@ -4064,31 +4204,33 @@ components:
type: string
description: The `createdAt` timestamp of the entity.
format: date-time
- example: '2023-01-01T00:00:00Z'
+ example: "2023-01-01T00:00:00Z"
updatedAt:
type: string
description: The `updatedAt` timestamp of the entity.
format: date-time
- example: '2023-01-01T00:00:00Z'
+ example: "2023-01-01T00:00:00Z"
EntityResponsePage:
required:
- - kind
- - self
- - pageOf
+ - kind
+ - self
+ - pageOf
type: object
properties:
contents:
type: array
items:
- $ref: '#/components/schemas/EntityResponse'
- description: A sequence of CredentialSchemaResponse objects representing
+ $ref: "#/components/schemas/EntityResponse"
+ description:
+ A sequence of CredentialSchemaResponse objects representing
the list of credential schemas that the API response contains
example:
- - EntityResponse(Entity,/prism-agent/iam/entities/00000000-0000-0000-0000-000000000000,00000000-0000-0000-0000-000000000000,John
- Doe,00000000-0000-0000-0000-000000000000,2023-01-01T00:00:00Z,2023-01-01T00:00:00Z)
+ - EntityResponse(Entity,/prism-agent/iam/entities/00000000-0000-0000-0000-000000000000,00000000-0000-0000-0000-000000000000,John
+ Doe,00000000-0000-0000-0000-000000000000,2023-01-01T00:00:00Z,2023-01-01T00:00:00Z)
kind:
type: string
- description: A string field indicating the type of the API response. In
+ description:
+ A string field indicating the type of the API response. In
this case, it will always be set to `CredentialSchemaPage`
example: CredentialSchemaPage
self:
@@ -4097,27 +4239,30 @@ components:
example: /prism-agent/schema-registry/schemas?skip=10&limit=10
pageOf:
type: string
- description: A string field indicating the type of resource that the contents
+ description:
+ A string field indicating the type of resource that the contents
field contains
example: /prism-agent/schema-registry/schemas
next:
type: string
- description: An optional string field containing the URL of the next page
+ description:
+ An optional string field containing the URL of the next page
of results. If the API response does not contain any more pages, this
field should be set to None.
example: /prism-agent/schema-registry/schemas?skip=20&limit=10
previous:
type: string
- description: An optional string field containing the URL of the previous
+ description:
+ An optional string field containing the URL of the previous
page of results. If the API response is the first page of results, this
field should be set to None.
example: /prism-agent/schema-registry/schemas?skip=0&limit=10
ErrorResponse:
required:
- - status
- - type
- - title
- - instance
+ - status
+ - type
+ - title
+ - instance
type: object
properties:
status:
@@ -4131,22 +4276,25 @@ components:
example: https://example.org/doc/#model-MalformedEmail/
title:
type: string
- description: A short, human-readable summary of the problem type. It does
+ description:
+ A short, human-readable summary of the problem type. It does
not change from occurrence to occurrence of the problem.
example: Malformed email
detail:
type: string
- description: A human-readable explanation specific to this occurrence of
+ description:
+ A human-readable explanation specific to this occurrence of
the problem.
example: The received '{}à !è@!.b}' email does not conform to the email format
instance:
type: string
- description: A URI reference that identifies the specific occurrence of
+ description:
+ A URI reference that identifies the specific occurrence of
the problem. It may or may not yield further information if dereferenced.
example: The received '{}à !è@!.b}' email does not conform to the email format
HealthInfo:
required:
- - version
+ - version
type: object
properties:
version:
@@ -4155,14 +4303,14 @@ components:
example: 1.1.0
IssueCredentialRecord:
required:
- - recordId
- - thid
- - credentialFormat
- - claims
- - createdAt
- - role
- - protocolState
- - metaRetries
+ - recordId
+ - thid
+ - credentialFormat
+ - claims
+ - createdAt
+ - role
+ - protocolState
+ - metaRetries
type: object
properties:
recordId:
@@ -4185,8 +4333,8 @@ components:
description: The credential format for this offer.
example: JWT
enum:
- - JWT
- - AnonCreds
+ - JWT
+ - AnonCreds
subjectId:
type: string
description: |2
@@ -4221,10 +4369,11 @@ components:
type: string
description: The date and time when the issue credential record was created.
format: date-time
- example: '2024-03-20T18:35:17.903237532Z'
+ example: "2024-03-20T18:35:17.903237532Z"
updatedAt:
type: string
- description: The date and time when the issue credential record was last
+ description:
+ The date and time when the issue credential record was last
updated.
format: date-time
role:
@@ -4232,30 +4381,31 @@ components:
description: The role played by the agent in the credential issuance flow.
example: Issuer
enum:
- - Issuer
- - Holder
+ - Issuer
+ - Holder
protocolState:
type: string
description: The current state of the issue credential protocol execution.
example: CredentialSent
enum:
- - OfferPending
- - OfferSent
- - OfferReceived
- - RequestPending
- - RequestGenerated
- - RequestSent
- - RequestReceived
- - CredentialPending
- - CredentialGenerated
- - CredentialSent
- - CredentialReceived
- - ProblemReportPending
- - ProblemReportSent
- - ProblemReportReceived
+ - OfferPending
+ - OfferSent
+ - OfferReceived
+ - RequestPending
+ - RequestGenerated
+ - RequestSent
+ - RequestReceived
+ - CredentialPending
+ - CredentialGenerated
+ - CredentialSent
+ - CredentialReceived
+ - ProblemReportPending
+ - ProblemReportSent
+ - ProblemReportReceived
credential:
type: string
- description: The base64-encoded credential that was issued by the issuer
+ description:
+ The base64-encoded credential that was issued by the issuer
agent, in 'JWT' or 'AnonCreds' format depending on the offer type.
example: eyJzY2hlbWFfaWQiOiJodHRwOi8vaG9zdC5kb2NrZXIuaW50ZXJuYWw6ODA4MC9wcmlzbS1hZ2VudC9zY2hlbWEtcmVnaXN0cnkvc2NoZW1hcy8zOTZmZDE2OC02YmVmLTMyNDItYTJiNy1hNTZlYWM1MDc2OWMvc2NoZW1hIiwiY3JlZF9kZWZfaWQiOiJodHRwOi8vMTkyLjE2OC4wLjE0OjgwODAvcHJpc20tYWdlbnQvY3JlZGVudGlhbC1kZWZpbml0aW9uLXJlZ2lzdHJ5L2RlZmluaXRpb25zLzNhZmQxZWJkLWIzN2ItMzRiNC1iMWQ2LWYwMDQ5ZmU5ZmQ1Mi9kZWZpbml0aW9uIiwicmV2X3JlZ19pZCI6bnVsbCwidmFsdWVzIjp7ImdpdmVuTmFtZSI6eyJyYXciOiJBbGljZSIsImVuY29kZWQiOiIyNzAzNDY0MDAyNDExNzMzMTAzMzA2MzEyODA0NDAwNDMxODIxODQ4NjgxNjkzMTUyMDg4NjQwNTUzNTY1OTkzNDQxNzQzODc4MTUwNyJ9LCJlbWFpbEFkZHJlc3MiOnsicmF3IjoiYWxpY2VAd29uZGVybGFuZC5jb20iLCJlbmNvZGVkIjoiNzUxMDcwNDYzNDAxNjU2NzcwMTE5NDIwNzU2NDQwMDkwNjY1NDE2NjExNDg4MjI1ODkwMzM2Nzk4NjEyMDkxODY0OTI3Njg2Njk5MjQifSwiZmFtaWx5TmFtZSI6eyJyYXciOiJXb25kZXJsYW5kIiwiZW5jb2RlZCI6IjE2NzkwODQ5MzEyMzc0Nzk0NzM2ODEzMzc3NTY3MjUzODUxMzczNjA3OTcwNDczMzc3NzAxNDc3MjY5MTk0MDE5NTU3NjU0NTYyMDM1In0sImRhdGVPZklzc3VhbmNlIjp7InJhdyI6IjIwMjAtMTEtMTNUMjA6MjA6MzkrMDA6MDAiLCJlbmNvZGVkIjoiNTM4Njg1NTk1MzE3NDg0NjcwOTc1MjA4NTkwNTMwODE4MzU3NDc0MzU2MTE2MDY4NDIwNDExNDc1ODIwMDQ4NzQzNDgwNDYxNjQ2ODUifSwiZHJpdmluZ0xpY2Vuc2VJRCI6eyJyYXciOiIxMjM0NSIsImVuY29kZWQiOiIxMjM0NSJ9LCJkcml2aW5nQ2xhc3MiOnsicmF3IjoiMyIsImVuY29kZWQiOiIzIn19LCJzaWduYXR1cmUiOnsicF9jcmVkZW50aWFsIjp7Im1fMiI6IjMzNjg4ODUzNTU3NTg2MDI3MDg3OTY5ODAzMjgzMzcyNzE4Nzc5MDAzNDAzMDgwODMzMjQzNDIxMTU3MDA5NzE4MDUzMTMyNDIwODAwIiwiYSI6IjEwMjUxMTg2OTU5MTg2NDc2NDcwNzU0MTQ0MDg5NDE3MjI4OTM1Mjk0ODgxNDExMTc5ODYwNzgxODIxODY2OTcyODIyMzg1MTQ1OTcwNDA4Mzk2Mjg5OTM2NzgzNTUxMDk4NDA2MjE2MjcwNjgyNDM1ODg3NjY0OTI0MzQwMDg3NTY4MDMyNzMyMzYwMDc5MTI2ODk2MDU3NDA3MTYyMjI0NDgwODM2NTgzNjY2MzQ1MzA5NzQ0NDE5NjA0ODg5ODA1NDU3Mjc4NDE0MjgyMjA4NzIzMDIwNDQzNzk0MjM0NzU1NTgwNjA1MTE1NjU3NTQ4NjE1MTgwNTU1ODEzMjA0MzQyNjkzNjYyODQzNzY4MjQ2NDM1NjU4MjQ5MDYyMjUxMzYwNzE2MzEyNzM4MjAyMTU2NTEwNzM2NDY1ODk2NjIyNDY4MDk3OTY0OTk0NTA1NDUwMjczMzQ2Mzk4MzY4NzcxNDM3MzAzNTI2NjE0NTk4NTU4Mjg0MTAxNzk0NjYwOTAxNDMwOTI4MzY1MTk3MzA2MDIxMzQ5OTQ3MDI2MzIzMzEwOTE3MjgzODM0ODY2NzI1MzgyMDg4NDIzNDU1NzE0MDY3MTk1NDEzMDA4MzAxNTQ2MTA1NzY4NTAxNzMxNjEwMjk3MDY5ODUyNjAxMTgxMTM3OTg2NjM2MDU2MjI4MTE4NzUzMTM1NjMxMDIwNzA0MzYxODQxNTg0MjA0NzIwMDU1NjY0ODIxMTczOTA3MzYyMTQzNTQyNjk1NTExMTMxNzU3NTE0OTUxMDY2ODQ2MzIyMDAyNzYxMzg4MzIwNjkyNSIsImUiOiIyNTkzNDQ3MjMwNTUwNjIwNTk5MDcwMjU0OTE0ODA2OTc1NzE5MzgyNzc4ODk1MTUxNTIzMDYyNDk3Mjg1ODMxMDU2NjU4MDA3MTMzMDY3NTkxNDk5ODE2OTA1NTkxOTM5ODcxNDMwMTIzNjc5MTMyMDYyOTkzMjM4OTk2OTY5NDIyMTMyMzU5NTY3NDI5Mjk4MTYwMTkzMjA4MDYyNzM5NTc5MDExNDE1Njk0NDAwMjUyMTkiLCJ2IjoiMTAwODYwMTE5NjExNDQ0MjUxODg1ODcyNzA0OTEyNDQwMTQzNTA0MDEwMDQ3NzE3MzYxNzgxMjIwOTQ0OTA3OTE3ODM0NTE3NjQyOTk5MDgxMjEzMDcyNTI4NzU5NTczMzIyNDM1NjU5NzY4OTI2NzA4MjE0NTI5Njg0Njg5NTc5MjAwNzY4MDkxMTM0OTM0MzYxNDUyNzM5ODUwMjEyODc1MDUwMzg5NjkzOTMxMjEzMDg2MTUyOTM4NzA2ODc4MzQyNjIxNjQ1MTc2NDY5NTU0NDMyNTY2MDk0MDY5NjU2ODkzNDg1NjQyNDI2MTc0MjA5MjY3OTI1MDEzODkxMTU2MzAzMzY0MzUwMzgwNTUwMzQ4OTk3MDI1Nzc3NDc5NDg3ODI0NDkzNzg4MDYwNTg1NzMxMTY2NDM5OTE1MTc3ODUyNTYwNjczMjkwODA2Mjk5ODEyOTY1NjMwNDc2OTc0NzExNDY4MDE1MzY4NzM2NTc3MDEzNDE2NjE3ODc0MTc3ODgwNjMzNTc1OTAwMzQyODM5MDUxNjc4NjExNDMxMTk5Mzk3NTIzMDE5Njc0NTA3MjM0NDAzNzcyMTcxMDM3Nzg3NzUyNTMwMjIyODYyNDg5OTMzMzczMzY1MjIwNTc4MDIzNDY2NjkyMDQ4MTA0NTE0NjczMzMwMzMwNzQ1OTEyMjUzNzQ0MDQwMjI1NTM4NjMxNDk2MjY4NDM0MDk5Njk3Nzk1NTY5MDA3MTExMjQzMTg4MTc3MzUyNjE5MTUxNzk1NjEzNTAwNjg5MzUwMzQyNTk3NjA1ODY2MjUyOTYwMjQ3ODg4OTE2NDIwNDcyMDEzNDYzMTA5NTA5MjMxNDcwNjc4MDc5MDI2Mzc3MzY4NDEwNTIyODg3NDExOTIyMzE4Njk5NzA4MjkxNzI4NTg3ODgzNjExODMyMjU4MTE5MzI2ODQ5NjkxODI1MDI2MzU2NDQ1OTM1NjYxOTkyODEyNjIwNDY4MzAxMjEwMzMwNTA1NjEwMjYyNTU5MDk5NDgwNzcxMjA0NDU0ODg0MDI5ODA3MDcwOTM4NDU5OTgxNDM1NjQyNTkzNTQyODc0ODAifSwicl9jcmVkZW50aWFsIjpudWxsfSwic2lnbmF0dXJlX2NvcnJlY3RuZXNzX3Byb29mIjp7InNlIjoiMjMwNDc5NjEzNTA0MDI5NTI3NTk3NzM3MTY4NjY0OTQ5MzQwNzk1NTg1ODM5NTQ4OTI2MTEwMjQ2NzU0NzA3OTgyNjc2MDEyMjIyMTYyNzQyNTQ2Nzg4NDI3MDA4MDQ5NzIyNDMwNDgyODAyOTYyNTgxNDE2ODI2MjEzMTgwMTE4MTA4MTA1Nzg1NjA4OTg5NjEyNTU0ODMwOTE5MjU4MTI0NDgyMzUwNTQ2MTkxOTQ5NTU5ODM2NTk4NzcxMTE0MzI1NjA5MTI4MjUxMTc1MDM4NDMxNDA2NzM2NTc1MDkwMzk5ODk0MDQzMjc3MTg5MTM3MzE1NTM5NTQ2MTE3Mjk2NTM1OTMyOTQ3NDk3NTU0Mjg0NDc1NjkxNDE1NDEzMzIzNjE2OTYyNTk1NDAzMTkxMjQ4ODY2NDE1MjI0NDY2MTU2OTgyODg4OTkyNTAxNjc1NTcwNjI0MzQ2MzMyMTE0NjMzMDQ1NzUxNDg3NzU3ODM3MDA5Mzc3ODMwNTI1MTU5MjUwNjMwMjcxNjY3NDQxMDI3MTM5MjE3Nzc5ODU5MDExMjUxOTc1OTczNjY0NTc4MjMxOTk1Mzc3OTE4Mjg4MTkyNjIyMDM5NDEzMDM0ODg5MjM3Mzg2NzU4Mzg3NTcwNTMxNDc1OTQxMDU2MTg3NzUzOTEyNDA0NzkwNzQ5NzgzMTM0OTk3MDgzODk3NjE5MTczMTg3MDg1MzE1MjQ3NTM4NjU2OTcwOTE0NzI2MzM1ODA1ODY5OTk3NzI3OTc5NTUwMjIzNjkzMDA2MjcwNjIzNTc3NjM2NTIyNjIyNTY0MTE4NTMiLCJjIjoiOTM2NzQ1MDczNzcxNzQ3MjE3OTg3OTY2OTYzMDQxNzUzMTE4NDk0NDE4NDQ0NzQ1MDI3NzAyMjI3Nzk0NzU1ODQ2Mjg3ODMzMzU4NTAifSwicmV2X3JlZyI6bnVsbCwid2l0bmVzcyI6bnVsbH0=
issuingDID:
@@ -4267,67 +4417,74 @@ components:
example: did:prism:3bb0505d13fcb04d28a48234edb27b0d4e6d7e18a81e2c1abab58f3bbc21ce6f
metaRetries:
type: integer
- description: The maximum background processing attempts remaining for this
+ description:
+ The maximum background processing attempts remaining for this
record.
format: int32
example: 5
IssueCredentialRecordPage:
required:
- - kind
- - self
- - pageOf
+ - kind
+ - self
+ - pageOf
type: object
properties:
contents:
type: array
items:
- $ref: '#/components/schemas/IssueCredentialRecord'
+ $ref: "#/components/schemas/IssueCredentialRecord"
description: |2
An sequence of IssueCredentialRecord resources representing the list of credential records that the paginated response contains.
example: []
kind:
type: string
- description: A string that identifies the type of resource being returned
+ description:
+ A string that identifies the type of resource being returned
in the response.
example: Collection
self:
type: string
- description: The URL that uniquely identifies the resource being returned
+ description:
+ The URL that uniquely identifies the resource being returned
in the response.
example: /prism-agent/issue-credentials/records?offset=10&limit=10
pageOf:
type: string
- description: A string field indicating the type of resource that the contents
+ description:
+ A string field indicating the type of resource that the contents
field contains.
example: /prism-agent/issue-credentials/records
next:
type: string
- description: An optional string field containing the URL of the next page
+ description:
+ An optional string field containing the URL of the next page
of results. If the API response does not contain any more pages, this
field should be set to None.
example: /prism-agent/issue-credentials/records?offset=20&limit=10
previous:
type: string
- description: An optional string field containing the URL of the previous
+ description:
+ An optional string field containing the URL of the previous
page of results. If the API response is the first page of results, this
field should be set to None.
example: /prism-agent/issue-credentials/records?offset=0&limit=10
Json:
- description: The service endpoint. Can contain multiple possible values as described
+ description:
+ The service endpoint. Can contain multiple possible values as described
in the [Create DID operation](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#create-did)
example: https://example.com
oneOf:
- - $ref: '#/components/schemas/Arr'
- - $ref: '#/components/schemas/Bool'
- - $ref: '#/components/schemas/Null'
- - $ref: '#/components/schemas/Num'
- - $ref: '#/components/schemas/Obj'
- - $ref: '#/components/schemas/Str'
+ - $ref: "#/components/schemas/Arr"
+ - $ref: "#/components/schemas/Bool"
+ - $ref: "#/components/schemas/Null"
+ - $ref: "#/components/schemas/Num"
+ - $ref: "#/components/schemas/Obj"
+ - $ref: "#/components/schemas/Str"
ManagedDID:
required:
- - did
- - status
+ - did
+ - status
type: object
properties:
did:
@@ -4336,7 +4493,8 @@ components:
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
longFormDid:
type: string
- description: A long-form DID. Mandatory when status is not `PUBLISHED` and
+ description:
+ A long-form DID. Mandatory when status is not `PUBLISHED` and
optional when status is `PUBLISHED`
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff:Cr4BCrsBElsKBmF1dGgtMRAEQk8KCXNlY3AyNTZrMRIg0opTuxu-zt6aRbT1tPniG4eu4CYsQPM3rrLzvzNiNgwaIIFTnyT2N4U7qCQ78qtWC3-p0el6Hvv8qxG5uuEw-WgMElwKB21hc3RlcjAQAUJPCglzZWNwMjU2azESIKhBU0eCOO6Vinz_8vhtFSAhYYqrkEXC8PHGxkuIUev8GiAydFHLXb7c22A1Uj_PR21NZp6BCDQqNq2xd244txRgsQ
status:
@@ -4347,8 +4505,8 @@ components:
example: CREATED
ManagedDIDKeyTemplate:
required:
- - id
- - purpose
+ - id
+ - purpose
type: object
properties:
id:
@@ -4356,13 +4514,13 @@ components:
description: Identifier of a verification material in the DID Document
example: key-1
purpose:
- $ref: '#/components/schemas/Purpose'
+ $ref: "#/components/schemas/Purpose"
description: A key-pair template to add to DID document.
ManagedDIDPage:
required:
- - self
- - kind
- - pageOf
+ - self
+ - kind
+ - pageOf
type: object
properties:
self:
@@ -4378,24 +4536,24 @@ components:
contents:
type: array
items:
- $ref: '#/components/schemas/ManagedDID'
+ $ref: "#/components/schemas/ManagedDID"
Map_AnoncredRequestedAttributeV1:
type: object
additionalProperties:
- $ref: '#/components/schemas/AnoncredRequestedAttributeV1'
+ $ref: "#/components/schemas/AnoncredRequestedAttributeV1"
Map_AnoncredRequestedPredicateV1:
type: object
additionalProperties:
- $ref: '#/components/schemas/AnoncredRequestedPredicateV1'
+ $ref: "#/components/schemas/AnoncredRequestedPredicateV1"
Map_String:
type: object
additionalProperties:
type: string
- 'Null':
+ "Null":
type: object
Num:
required:
- - value
+ - value
type: object
properties:
value:
@@ -4404,8 +4562,8 @@ components:
type: object
Options:
required:
- - challenge
- - domain
+ - challenge
+ - domain
type: object
properties:
challenge:
@@ -4416,7 +4574,8 @@ components:
type: string
description: The domain value can be any string or URI.
example: https://example-verifier.com
- description: The options to use when creating the proof presentation request
+ description:
+ The options to use when creating the proof presentation request
(e.g., domain, challenge).
PatchContextAction:
type: object
@@ -4429,11 +4588,11 @@ components:
example: https://didcomm.org/messaging/contexts/v2
PresentationStatus:
required:
- - presentationId
- - thid
- - role
- - status
- - metaRetries
+ - presentationId
+ - thid
+ - role
+ - status
+ - metaRetries
type: object
properties:
presentationId:
@@ -4442,42 +4601,45 @@ components:
example: 3c6d9fa5-d277-431e-a6cb-d3956e47e610
thid:
type: string
- description: The unique identifier of the thread this presentation record
+ description:
+ The unique identifier of the thread this presentation record
belongs to. The value will identical on both sides of the presentation
flow (verifier and prover)
example: 0527aea1-d131-3948-a34d-03af39aba8b4
role:
type: string
- description: The role played by the Prism agent in the proof presentation
+ description:
+ The role played by the Prism agent in the proof presentation
flow.
example: Verifier
enum:
- - Verifier
- - Prover
+ - Verifier
+ - Prover
status:
type: string
description: The current state of the proof presentation record.
example: RequestPending
enum:
- - RequestPending
- - RequestSent
- - RequestReceived
- - RequestRejected
- - PresentationPending
- - PresentationGenerated
- - PresentationSent
- - PresentationReceived
- - PresentationVerified
- - PresentationAccepted
- - PresentationRejected
- - ProblemReportPending
- - ProblemReportSent
- - ProblemReportReceived
+ - RequestPending
+ - RequestSent
+ - RequestReceived
+ - RequestRejected
+ - PresentationPending
+ - PresentationGenerated
+ - PresentationSent
+ - PresentationReceived
+ - PresentationVerified
+ - PresentationAccepted
+ - PresentationRejected
+ - ProblemReportPending
+ - ProblemReportSent
+ - ProblemReportReceived
proofs:
type: array
items:
- $ref: '#/components/schemas/ProofRequestAux'
- description: The type of proofs requested in the context of this proof presentation
+ $ref: "#/components/schemas/ProofRequestAux"
+ description:
+ The type of proofs requested in the context of this proof presentation
request (e.g., VC schema, trusted issuers, etc.)
example: []
data:
@@ -4488,26 +4650,28 @@ components:
example: []
connectionId:
type: string
- description: The unique identifier of an established connection between
+ description:
+ The unique identifier of an established connection between
the verifier and the prover.
example: bc528dc8-69f1-4c5a-a508-5f8019047900
metaRetries:
type: integer
- description: The maximum background processing attempts remaining for this
+ description:
+ The maximum background processing attempts remaining for this
record
format: int32
example: 5
PresentationStatusPage:
required:
- - self
- - kind
- - pageOf
+ - self
+ - kind
+ - pageOf
type: object
properties:
contents:
type: array
items:
- $ref: '#/components/schemas/PresentationStatus'
+ $ref: "#/components/schemas/PresentationStatus"
description: A sequence of Presentation objects.
example: []
self:
@@ -4525,48 +4689,53 @@ components:
next:
type: string
description: URL of the next page (if available)
- example: ''
+ example: ""
previous:
type: string
description: URL of the previous page (if available)
- example: ''
+ example: ""
Proof:
required:
- - type
- - created
- - verificationMethod
- - proofPurpose
- - proofValue
- - jws
+ - type
+ - created
+ - verificationMethod
+ - proofPurpose
+ - proofValue
+ - jws
type: object
properties:
type:
type: string
- description: The type of cryptographic signature algorithm used to generate
+ description:
+ The type of cryptographic signature algorithm used to generate
the proof.
example: Ed25519Signature2018
created:
type: string
- description: The date and time at which the proof was created, in UTC format.
+ description:
+ The date and time at which the proof was created, in UTC format.
This field is used to ensure that the proof was generated before or at
the same time as the credential definition itself.
format: date-time
example: 2022-03-10T12:00Z
verificationMethod:
type: string
- description: The verification method used to generate the proof. This is
+ description:
+ The verification method used to generate the proof. This is
usually a DID and key ID combination that can be used to look up the public
key needed to verify the proof.
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff#key-1
proofPurpose:
type: string
- description: 'The purpose of the proof (for example: `assertionMethod`).
+ description:
+ "The purpose of the proof (for example: `assertionMethod`).
This indicates that the proof is being used to assert that the issuer
- really issued this credential definition instance.'
+ really issued this credential definition instance."
example: assertionMethod
proofValue:
type: string
- description: The cryptographic signature value that was generated using
+ description:
+ The cryptographic signature value that was generated using
the private key associated with the verification method, and which can
be used to verify the proof.
example: FiPfjknHikKmZ...
@@ -4576,14 +4745,16 @@ components:
example: eyJhbGciOiJFZERTQSIsImI2NCI6ZmFsc2UsImNyaXQiOlsiYjY0Il0sImt0eSI6Ik...
domain:
type: string
- description: It specifies the domain context within which the credential
+ description:
+ It specifies the domain context within which the credential
definition and proof are being used
example: prims.atala.com
- description: A digital signature over the Credential Definition for the sake
+ description:
+ A digital signature over the Credential Definition for the sake
of asserting authorship. A piece of Metadata.
example:
type: Ed25519Signature2018
- created: '2022-03-10T12:00:00Z'
+ created: "2022-03-10T12:00:00Z"
verificationMethod: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff#key-1
proofPurpose: assertionMethod
proofValue: FiPfjknHikKmZ...
@@ -4591,41 +4762,46 @@ components:
domain: prims.atala.com
Proof1:
required:
- - type
- - created
- - verificationMethod
- - proofPurpose
- - proofValue
- - jws
+ - type
+ - created
+ - verificationMethod
+ - proofPurpose
+ - proofValue
+ - jws
type: object
properties:
type:
type: string
- description: The type of cryptographic signature algorithm used to generate
+ description:
+ The type of cryptographic signature algorithm used to generate
the proof.
example: Ed25519Signature2018
created:
type: string
- description: The date and time at which the proof was created, in UTC format.
+ description:
+ The date and time at which the proof was created, in UTC format.
This field is used to ensure that the proof was generated before or at
the same time as the credential schema itself.
format: date-time
example: 2022-03-10T12:00Z
verificationMethod:
type: string
- description: The verification method used to generate the proof. This is
+ description:
+ The verification method used to generate the proof. This is
usually a DID and key ID combination that can be used to look up the public
key needed to verify the proof.
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff#key-1
proofPurpose:
type: string
- description: 'The purpose of the proof (for example: `assertionMethod`).
+ description:
+ "The purpose of the proof (for example: `assertionMethod`).
This indicates that the proof is being used to assert that the issuer
- really issued this credential schema instance.'
+ really issued this credential schema instance."
example: assertionMethod
proofValue:
type: string
- description: The cryptographic signature value that was generated using
+ description:
+ The cryptographic signature value that was generated using
the private key associated with the verification method, and which can
be used to verify the proof.
example: FiPfjknHikKmZ...
@@ -4635,14 +4811,16 @@ components:
example: eyJhbGciOiJFZERTQSIsImI2NCI6ZmFsc2UsImNyaXQiOlsiYjY0Il0sImt0eSI6Ik...
domain:
type: string
- description: It specifies the domain context within which the credential
+ description:
+ It specifies the domain context within which the credential
schema and proof are being used
example: prims.atala.com
- description: A digital signature over the Credential Schema for the sake of
+ description:
+ A digital signature over the Credential Schema for the sake of
asserting authorship. A piece of Metadata.
example:
type: Ed25519Signature2018
- created: '2022-03-10T12:00:00Z'
+ created: "2022-03-10T12:00:00Z"
verificationMethod: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff#key-1
proofPurpose: assertionMethod
proofValue: FiPfjknHikKmZ...
@@ -4650,7 +4828,7 @@ components:
domain: prims.atala.com
ProofRequestAux:
required:
- - schemaId
+ - schemaId
type: object
properties:
schemaId:
@@ -4661,15 +4839,16 @@ components:
type: array
items:
type: string
- description: One or more issuers that are trusted by the verifier emitting
+ description:
+ One or more issuers that are trusted by the verifier emitting
the proof presentation request.
example:
- - did:web:atalaprism.io/users/testUser
- - did.prism:123
- - did:prism:...
+ - did:web:atalaprism.io/users/testUser
+ - did.prism:123
+ - did:prism:...
PublicKeyJwk:
required:
- - kty
+ - kty
type: object
properties:
crv:
@@ -4685,21 +4864,21 @@ components:
description: Purpose of the verification material in the DID Document
example: authentication
enum:
- - assertionMethod
- - authentication
- - capabilityDelegation
- - capabilityInvocation
- - keyAgreement
+ - assertionMethod
+ - authentication
+ - capabilityDelegation
+ - capabilityInvocation
+ - keyAgreement
RemoveEntryById:
required:
- - id
+ - id
type: object
properties:
id:
type: string
RequestPresentationAction:
required:
- - action
+ - action
type: object
properties:
action:
@@ -4707,41 +4886,44 @@ components:
description: The action to perform on the proof presentation record.
example: request-accept
enum:
- - request-accept
- - request-reject
- - presentation-accept
- - presentation-reject
+ - request-accept
+ - request-reject
+ - presentation-accept
+ - presentation-reject
proofId:
type: array
items:
type: string
- description: The unique identifier of the issue credential record - and
+ description:
+ The unique identifier of the issue credential record - and
hence VC - to use as the prover accepts the presentation request. Only
applicable on the prover side when the action is `request-accept`.
anoncredPresentationRequest:
- $ref: '#/components/schemas/AnoncredCredentialProofsV1'
+ $ref: "#/components/schemas/AnoncredCredentialProofsV1"
RequestPresentationInput:
required:
- - connectionId
+ - connectionId
type: object
properties:
connectionId:
type: string
- description: The unique identifier of an established connection between
+ description:
+ The unique identifier of an established connection between
the verifier and the prover.
format: uuid
example: bc528dc8-69f1-4c5a-a508-5f8019047900
options:
- $ref: '#/components/schemas/Options'
+ $ref: "#/components/schemas/Options"
proofs:
type: array
items:
- $ref: '#/components/schemas/ProofRequestAux'
- description: The type of proofs requested in the context of this proof presentation
+ $ref: "#/components/schemas/ProofRequestAux"
+ description:
+ The type of proofs requested in the context of this proof presentation
request (e.g., VC schema, trusted issuers, etc.)
example: []
anoncredPresentationRequest:
- $ref: '#/components/schemas/AnoncredPresentationRequestV1'
+ $ref: "#/components/schemas/AnoncredPresentationRequestV1"
credentialFormat:
type: string
description: The credential format (default to 'JWT')
@@ -4750,9 +4932,9 @@ components:
type: object
Service:
required:
- - id
- - type
- - serviceEndpoint
+ - id
+ - type
+ - serviceEndpoint
type: object
properties:
id:
@@ -4763,43 +4945,44 @@ components:
Returns the full ID (with DID prefix) when resolving DID
example: service-1
type:
- description: Service type. Can contain multiple possible values as described
+ description:
+ Service type. Can contain multiple possible values as described
in the [Create DID operation](https://github.com/input-output-hk/prism-did-method-spec/blob/main/w3c-spec/PRISM-method.md#create-did)
under the construction section.
example: LinkedDomains
oneOf:
- - type: array
- items:
- type: string
- - type: string
+ - type: array
+ items:
+ type: string
+ - type: string
serviceEndpoint:
- $ref: '#/components/schemas/Json'
+ $ref: "#/components/schemas/Json"
description: A service that should appear in the DID document. https://www.w3.org/TR/did-core/#services
StatusListCredential:
required:
- - issuer
- - id
- - issuanceDate
- - credentialSubject
- - proof
+ - issuer
+ - id
+ - issuanceDate
+ - credentialSubject
+ - proof
type: object
properties:
- '@context':
+ "@context":
type: array
items:
type: string
description: List of JSON-LD contexts
example:
- - https://www.w3.org/2018/credentials/v1
- - https://w3id.org/vc/status-list/2021/v1
+ - https://www.w3.org/2018/credentials/v1
+ - https://w3id.org/vc/status-list/2021/v1
type:
type: array
items:
type: string
description: List of credential types
example:
- - VerifiableCredential
- - StatusList2021Credential
+ - VerifiableCredential
+ - StatusList2021Credential
issuer:
type: string
description: DID of the issuer of status list credential
@@ -4812,29 +4995,30 @@ components:
type: string
description: Issuance timestamp of status list credential
format: date-time
- example: '2024-03-20T18:35:17.949576647Z'
+ example: "2024-03-20T18:35:17.949576647Z"
credentialSubject:
- $ref: '#/components/schemas/CredentialSubject'
+ $ref: "#/components/schemas/CredentialSubject"
proof:
- description: Embedded proof to verify data integrity of status list credential,
+ description:
+ Embedded proof to verify data integrity of status list credential,
includes "type" property which defines an algorithm to be used for proof
verification
example:
type: DataIntegrityProof
proofPurpose: assertionMethod
verificationMethod: data:application/json;base64,eyJAY29udGV4dCI6WyJodHRwczovL3czaWQub3JnL3NlY3VyaXR5L211bHRpa2V5L3YxIl0sInR5cGUiOiJNdWx0aWtleSIsInB1YmxpY0tleU11bHRpYmFzZSI6InVNRmt3RXdZSEtvWkl6ajBDQVFZSUtvWkl6ajBEQVFjRFFnQUVRUENjM1M0X0xHVXRIM25DRjZ2dUw3ekdEMS13UmVrMHRHbnB0UnZUakhIMUdvTnk1UFBIZ0FmNTZlSzNOd3B0LWNGcmhrT2pRQk1rcFRKOHNaS1pCZz09In0=
- created: '2024-01-22T22:40:34.560891Z'
+ created: "2024-01-22T22:40:34.560891Z"
proofValue: zAN1rKq8npnByRqPRxhjHEkivhN8AhA8V6MqDJga1zcCUEvPDUoqJB5Rj6ZJHTCnBZ98VXTEVd1rprX2wvP1MAaTEi7Pm241qm
cryptoSuite: eddsa-jcs-2022
StatusPurpose:
description: type of status list credential, either revocation or suspension
example: Revocation
oneOf:
- - $ref: '#/components/schemas/Revocation'
- - $ref: '#/components/schemas/Suspension'
+ - $ref: "#/components/schemas/Revocation"
+ - $ref: "#/components/schemas/Suspension"
Str:
required:
- - value
+ - value
type: object
properties:
value:
@@ -4843,7 +5027,7 @@ components:
type: object
UpdateEntityNameRequest:
required:
- - name
+ - name
type: object
properties:
name:
@@ -4854,7 +5038,7 @@ components:
maxLength: 128
UpdateEntityWalletIdRequest:
required:
- - walletId
+ - walletId
type: object
properties:
walletId:
@@ -4868,33 +5052,33 @@ components:
actions:
type: array
items:
- $ref: '#/components/schemas/UpdateManagedDIDRequestAction'
+ $ref: "#/components/schemas/UpdateManagedDIDRequestAction"
UpdateManagedDIDRequestAction:
required:
- - actionType
+ - actionType
type: object
properties:
actionType:
- $ref: '#/components/schemas/ActionType'
+ $ref: "#/components/schemas/ActionType"
addKey:
- $ref: '#/components/schemas/ManagedDIDKeyTemplate'
+ $ref: "#/components/schemas/ManagedDIDKeyTemplate"
removeKey:
- $ref: '#/components/schemas/RemoveEntryById'
+ $ref: "#/components/schemas/RemoveEntryById"
addService:
- $ref: '#/components/schemas/Service'
+ $ref: "#/components/schemas/Service"
removeService:
- $ref: '#/components/schemas/RemoveEntryById'
+ $ref: "#/components/schemas/RemoveEntryById"
updateService:
- $ref: '#/components/schemas/UpdateManagedDIDServiceAction'
+ $ref: "#/components/schemas/UpdateManagedDIDServiceAction"
patchContext:
- $ref: '#/components/schemas/PatchContextAction'
+ $ref: "#/components/schemas/PatchContextAction"
description: |-
A list of actions to perform on DID document.
The field `addKey`, `removeKey`, `addService`, `removeService`, `updateService`, `patchContext` must corresponds to
the `actionType` specified. For example, `addKey` must be present when `actionType` is `ADD_KEY`.
UpdateManagedDIDServiceAction:
required:
- - id
+ - id
type: object
properties:
id:
@@ -4905,20 +5089,21 @@ components:
description: The type of the service
example: LinkedDomains
oneOf:
- - type: array
- items:
- type: string
- - type: string
+ - type: array
+ items:
+ type: string
+ - type: string
serviceEndpoint:
- $ref: '#/components/schemas/Json'
- description: A patch to existing Service. 'type' and 'serviceEndpoint' cannot
+ $ref: "#/components/schemas/Json"
+ description:
+ A patch to existing Service. 'type' and 'serviceEndpoint' cannot
both be empty.
VerificationMethod:
required:
- - id
- - type
- - controller
- - publicKeyJwk
+ - id
+ - type
+ - controller
+ - publicKeyJwk
type: object
properties:
id:
@@ -4934,11 +5119,11 @@ components:
description: The DID that controls the verification method.
example: did:prism:4a5b5cf0a513e83b598bbea25cd6196746747f361a73ef77068268bc9bd732ff
publicKeyJwk:
- $ref: '#/components/schemas/PublicKeyJwk'
+ $ref: "#/components/schemas/PublicKeyJwk"
description: A cryptographic public key expressed in the DID document. https://www.w3.org/TR/did-core/#verification-methods
VerificationPolicyConstraint:
required:
- - schemaId
+ - schemaId
type: object
properties:
schemaId:
@@ -4952,169 +5137,189 @@ components:
type: string
description: A list of DIDs of the trusted issuers.
example:
- - did:example:123456789abcdefghi
+ - did:example:123456789abcdefghi
VerificationPolicyInput:
required:
- - name
- - description
+ - name
+ - description
type: object
properties:
id:
type: string
- description: A unique identifier to address the verification policy instance.
+ description:
+ A unique identifier to address the verification policy instance.
UUID is generated by the backend.
format: uuid
example: 0527aea1-d131-3948-a34d-03af39aba8b5
name:
type: string
- description: A human-readable name for the verification policy. The `name`
+ description:
+ A human-readable name for the verification policy. The `name`
cannot be empty.
example: Trusted Issuers Verification Policy
minLength: 1
description:
type: string
description: A human-readable description of the verification policy.
- example: Verification policy that checks if the credential was issued by
+ example:
+ Verification policy that checks if the credential was issued by
a trusted issuer.
constraints:
type: array
items:
- $ref: '#/components/schemas/VerificationPolicyConstraint'
- description: The object that describes the constraints of the verification
+ $ref: "#/components/schemas/VerificationPolicyConstraint"
+ description:
+ The object that describes the constraints of the verification
policy. Each constraint is a tuple of the `schemaId` and a set of DIDs
of the trusted issuers.
example:
- - schemaId: https://example.com/driving-license-1.0
- trustedIssuers:
- - did:example:123456789abcdefghi
+ - schemaId: https://example.com/driving-license-1.0
+ trustedIssuers:
+ - did:example:123456789abcdefghi
VerificationPolicyResponse:
required:
- - self
- - kind
- - id
- - nonce
- - name
- - description
- - createdAt
- - updatedAt
+ - self
+ - kind
+ - id
+ - nonce
+ - name
+ - description
+ - createdAt
+ - updatedAt
type: object
properties:
self:
type: string
- description: The URL that uniquely identifies the resource being returned
+ description:
+ The URL that uniquely identifies the resource being returned
in the response.
example: /prism-agent/verification/policies/0527aea1-d131-3948-a34d-03af39aba8b4
kind:
type: string
- description: A string that identifies the type of resource being returned
+ description:
+ A string that identifies the type of resource being returned
in the response.
example: VerificationPolicy
id:
type: string
- description: A unique identifier to address the verification policy instance.
+ description:
+ A unique identifier to address the verification policy instance.
UUID is generated by the backend.
format: uuid
example: 0527aea1-d131-3948-a34d-03af39aba8b5
nonce:
type: integer
- description: A number that is changed every time the verification policy
+ description:
+ A number that is changed every time the verification policy
is updated.
format: int32
example: 1234
name:
type: string
- description: A human-readable name for the verification policy. The `name`
+ description:
+ A human-readable name for the verification policy. The `name`
cannot be empty.
example: Trusted Issuers Verification Policy
minLength: 1
description:
type: string
description: A human-readable description of the verification policy.
- example: Verification policy that checks if the credential was issued by
+ example:
+ Verification policy that checks if the credential was issued by
a trusted issuer.
createdAt:
type: string
- description: '[RFC3339](https://www.rfc-editor.org/rfc/rfc3339) date on
- which the verification policy was created.'
+ description:
+ "[RFC3339](https://www.rfc-editor.org/rfc/rfc3339) date on
+ which the verification policy was created."
format: date-time
example: 2022-03-10T12:00Z
updatedAt:
type: string
- description: '[RFC3339](https://www.rfc-editor.org/rfc/rfc3339) date on
- which the verification policy was updated.'
+ description:
+ "[RFC3339](https://www.rfc-editor.org/rfc/rfc3339) date on
+ which the verification policy was updated."
format: date-time
example: 2022-03-10T12:00Z
constraints:
type: array
items:
- $ref: '#/components/schemas/VerificationPolicyConstraint'
- description: The object that describes the constraints of the verification
+ $ref: "#/components/schemas/VerificationPolicyConstraint"
+ description:
+ The object that describes the constraints of the verification
policy. Each constraint is a tuple of the `schemaId` and a set of DIDs
of the trusted issuers.
example:
- - schemaId: https://example.com/driving-license-1.0
- trustedIssuers:
- - did:example:123456789abcdefghi
+ - schemaId: https://example.com/driving-license-1.0
+ trustedIssuers:
+ - did:example:123456789abcdefghi
VerificationPolicyResponsePage:
required:
- - self
- - kind
- - pageOf
+ - self
+ - kind
+ - pageOf
type: object
properties:
self:
type: string
- description: The URL that uniquely identifies the resource being returned
+ description:
+ The URL that uniquely identifies the resource being returned
in the response.
example: /prism-agent/verification/policies?name=Trusted&offset=0&limit=10
kind:
type: string
- description: A string that identifies the type of resource being returned
+ description:
+ A string that identifies the type of resource being returned
in the response.
example: VerificationPolicyPage
pageOf:
type: string
- description: A string field indicating the type of resource that the contents
+ description:
+ A string field indicating the type of resource that the contents
field contains
example: /prism-agent/verification/policies
next:
type: string
- description: An optional string field containing the URL of the next page
+ description:
+ An optional string field containing the URL of the next page
of results. If the API response does not contain any more pages, this
field should be set to None.
example: /prism-agent/verification/policies?skip=20&limit=10
previous:
type: string
- description: An optional string field containing the URL of the previous
+ description:
+ An optional string field containing the URL of the previous
page of results. If the API response is the first page of results, this
field should be set to None.
example: /prism-agent/verification/policies?skip=0&limit=10
contents:
type: array
items:
- $ref: '#/components/schemas/VerificationPolicyResponse'
- description: A sequence of VerificationPolicyResponse objects representing
+ $ref: "#/components/schemas/VerificationPolicyResponse"
+ description:
+ A sequence of VerificationPolicyResponse objects representing
the list of verification policies that the paginated response contains
example:
- - self: /prism-agent/verification/policies
- kind: VerificationPolicy
- id: 0527aea1-d131-3948-a34d-03af39aba8b4
- nonce: 0
- name: Trusted Issuers Verification Policy
- description: Verification policy that checks if the credential was issued
- by a trusted issuer.
- createdAt: '2022-03-10T12:00:00Z'
- updatedAt: '2022-03-10T12:00:00Z'
- constraints:
- - schemaId: https://example.com/driving-license-1.0
- trustedIssuers:
- - did:example:123456789abcdefghi
+ - self: /prism-agent/verification/policies
+ kind: VerificationPolicy
+ id: 0527aea1-d131-3948-a34d-03af39aba8b4
+ nonce: 0
+ name: Trusted Issuers Verification Policy
+ description:
+ Verification policy that checks if the credential was issued
+ by a trusted issuer.
+ createdAt: "2022-03-10T12:00:00Z"
+ updatedAt: "2022-03-10T12:00:00Z"
+ constraints:
+ - schemaId: https://example.com/driving-license-1.0
+ trustedIssuers:
+ - did:example:123456789abcdefghi
WalletDetail:
required:
- - id
- - name
- - createdAt
- - updatedAt
+ - id
+ - name
+ - createdAt
+ - updatedAt
type: object
properties:
id:
@@ -5130,17 +5335,17 @@ components:
type: string
description: The `createdAt` timestamp of the wallet.
format: date-time
- example: '2023-01-01T00:00:00Z'
+ example: "2023-01-01T00:00:00Z"
updatedAt:
type: string
description: The `updateddAt` timestamp of the wallet.
format: date-time
- example: '2023-01-01T00:00:00Z'
+ example: "2023-01-01T00:00:00Z"
WalletDetailPage:
required:
- - self
- - kind
- - pageOf
+ - self
+ - kind
+ - pageOf
type: object
properties:
self:
@@ -5156,13 +5361,13 @@ components:
contents:
type: array
items:
- $ref: '#/components/schemas/WalletDetail'
+ $ref: "#/components/schemas/WalletDetail"
WebhookNotification:
required:
- - id
- - url
- - customHeaders
- - createdAt
+ - id
+ - url
+ - customHeaders
+ - createdAt
type: object
properties:
id:
@@ -5175,17 +5380,17 @@ components:
description: A URL of webhook for event notification
example: http://example.com
customHeaders:
- $ref: '#/components/schemas/Map_String'
+ $ref: "#/components/schemas/Map_String"
createdAt:
type: string
description: A time which the webhook notification resource was created.
format: date-time
- example: '1970-01-01T00:00:00Z'
+ example: "1970-01-01T00:00:00Z"
WebhookNotificationPage:
required:
- - self
- - kind
- - pageOf
+ - self
+ - kind
+ - pageOf
type: object
properties:
self:
@@ -5201,28 +5406,31 @@ components:
contents:
type: array
items:
- $ref: '#/components/schemas/WebhookNotification'
+ $ref: "#/components/schemas/WebhookNotification"
securitySchemes:
apiKeyAuth:
type: apiKey
- description: API Key Authentication. The header `apikey` must be set with the
+ description:
+ API Key Authentication. The header `apikey` must be set with the
API key.
name: apikey
in: header
adminApiKeyAuth:
type: apiKey
- description: Admin API Key Authentication. The header `x-admin-api-key` must
+ description:
+ Admin API Key Authentication. The header `x-admin-api-key` must
be set with the Admin API key.
name: x-admin-api-key
in: header
jwtAuth:
type: http
- description: JWT Authentication. The header `Authorization` must be set with
+ description:
+ JWT Authentication. The header `Authorization` must be set with
the JWT token using `Bearer` scheme
name: Authorization
in: header
scheme: Bearer
security:
-- apiKeyAuth: []
- adminApiKeyAuth: []
- jwtAuth: []
+ - apiKeyAuth: []
+ adminApiKeyAuth: []
+ jwtAuth: []
diff --git a/prism-agent/service/server/src/main/resources/application.conf b/cloud-agent/service/server/src/main/resources/application.conf
similarity index 100%
rename from prism-agent/service/server/src/main/resources/application.conf
rename to cloud-agent/service/server/src/main/resources/application.conf
diff --git a/prism-agent/service/server/src/main/resources/logback.xml b/cloud-agent/service/server/src/main/resources/logback.xml
similarity index 100%
rename from prism-agent/service/server/src/main/resources/logback.xml
rename to cloud-agent/service/server/src/main/resources/logback.xml
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/LogUtils.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/LogUtils.scala
similarity index 91%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/LogUtils.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/LogUtils.scala
index 0edb7598c6..bfe877b818 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/LogUtils.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/LogUtils.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala
+package org.hyperledger.identus
import zio.*
-import io.iohk.atala.api.http.RequestContext
+import org.hyperledger.identus.api.http.RequestContext
import sttp.model.Header
object LogUtils {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/notification/JsonEventEncoders.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/notification/JsonEventEncoders.scala
similarity index 63%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/notification/JsonEventEncoders.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/notification/JsonEventEncoders.scala
index dc78bec0b1..c5971216c1 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/notification/JsonEventEncoders.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/notification/JsonEventEncoders.scala
@@ -1,18 +1,18 @@
-package io.iohk.atala.agent.notification
-
-import io.iohk.atala.agent.walletapi.model.ManagedDIDDetail
-import io.iohk.atala.castor.controller.http.ManagedDID
-import io.iohk.atala.castor.controller.http.ManagedDID.*
-import io.iohk.atala.connect.controller.http.Connection
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.event.notification.Event
-import io.iohk.atala.issue.controller.http.IssueCredentialRecord
-import io.iohk.atala.pollux.core.model.{
+package org.hyperledger.identus.agent.notification
+
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDDetail
+import org.hyperledger.identus.castor.controller.http.ManagedDID
+import org.hyperledger.identus.castor.controller.http.ManagedDID.*
+import org.hyperledger.identus.connect.controller.http.Connection
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.event.notification.Event
+import org.hyperledger.identus.issue.controller.http.IssueCredentialRecord
+import org.hyperledger.identus.pollux.core.model.{
IssueCredentialRecord as PolluxIssueCredentialRecord,
PresentationRecord as PolluxPresentationRecord
}
-import io.iohk.atala.presentproof.controller.http.PresentationStatus
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.presentproof.controller.http.PresentationStatus
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import zio.json.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/notification/WebhookPublisher.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/notification/WebhookPublisher.scala
similarity index 83%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/notification/WebhookPublisher.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/notification/WebhookPublisher.scala
index c88aa35806..7eefc95f5c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/notification/WebhookPublisher.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/notification/WebhookPublisher.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.agent.notification
+package org.hyperledger.identus.agent.notification
-import io.iohk.atala.agent.notification.JsonEventEncoders.*
-import io.iohk.atala.agent.notification.WebhookPublisherError.UnexpectedError
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.walletapi.model.ManagedDIDDetail
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.event.notification.EventNotificationConfig
-import io.iohk.atala.event.notification.{Event, EventConsumer, EventNotificationService}
-import io.iohk.atala.pollux.core.model.{IssueCredentialRecord, PresentationRecord}
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.notification.JsonEventEncoders.*
+import org.hyperledger.identus.agent.notification.WebhookPublisherError.UnexpectedError
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDDetail
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementService
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.event.notification.EventNotificationConfig
+import org.hyperledger.identus.event.notification.{Event, EventConsumer, EventNotificationService}
+import org.hyperledger.identus.pollux.core.model.{IssueCredentialRecord, PresentationRecord}
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import zio.http.*
import zio.json.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/notification/WebhookPublisherError.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/notification/WebhookPublisherError.scala
similarity index 80%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/notification/WebhookPublisherError.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/notification/WebhookPublisherError.scala
index 4d629c0684..13684ecb40 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/notification/WebhookPublisherError.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/notification/WebhookPublisherError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.agent.notification
+package org.hyperledger.identus.agent.notification
sealed trait WebhookPublisherError
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/ControllerHelper.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/ControllerHelper.scala
similarity index 66%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/ControllerHelper.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/ControllerHelper.scala
index 66f79f3177..30a756285a 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/ControllerHelper.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/ControllerHelper.scala
@@ -1,18 +1,21 @@
-package io.iohk.atala.agent.server
+package org.hyperledger.identus.agent.server
-import io.iohk.atala.agent.walletapi.model.PublicationState.Published
-import io.iohk.atala.agent.walletapi.model.error.GetManagedDIDError
-import io.iohk.atala.agent.walletapi.model.{ManagedDIDState, PublicationState}
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.castor.core.model.did.{LongFormPrismDID, PrismDID}
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.ConnectionRecord.{ProtocolState, Role}
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError.{InvalidStateForOperation, RecordIdNotFound}
-import io.iohk.atala.connect.core.service.ConnectionService
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.PublicationState.Published
+import org.hyperledger.identus.agent.walletapi.model.error.GetManagedDIDError
+import org.hyperledger.identus.agent.walletapi.model.{ManagedDIDState, PublicationState}
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.castor.core.model.did.{LongFormPrismDID, PrismDID}
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.{ProtocolState, Role}
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError.{
+ InvalidStateForOperation,
+ RecordIdNotFound
+}
+import org.hyperledger.identus.connect.core.service.ConnectionService
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{IO, ZIO}
import java.util.UUID
@@ -50,9 +53,9 @@ trait ControllerHelper {
protected def extractDidCommIdFromString(
maybeDidCommId: String
- ): IO[ErrorResponse, io.iohk.atala.pollux.core.model.DidCommID] =
+ ): IO[ErrorResponse, org.hyperledger.identus.pollux.core.model.DidCommID] =
ZIO
- .fromTry(Try(io.iohk.atala.pollux.core.model.DidCommID(maybeDidCommId)))
+ .fromTry(Try(org.hyperledger.identus.pollux.core.model.DidCommID(maybeDidCommId)))
.mapError(e => ErrorResponse.badRequest(detail = Some(s"Error parsing string as DidCommID: ${e.getMessage}")))
protected def extractPrismDIDFromString(maybeDid: String): IO[ErrorResponse, PrismDID] =
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/DidCommHttpServer.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/DidCommHttpServer.scala
similarity index 86%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/DidCommHttpServer.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/DidCommHttpServer.scala
index 80d1158384..a94f10ac26 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/DidCommHttpServer.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/DidCommHttpServer.scala
@@ -1,31 +1,31 @@
-package io.iohk.atala.agent.server
+package org.hyperledger.identus.agent.server
import io.circe.*
import io.circe.parser.*
-import io.iohk.atala.agent.server.DidCommHttpServerError.{
+import org.hyperledger.identus.agent.server.DidCommHttpServerError.{
DIDCommMessageParsingError,
InvalidContentTypeError,
RequestBodyParsingError
}
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.walletapi.model.error.DIDSecretStorageError
-import io.iohk.atala.agent.walletapi.model.error.DIDSecretStorageError.{KeyNotFoundError, WalletNotFoundError}
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.service.ConnectionService
-import io.iohk.atala.mercury.*
-import io.iohk.atala.mercury.DidOps.*
-import io.iohk.atala.mercury.model.*
-import io.iohk.atala.mercury.model.error.*
-import io.iohk.atala.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
-import io.iohk.atala.mercury.protocol.issuecredential.*
-import io.iohk.atala.mercury.protocol.presentproof.*
-import io.iohk.atala.mercury.protocol.revocationnotificaiton.RevocationNotification
-import io.iohk.atala.pollux.core.model.error.{CredentialServiceError, PresentationError}
-import io.iohk.atala.pollux.core.service.{CredentialService, PresentationService}
-import io.iohk.atala.resolvers.DIDResolver
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.walletapi.model.error.DIDSecretStorageError
+import org.hyperledger.identus.agent.walletapi.model.error.DIDSecretStorageError.{KeyNotFoundError, WalletNotFoundError}
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.service.ConnectionService
+import org.hyperledger.identus.mercury.*
+import org.hyperledger.identus.mercury.DidOps.*
+import org.hyperledger.identus.mercury.model.*
+import org.hyperledger.identus.mercury.error.*
+import org.hyperledger.identus.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
+import org.hyperledger.identus.mercury.protocol.issuecredential.*
+import org.hyperledger.identus.mercury.protocol.presentproof.*
+import org.hyperledger.identus.mercury.protocol.revocationnotificaiton.RevocationNotification
+import org.hyperledger.identus.pollux.core.model.error.{CredentialServiceError, PresentationError}
+import org.hyperledger.identus.pollux.core.service.{CredentialService, PresentationService}
+import org.hyperledger.identus.resolvers.DIDResolver
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.http.*
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/DidCommHttpServerError.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/DidCommHttpServerError.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/DidCommHttpServerError.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/DidCommHttpServerError.scala
index aacbbe732e..042a9835b6 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/DidCommHttpServerError.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/DidCommHttpServerError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.agent.server
+package org.hyperledger.identus.agent.server
sealed trait DidCommHttpServerError
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Main.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/MainApp.scala
similarity index 76%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Main.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/MainApp.scala
index b12d7fbdf0..6e4ac6dfd2 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Main.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/MainApp.scala
@@ -1,43 +1,47 @@
-package io.iohk.atala.agent.server
+package org.hyperledger.identus.agent.server
import com.nimbusds.jose.crypto.bc.BouncyCastleProviderSingleton
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.server.http.ZioHttpClient
-import io.iohk.atala.agent.server.sql.Migrations as AgentMigrations
-import io.iohk.atala.agent.walletapi.service.{
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.http.ZioHttpClient
+import org.hyperledger.identus.agent.server.sql.Migrations as AgentMigrations
+import org.hyperledger.identus.agent.walletapi.service.{
EntityServiceImpl,
ManagedDIDService,
ManagedDIDServiceWithEventNotificationImpl,
WalletManagementServiceImpl
}
-import io.iohk.atala.agent.walletapi.sql.{JdbcDIDNonSecretStorage, JdbcEntityRepository, JdbcWalletNonSecretStorage}
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.castor.controller.{DIDControllerImpl, DIDRegistrarControllerImpl}
-import io.iohk.atala.castor.core.service.DIDServiceImpl
-import io.iohk.atala.castor.core.util.DIDOperationValidator
-import io.iohk.atala.connect.controller.ConnectionControllerImpl
-import io.iohk.atala.connect.core.service.{ConnectionServiceImpl, ConnectionServiceNotifier}
-import io.iohk.atala.connect.sql.repository.{JdbcConnectionRepository, Migrations as ConnectMigrations}
-import io.iohk.atala.credentialstatus.controller.CredentialStatusControllerImpl
-import io.iohk.atala.event.controller.EventControllerImpl
-import io.iohk.atala.event.notification.EventNotificationServiceImpl
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.apikey.JdbcAuthenticationRepository
-import io.iohk.atala.iam.authorization.DefaultPermissionManagementService
-import io.iohk.atala.iam.authorization.core.EntityPermissionManagementService
-import io.iohk.atala.iam.entity.http.controller.{EntityController, EntityControllerImpl}
-import io.iohk.atala.iam.wallet.http.controller.WalletManagementControllerImpl
-import io.iohk.atala.issue.controller.IssueControllerImpl
-import io.iohk.atala.mercury.*
-import io.iohk.atala.pollux.core.service.*
-import io.iohk.atala.pollux.core.service.verification.VcVerificationServiceImpl
-import io.iohk.atala.pollux.credentialdefinition.controller.CredentialDefinitionControllerImpl
-import io.iohk.atala.pollux.credentialschema.controller.{
+import org.hyperledger.identus.agent.walletapi.sql.{
+ JdbcDIDNonSecretStorage,
+ JdbcEntityRepository,
+ JdbcWalletNonSecretStorage
+}
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.castor.controller.{DIDControllerImpl, DIDRegistrarControllerImpl}
+import org.hyperledger.identus.castor.core.service.DIDServiceImpl
+import org.hyperledger.identus.castor.core.util.DIDOperationValidator
+import org.hyperledger.identus.connect.controller.ConnectionControllerImpl
+import org.hyperledger.identus.connect.core.service.{ConnectionServiceImpl, ConnectionServiceNotifier}
+import org.hyperledger.identus.connect.sql.repository.{JdbcConnectionRepository, Migrations as ConnectMigrations}
+import org.hyperledger.identus.credential.status.controller.CredentialStatusControllerImpl
+import org.hyperledger.identus.event.controller.EventControllerImpl
+import org.hyperledger.identus.event.notification.EventNotificationServiceImpl
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.apikey.JdbcAuthenticationRepository
+import org.hyperledger.identus.iam.authorization.DefaultPermissionManagementService
+import org.hyperledger.identus.iam.authorization.core.EntityPermissionManagementService
+import org.hyperledger.identus.iam.entity.http.controller.{EntityController, EntityControllerImpl}
+import org.hyperledger.identus.iam.wallet.http.controller.WalletManagementControllerImpl
+import org.hyperledger.identus.issue.controller.IssueControllerImpl
+import org.hyperledger.identus.mercury.*
+import org.hyperledger.identus.pollux.core.service.*
+import org.hyperledger.identus.pollux.core.service.verification.VcVerificationServiceImpl
+import org.hyperledger.identus.pollux.credentialdefinition.controller.CredentialDefinitionControllerImpl
+import org.hyperledger.identus.pollux.credentialschema.controller.{
CredentialSchemaController,
CredentialSchemaControllerImpl,
VerificationPolicyControllerImpl
}
-import io.iohk.atala.pollux.sql.repository.{
+import org.hyperledger.identus.pollux.sql.repository.{
JdbcCredentialDefinitionRepository,
JdbcCredentialRepository,
JdbcCredentialSchemaRepository,
@@ -46,10 +50,10 @@ import io.iohk.atala.pollux.sql.repository.{
JdbcVerificationPolicyRepository,
Migrations as PolluxMigrations
}
-import io.iohk.atala.presentproof.controller.PresentProofControllerImpl
-import io.iohk.atala.resolvers.DIDResolver
-import io.iohk.atala.system.controller.SystemControllerImpl
-import io.iohk.atala.verification.controller.VcVerificationControllerImpl
+import org.hyperledger.identus.presentproof.controller.PresentProofControllerImpl
+import org.hyperledger.identus.resolvers.DIDResolver
+import org.hyperledger.identus.system.controller.SystemControllerImpl
+import org.hyperledger.identus.verification.controller.VcVerificationControllerImpl
import io.micrometer.prometheus.{PrometheusConfig, PrometheusMeterRegistry}
import zio.*
import zio.metrics.connectors.micrometer
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Modules.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/Modules.scala
similarity index 79%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Modules.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/Modules.scala
index 7896437f49..92e42c4e0a 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/Modules.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/Modules.scala
@@ -1,41 +1,45 @@
-package io.iohk.atala.agent.server
+package org.hyperledger.identus.agent.server
import com.typesafe.config.ConfigFactory
import doobie.util.transactor.Transactor
import io.grpc.ManagedChannelBuilder
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.server.config.SecretStorageBackend
-import io.iohk.atala.agent.server.config.ValidatedVaultConfig
-import io.iohk.atala.agent.walletapi.service.EntityService
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.agent.walletapi.sql.{JdbcDIDSecretStorage, JdbcGenericSecretStorage, JdbcWalletSecretStorage}
-import io.iohk.atala.agent.walletapi.storage.{DIDSecretStorage, GenericSecretStorage, WalletSecretStorage}
-import io.iohk.atala.agent.walletapi.vault.*
-import io.iohk.atala.agent.walletapi.vault.{
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.config.SecretStorageBackend
+import org.hyperledger.identus.agent.server.config.ValidatedVaultConfig
+import org.hyperledger.identus.agent.walletapi.service.EntityService
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementService
+import org.hyperledger.identus.agent.walletapi.sql.{
+ JdbcDIDSecretStorage,
+ JdbcGenericSecretStorage,
+ JdbcWalletSecretStorage
+}
+import org.hyperledger.identus.agent.walletapi.storage.{DIDSecretStorage, GenericSecretStorage, WalletSecretStorage}
+import org.hyperledger.identus.agent.walletapi.vault.*
+import org.hyperledger.identus.agent.walletapi.vault.{
VaultDIDSecretStorage,
VaultKVClient,
VaultKVClientImpl,
VaultWalletSecretStorage
}
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.iam.authentication.admin.AdminApiKeyAuthenticator
-import io.iohk.atala.iam.authentication.admin.AdminApiKeyAuthenticatorImpl
-import io.iohk.atala.iam.authentication.admin.AdminConfig
-import io.iohk.atala.iam.authentication.apikey.ApiKeyAuthenticator
-import io.iohk.atala.iam.authentication.apikey.ApiKeyAuthenticatorImpl
-import io.iohk.atala.iam.authentication.apikey.ApiKeyConfig
-import io.iohk.atala.iam.authentication.apikey.AuthenticationRepository
-import io.iohk.atala.iam.authentication.oidc.KeycloakAuthenticator
-import io.iohk.atala.iam.authentication.oidc.KeycloakAuthenticatorImpl
-import io.iohk.atala.iam.authentication.oidc.KeycloakClientImpl
-import io.iohk.atala.iam.authentication.oidc.KeycloakConfig
-import io.iohk.atala.iam.authentication.oidc.KeycloakEntity
-import io.iohk.atala.iam.authorization.core.PermissionManagement
-import io.iohk.atala.iam.authorization.keycloak.admin.KeycloakPermissionManagementService
-import io.iohk.atala.pollux.vc.jwt.{PrismDidResolver, DidResolver as JwtDidResolver}
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.iam.authentication.admin.AdminApiKeyAuthenticator
+import org.hyperledger.identus.iam.authentication.admin.AdminApiKeyAuthenticatorImpl
+import org.hyperledger.identus.iam.authentication.admin.AdminConfig
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyAuthenticator
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyAuthenticatorImpl
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyConfig
+import org.hyperledger.identus.iam.authentication.apikey.AuthenticationRepository
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakAuthenticator
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakAuthenticatorImpl
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakClientImpl
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakConfig
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakEntity
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement
+import org.hyperledger.identus.iam.authorization.keycloak.admin.KeycloakPermissionManagementService
+import org.hyperledger.identus.pollux.vc.jwt.{PrismDidResolver, DidResolver as JwtDidResolver}
import io.iohk.atala.prism.protos.node_api.NodeServiceGrpc
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.db.{ContextAwareTask, DbConfig, TransactorLayer}
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.db.{ContextAwareTask, DbConfig, TransactorLayer}
import org.keycloak.authorization.client.AuthzClient
import zio.*
import zio.config.typesafe.TypesafeConfigProvider
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/PrismAgentApp.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/PrismAgentApp.scala
similarity index 76%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/PrismAgentApp.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/PrismAgentApp.scala
index a8950f0c1b..84e704fda0 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/PrismAgentApp.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/PrismAgentApp.scala
@@ -1,34 +1,37 @@
-package io.iohk.atala.agent.server
-
-import io.iohk.atala.agent.notification.WebhookPublisher
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.server.http.{ZHttp4sBlazeServer, ZHttpEndpoints}
-import io.iohk.atala.agent.server.jobs.*
-import io.iohk.atala.agent.walletapi.model.{Entity, Wallet, WalletSeed}
-import io.iohk.atala.agent.walletapi.service.{EntityService, ManagedDIDService, WalletManagementService}
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.castor.controller.{DIDRegistrarServerEndpoints, DIDServerEndpoints}
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.connect.controller.ConnectionServerEndpoints
-import io.iohk.atala.connect.core.service.ConnectionService
-import io.iohk.atala.credentialstatus.controller.CredentialStatusServiceEndpoints
-import io.iohk.atala.event.controller.EventServerEndpoints
-import io.iohk.atala.event.notification.EventNotificationConfig
-import io.iohk.atala.iam.authentication.apikey.ApiKeyAuthenticator
-import io.iohk.atala.iam.entity.http.EntityServerEndpoints
-import io.iohk.atala.iam.wallet.http.WalletManagementServerEndpoints
-import io.iohk.atala.issue.controller.IssueServerEndpoints
-import io.iohk.atala.mercury.{DidOps, HttpClient}
-import io.iohk.atala.pollux.core.service.{CredentialService, PresentationService}
-import io.iohk.atala.pollux.credentialdefinition.CredentialDefinitionRegistryServerEndpoints
-import io.iohk.atala.pollux.credentialschema.{SchemaRegistryServerEndpoints, VerificationPolicyServerEndpoints}
-import io.iohk.atala.pollux.vc.jwt.DidResolver as JwtDidResolver
-import io.iohk.atala.presentproof.controller.PresentProofServerEndpoints
-import io.iohk.atala.resolvers.DIDResolver
-import io.iohk.atala.shared.models.{HexString, WalletAccessContext, WalletAdministrationContext, WalletId}
-import io.iohk.atala.shared.utils.DurationOps.toMetricsSeconds
-import io.iohk.atala.system.controller.SystemServerEndpoints
-import io.iohk.atala.verification.controller.VcVerificationServerEndpoints
+package org.hyperledger.identus.agent.server
+
+import org.hyperledger.identus.agent.notification.WebhookPublisher
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.http.{ZHttp4sBlazeServer, ZHttpEndpoints}
+import org.hyperledger.identus.agent.server.jobs.*
+import org.hyperledger.identus.agent.walletapi.model.{Entity, Wallet, WalletSeed}
+import org.hyperledger.identus.agent.walletapi.service.{EntityService, ManagedDIDService, WalletManagementService}
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.castor.controller.{DIDRegistrarServerEndpoints, DIDServerEndpoints}
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.connect.controller.ConnectionServerEndpoints
+import org.hyperledger.identus.connect.core.service.ConnectionService
+import org.hyperledger.identus.credential.status.controller.CredentialStatusServiceEndpoints
+import org.hyperledger.identus.event.controller.EventServerEndpoints
+import org.hyperledger.identus.event.notification.EventNotificationConfig
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyAuthenticator
+import org.hyperledger.identus.iam.entity.http.EntityServerEndpoints
+import org.hyperledger.identus.iam.wallet.http.WalletManagementServerEndpoints
+import org.hyperledger.identus.issue.controller.IssueServerEndpoints
+import org.hyperledger.identus.mercury.{DidOps, HttpClient}
+import org.hyperledger.identus.pollux.core.service.{CredentialService, PresentationService}
+import org.hyperledger.identus.pollux.credentialdefinition.CredentialDefinitionRegistryServerEndpoints
+import org.hyperledger.identus.pollux.credentialschema.{
+ SchemaRegistryServerEndpoints,
+ VerificationPolicyServerEndpoints
+}
+import org.hyperledger.identus.pollux.vc.jwt.DidResolver as JwtDidResolver
+import org.hyperledger.identus.presentproof.controller.PresentProofServerEndpoints
+import org.hyperledger.identus.shared.models.{HexString, WalletAccessContext, WalletAdministrationContext, WalletId}
+import org.hyperledger.identus.resolvers.DIDResolver
+import org.hyperledger.identus.shared.utils.DurationOps.toMetricsSeconds
+import org.hyperledger.identus.system.controller.SystemServerEndpoints
+import org.hyperledger.identus.verification.controller.VcVerificationServerEndpoints
import zio.*
import zio.metrics.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/config/AppConfig.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/config/AppConfig.scala
similarity index 95%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/config/AppConfig.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/config/AppConfig.scala
index 9f3ab58e52..b0379ce672 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/config/AppConfig.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/config/AppConfig.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.agent.server.config
+package org.hyperledger.identus.agent.server.config
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.iam.authentication.AuthenticationConfig
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.shared.db.DbConfig
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.iam.authentication.AuthenticationConfig
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.shared.db.DbConfig
import zio.Config
import zio.config.*
import zio.config.magnolia.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/CustomServerInterceptors.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/CustomServerInterceptors.scala
similarity index 96%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/CustomServerInterceptors.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/CustomServerInterceptors.scala
index 7e52ba4ef0..1a3c46a442 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/CustomServerInterceptors.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/CustomServerInterceptors.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.agent.server.http
+package org.hyperledger.identus.agent.server.http
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.shared.models.StatusCode
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.shared.models.StatusCode
import org.log4s.*
import sttp.tapir.*
import sttp.tapir.json.zio.jsonBody
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/DocModels.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/DocModels.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/DocModels.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/DocModels.scala
index 2c54b9f308..f80c886577 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/DocModels.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/DocModels.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.agent.server.http
+package org.hyperledger.identus.agent.server.http
-import io.iohk.atala.castor.controller.{DIDEndpoints, DIDRegistrarEndpoints}
-import io.iohk.atala.connect.controller.ConnectionEndpoints
-import io.iohk.atala.iam.wallet.http.WalletManagementEndpoints
-import io.iohk.atala.pollux.credentialdefinition.CredentialDefinitionRegistryEndpoints
-import io.iohk.atala.pollux.credentialschema.{SchemaRegistryEndpoints, VerificationPolicyEndpoints}
-import io.iohk.atala.system.controller.SystemEndpoints
+import org.hyperledger.identus.castor.controller.{DIDEndpoints, DIDRegistrarEndpoints}
+import org.hyperledger.identus.connect.controller.ConnectionEndpoints
+import org.hyperledger.identus.iam.wallet.http.WalletManagementEndpoints
+import org.hyperledger.identus.pollux.credentialdefinition.CredentialDefinitionRegistryEndpoints
+import org.hyperledger.identus.pollux.credentialschema.{SchemaRegistryEndpoints, VerificationPolicyEndpoints}
+import org.hyperledger.identus.system.controller.SystemEndpoints
import sttp.apispec.openapi.*
import sttp.apispec.{SecurityScheme, Tag}
import sttp.model.headers.AuthenticationScheme
import scala.collection.immutable.ListMap
-import io.iohk.atala.issue.controller.IssueEndpoints
+import org.hyperledger.identus.issue.controller.IssueEndpoints
object DocModels {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/ZHttp4sBlazeServer.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/ZHttp4sBlazeServer.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/ZHttp4sBlazeServer.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/ZHttp4sBlazeServer.scala
index 58654aff4c..6c57437737 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/ZHttp4sBlazeServer.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/ZHttp4sBlazeServer.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.agent.server.http
+package org.hyperledger.identus.agent.server.http
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.system.controller.SystemEndpoints
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.system.controller.SystemEndpoints
import io.micrometer.prometheus.PrometheusMeterRegistry
import org.http4s.*
import org.http4s.blaze.server.BlazeServerBuilder
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/ZHttpEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/ZHttpEndpoints.scala
similarity index 91%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/ZHttpEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/ZHttpEndpoints.scala
index 384976e388..a280470ac3 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/ZHttpEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/ZHttpEndpoints.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.server.http
+package org.hyperledger.identus.agent.server.http
-import io.iohk.atala.agent.server.buildinfo.BuildInfo
+import org.hyperledger.identus.agent.server.buildinfo.BuildInfo
import sttp.apispec.openapi.OpenAPI
import sttp.tapir.redoc.RedocUIOptions
import sttp.tapir.redoc.bundle.RedocInterpreter
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/ZioHttpClient.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/ZioHttpClient.scala
similarity index 94%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/ZioHttpClient.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/ZioHttpClient.scala
index 95a2c4779e..83ac8ade77 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/http/ZioHttpClient.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/http/ZioHttpClient.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.server.http
+package org.hyperledger.identus.agent.server.http
-import io.iohk.atala.mercury.*
+import org.hyperledger.identus.mercury.*
import zio.*
import zio.http.{Header as _, *}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/BackgroundJobError.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/BackgroundJobError.scala
similarity index 80%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/BackgroundJobError.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/BackgroundJobError.scala
index c58b1c9419..ca860b5995 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/BackgroundJobError.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/BackgroundJobError.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.server.jobs
+package org.hyperledger.identus.agent.server.jobs
-import io.iohk.atala.mercury.HttpResponse
+import org.hyperledger.identus.mercury.HttpResponse
sealed trait BackgroundJobError
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/BackgroundJobsHelper.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/BackgroundJobsHelper.scala
similarity index 77%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/BackgroundJobsHelper.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/BackgroundJobsHelper.scala
index 37d1a3e563..d3e9ba5845 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/BackgroundJobsHelper.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/BackgroundJobsHelper.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.agent.server.jobs
+package org.hyperledger.identus.agent.server.jobs
-import io.iohk.atala.agent.walletapi.model.error.DIDSecretStorageError.KeyNotFoundError
-import io.iohk.atala.agent.walletapi.model.{ManagedDIDState, PublicationState}
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.castor.core.model.did.{LongFormPrismDID, PrismDID, VerificationRelationship}
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.{AgentPeerService, DidAgent}
-import io.iohk.atala.pollux.vc.jwt.{ES256KSigner, Issuer as JwtIssuer}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.error.DIDSecretStorageError.KeyNotFoundError
+import org.hyperledger.identus.agent.walletapi.model.{ManagedDIDState, PublicationState}
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.castor.core.model.did.{LongFormPrismDID, PrismDID, VerificationRelationship}
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.{AgentPeerService, DidAgent}
+import org.hyperledger.identus.pollux.vc.jwt.{ES256KSigner, Issuer as JwtIssuer}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{ZIO, ZLayer}
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.agent.walletapi.model.error.DIDSecretStorageError.WalletNotFoundError
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.model.error.DIDSecretStorageError.WalletNotFoundError
trait BackgroundJobsHelper {
@@ -57,7 +57,7 @@ trait BackgroundJobsHelper {
)
(privateKey, publicKey) = ecKeyPair
jwtIssuer = JwtIssuer(
- io.iohk.atala.pollux.vc.jwt.DID(jwtIssuerDID.toString),
+ org.hyperledger.identus.pollux.vc.jwt.DID(jwtIssuerDID.toString),
ES256KSigner(privateKey),
publicKey
)
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/ConnectBackgroundJobs.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/ConnectBackgroundJobs.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/ConnectBackgroundJobs.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/ConnectBackgroundJobs.scala
index 117862ffb2..9bc0bc8809 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/ConnectBackgroundJobs.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/ConnectBackgroundJobs.scala
@@ -1,21 +1,19 @@
-package io.iohk.atala.agent.server.jobs
+package org.hyperledger.identus.agent.server.jobs
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.server.jobs.BackgroundJobError.ErrorResponseReceivedFromPeerAgent
-import io.iohk.atala.agent.walletapi.model.error.DIDSecretStorageError
-import io.iohk.atala.agent.walletapi.model.error.DIDSecretStorageError.{KeyNotFoundError, WalletNotFoundError}
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.ConnectionRecord.*
-import io.iohk.atala.connect.core.service.ConnectionService
-import io.iohk.atala.mercury.*
-import io.iohk.atala.mercury.model.*
-import io.iohk.atala.mercury.model.error.*
-import io.iohk.atala.resolvers.DIDResolver
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.utils.DurationOps.toMetricsSeconds
-import io.iohk.atala.shared.utils.aspects.CustomMetricsAspect
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.jobs.BackgroundJobError.ErrorResponseReceivedFromPeerAgent
+import org.hyperledger.identus.agent.walletapi.model.error.DIDSecretStorageError
+import org.hyperledger.identus.agent.walletapi.model.error.DIDSecretStorageError.{KeyNotFoundError, WalletNotFoundError}
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.*
+import org.hyperledger.identus.connect.core.service.ConnectionService
+import org.hyperledger.identus.mercury.*
+import org.hyperledger.identus.resolvers.DIDResolver
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.utils.DurationOps.toMetricsSeconds
+import org.hyperledger.identus.shared.utils.aspects.CustomMetricsAspect
import zio.*
import zio.metrics.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/DIDStateSyncBackgroundJobs.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/DIDStateSyncBackgroundJobs.scala
similarity index 70%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/DIDStateSyncBackgroundJobs.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/DIDStateSyncBackgroundJobs.scala
index 39de8dacae..22e4e9d568 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/DIDStateSyncBackgroundJobs.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/DIDStateSyncBackgroundJobs.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.server.jobs
+package org.hyperledger.identus.agent.server.jobs
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
import zio.*
object DIDStateSyncBackgroundJobs {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/IssueBackgroundJobs.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/IssueBackgroundJobs.scala
similarity index 95%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/IssueBackgroundJobs.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/IssueBackgroundJobs.scala
index cb25f944c1..1cb1461f85 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/IssueBackgroundJobs.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/IssueBackgroundJobs.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.agent.server.jobs
-
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.server.jobs.BackgroundJobError.ErrorResponseReceivedFromPeerAgent
-import io.iohk.atala.agent.walletapi.model.error.DIDSecretStorageError.WalletNotFoundError
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.mercury.*
-import io.iohk.atala.mercury.protocol.issuecredential.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.pollux.core.service.CredentialService
-import io.iohk.atala.shared.utils.DurationOps.toMetricsSeconds
-import io.iohk.atala.shared.utils.aspects.CustomMetricsAspect
+package org.hyperledger.identus.agent.server.jobs
+
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.jobs.BackgroundJobError.ErrorResponseReceivedFromPeerAgent
+import org.hyperledger.identus.agent.walletapi.model.error.DIDSecretStorageError.WalletNotFoundError
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.mercury.*
+import org.hyperledger.identus.mercury.protocol.issuecredential.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.pollux.core.service.CredentialService
+import org.hyperledger.identus.shared.utils.DurationOps.toMetricsSeconds
+import org.hyperledger.identus.shared.utils.aspects.CustomMetricsAspect
import zio.*
import zio.metrics.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/PresentBackgroundJobs.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/PresentBackgroundJobs.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/PresentBackgroundJobs.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/PresentBackgroundJobs.scala
index 6f7e3f3b00..5f2f3b4718 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/PresentBackgroundJobs.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/PresentBackgroundJobs.scala
@@ -1,40 +1,40 @@
-package io.iohk.atala.agent.server.jobs
+package org.hyperledger.identus.agent.server.jobs
import cats.syntax.all.*
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.server.jobs.BackgroundJobError.{
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.jobs.BackgroundJobError.{
ErrorResponseReceivedFromPeerAgent,
InvalidState,
NotImplemented
}
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.mercury.*
-import io.iohk.atala.mercury.model.*
-import io.iohk.atala.mercury.protocol.presentproof.*
-import io.iohk.atala.mercury.protocol.reportproblem.v2.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.error.PresentationError.*
-import io.iohk.atala.pollux.core.model.error.{CredentialServiceError, PresentationError}
-import io.iohk.atala.pollux.core.service.serdes.AnoncredCredentialProofsV1
-import io.iohk.atala.pollux.core.service.{CredentialService, PresentationService}
-import io.iohk.atala.pollux.vc.jwt.{JWT, JwtPresentation, DidResolver as JwtDidResolver}
-import io.iohk.atala.shared.utils.DurationOps.toMetricsSeconds
-import io.iohk.atala.shared.utils.aspects.CustomMetricsAspect
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.mercury.*
+import org.hyperledger.identus.mercury.model.*
+import org.hyperledger.identus.mercury.protocol.presentproof.*
+import org.hyperledger.identus.mercury.protocol.reportproblem.v2.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.error.PresentationError.*
+import org.hyperledger.identus.pollux.core.model.error.{CredentialServiceError, PresentationError}
+import org.hyperledger.identus.pollux.core.service.serdes.AnoncredCredentialProofsV1
+import org.hyperledger.identus.pollux.core.service.{CredentialService, PresentationService}
+import org.hyperledger.identus.pollux.vc.jwt.{JWT, JwtPresentation, DidResolver as JwtDidResolver}
+import org.hyperledger.identus.shared.utils.DurationOps.toMetricsSeconds
+import org.hyperledger.identus.shared.utils.aspects.CustomMetricsAspect
import zio.*
import zio.json.ast.Json
import zio.metrics.*
import zio.prelude.Validation
import zio.prelude.ZValidation.*
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.agent.walletapi.model.error.DIDSecretStorageError.WalletNotFoundError
-import io.iohk.atala.resolvers.DIDResolver
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.model.error.DIDSecretStorageError.WalletNotFoundError
+import org.hyperledger.identus.resolvers.DIDResolver
+import org.hyperledger.identus.shared.models.WalletAccessContext
import java.time.{Clock, Instant, ZoneId}
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.shared.http.*
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.shared.http.*
object PresentBackgroundJobs extends BackgroundJobsHelper {
@@ -103,7 +103,7 @@ object PresentBackgroundJobs extends BackgroundJobsHelper {
DIDNonSecretStorage & DIDService & ManagedDIDService,
Unit
] = {
- import io.iohk.atala.pollux.core.model.PresentationRecord.ProtocolState.*
+ import org.hyperledger.identus.pollux.core.model.PresentationRecord.ProtocolState.*
val VerifierReqPendingToSentSuccess = counterMetric(
"present_proof_flow_verifier_request_pending_to_sent_success_counter"
@@ -495,15 +495,18 @@ object PresentBackgroundJobs extends BackgroundJobsHelper {
credentialsValidationResult <- p.attachments.head.data match {
case Base64(data) =>
val base64Decoded = new String(java.util.Base64.getDecoder.decode(data))
- val maybePresentationOptions
- : Either[PresentationError, Option[io.iohk.atala.pollux.core.model.presentation.Options]] =
+ val maybePresentationOptions: Either[PresentationError, Option[
+ org.hyperledger.identus.pollux.core.model.presentation.Options
+ ]] =
mayBeRequestPresentation
.map(
_.attachments.headOption
.map(attachment =>
- decode[io.iohk.atala.mercury.model.JsonData](attachment.data.asJson.noSpaces)
+ decode[org.hyperledger.identus.mercury.model.JsonData](
+ attachment.data.asJson.noSpaces
+ )
.flatMap(data =>
- io.iohk.atala.pollux.core.model.presentation.PresentationAttachment.given_Decoder_PresentationAttachment
+ org.hyperledger.identus.pollux.core.model.presentation.PresentationAttachment.given_Decoder_PresentationAttachment
.decodeJson(data.json.asJson)
.map(_.options)
.leftMap(err =>
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/StatusListJobs.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/StatusListJobs.scala
similarity index 89%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/StatusListJobs.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/StatusListJobs.scala
index f5b090fbc7..3eb4e0625f 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/jobs/StatusListJobs.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/jobs/StatusListJobs.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.agent.server.jobs
+package org.hyperledger.identus.agent.server.jobs
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.mercury.*
-import io.iohk.atala.mercury.protocol.revocationnotificaiton.RevocationNotification
-import io.iohk.atala.pollux.core.service.{CredentialService, CredentialStatusListService}
-import io.iohk.atala.pollux.vc.jwt.revocation.{VCStatusList2021, VCStatusList2021Error}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.mercury.*
+import org.hyperledger.identus.mercury.protocol.revocationnotificaiton.RevocationNotification
+import org.hyperledger.identus.pollux.core.service.{CredentialService, CredentialStatusListService}
+import org.hyperledger.identus.pollux.vc.jwt.revocation.{VCStatusList2021, VCStatusList2021Error}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.metrics.Metric
-import io.iohk.atala.shared.utils.DurationOps.toMetricsSeconds
+import org.hyperledger.identus.shared.utils.DurationOps.toMetricsSeconds
object StatusListJobs extends BackgroundJobsHelper {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/sql/Migrations.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/sql/Migrations.scala
similarity index 89%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/sql/Migrations.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/sql/Migrations.scala
index d4cda1e7af..a3a06ba70d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/agent/server/sql/Migrations.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/agent/server/sql/Migrations.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.agent.server.sql
+package org.hyperledger.identus.agent.server.sql
import doobie.*
import doobie.implicits.*
import doobie.util.transactor.Transactor
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.DbConfig
-import io.iohk.atala.shared.db.Implicits.*
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.DbConfig
+import org.hyperledger.identus.shared.db.Implicits.*
import org.flywaydb.core.Flyway
import zio.*
import zio.interop.catz.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/EndpointOutputs.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/EndpointOutputs.scala
similarity index 98%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/EndpointOutputs.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/EndpointOutputs.scala
index ae91b269d6..2a36f43a75 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/EndpointOutputs.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/EndpointOutputs.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.api.http
+package org.hyperledger.identus.api.http
import sttp.model.StatusCode
import sttp.tapir.json.zio.jsonBody
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/ErrorResponse.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/ErrorResponse.scala
similarity index 96%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/ErrorResponse.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/ErrorResponse.scala
index 262a0ee3a2..70b6d8cb63 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/ErrorResponse.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/ErrorResponse.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.api.http
+package org.hyperledger.identus.api.http
-import io.iohk.atala.api.http.ErrorResponse.annotations
-import io.iohk.atala.shared.models.Failure
+import org.hyperledger.identus.api.http.ErrorResponse.annotations
+import org.hyperledger.identus.shared.models.Failure
import sttp.model.StatusCode
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/RequestContext.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/RequestContext.scala
similarity index 68%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/RequestContext.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/RequestContext.scala
index 8fd88d799f..821b2c1eb1 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/RequestContext.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/RequestContext.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.api.http
+package org.hyperledger.identus.api.http
import sttp.tapir.model.ServerRequest
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/CirceJsonInterop.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/CirceJsonInterop.scala
similarity index 96%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/CirceJsonInterop.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/CirceJsonInterop.scala
index 3a375c010c..d16f4e62af 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/CirceJsonInterop.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/CirceJsonInterop.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.api.http.codec
+package org.hyperledger.identus.api.http.codec
import io.circe.Json as CirceJson
import sttp.tapir.Schema
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/CustomMediaTypes.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/CustomMediaTypes.scala
similarity index 88%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/CustomMediaTypes.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/CustomMediaTypes.scala
index f6dc4d45ed..28f7073f7c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/CustomMediaTypes.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/CustomMediaTypes.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.api.http.codec
+package org.hyperledger.identus.api.http.codec
import sttp.model.MediaType
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/DIDCodec.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/DIDCodec.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/DIDCodec.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/DIDCodec.scala
index 6ccdc8a30d..8922f79829 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/DIDCodec.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/DIDCodec.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.api.http.codec
+package org.hyperledger.identus.api.http.codec
-import io.iohk.atala.castor.controller.http.{DIDDocument, DIDResolutionResult}
+import org.hyperledger.identus.castor.controller.http.{DIDDocument, DIDResolutionResult}
import sttp.model.MediaType
import sttp.tapir.*
import sttp.tapir.DecodeResult.Error
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/DidCommIDCodec.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/DidCommIDCodec.scala
similarity index 81%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/DidCommIDCodec.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/DidCommIDCodec.scala
index 171e3ce01f..322f8a643f 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/DidCommIDCodec.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/DidCommIDCodec.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.api.http.codec
+package org.hyperledger.identus.api.http.codec
import sttp.tapir._
import sttp.tapir.Codec.PlainCodec
-import io.iohk.atala.pollux.core.model.DidCommID
+import org.hyperledger.identus.pollux.core.model.DidCommID
import sttp.tapir.DecodeResult.*
object DidCommIDCodec {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/OrderCodec.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/OrderCodec.scala
similarity index 86%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/OrderCodec.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/OrderCodec.scala
index 882ded5de1..0cdd28bd21 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/codec/OrderCodec.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/codec/OrderCodec.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.api.http.codec
+package org.hyperledger.identus.api.http.codec
-import io.iohk.atala.api.http.model.Order
-import io.iohk.atala.api.http.model.Order.Direction
+import org.hyperledger.identus.api.http.model.Order
+import org.hyperledger.identus.api.http.model.Order.Direction
import sttp.tapir.Codec.PlainCodec
import sttp.tapir.{Codec, DecodeResult}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/model/CollectionStats.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/model/CollectionStats.scala
similarity index 58%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/model/CollectionStats.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/model/CollectionStats.scala
index 339e0903af..8ce21c81e8 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/model/CollectionStats.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/model/CollectionStats.scala
@@ -1,3 +1,3 @@
-package io.iohk.atala.api.http.model
+package org.hyperledger.identus.api.http.model
case class CollectionStats(totalCount: Long, filteredCount: Long)
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/model/Order.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/model/Order.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/model/Order.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/model/Order.scala
index 57bb13a32a..6dfb248db3 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/model/Order.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/model/Order.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.api.http.model
+package org.hyperledger.identus.api.http.model
import scala.annotation.unused
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/model/PaginationInput.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/model/PaginationInput.scala
similarity index 94%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/model/PaginationInput.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/model/PaginationInput.scala
index b56112d6d4..f0754920ef 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/model/PaginationInput.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/model/PaginationInput.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.api.http.model
+package org.hyperledger.identus.api.http.model
import sttp.tapir.EndpointIO.annotations.{description, query}
import sttp.tapir.Schema.annotations.validateEach
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/package.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/package.scala
similarity index 94%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/package.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/package.scala
index c4c03be20e..2a66fbdfe1 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/package.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/http/package.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.api
+package org.hyperledger.identus.api
import sttp.tapir.Validator
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/util/PaginationUtils.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/util/PaginationUtils.scala
similarity index 95%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/api/util/PaginationUtils.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/util/PaginationUtils.scala
index 061f7c1ee3..98c3ac01ca 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/api/util/PaginationUtils.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/api/util/PaginationUtils.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.api.util
+package org.hyperledger.identus.api.util
-import io.iohk.atala.api.http.model.{CollectionStats, Pagination}
+import org.hyperledger.identus.api.http.model.{CollectionStats, Pagination}
import scala.util.chaining.scalaUtilChainingOps
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionController.scala
similarity index 72%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionController.scala
index 4f8545f988..59ec27435c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionController.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.connect.controller
+package org.hyperledger.identus.connect.controller
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.connect.controller.http.{
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.connect.controller.http.{
AcceptConnectionInvitationRequest,
Connection,
ConnectionsPage,
CreateConnectionRequest
}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionControllerImpl.scala
similarity index 79%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionControllerImpl.scala
index 861502e2de..bb9591d11a 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionControllerImpl.scala
@@ -1,18 +1,18 @@
-package io.iohk.atala.connect.controller
+package org.hyperledger.identus.connect.controller
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.connect.controller.http.{
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.connect.controller.http.{
AcceptConnectionInvitationRequest,
Connection,
ConnectionsPage,
CreateConnectionRequest
}
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.service.ConnectionService
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.service.ConnectionService
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionEndpoints.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionEndpoints.scala
index b69739b8c8..6268685b61 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionEndpoints.scala
@@ -1,18 +1,18 @@
-package io.iohk.atala.connect.controller
+package org.hyperledger.identus.connect.controller
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.connect.controller.http.{
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.connect.controller.http.{
AcceptConnectionInvitationRequest,
Connection,
ConnectionsPage,
CreateConnectionRequest
}
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
import sttp.apispec.Tag
import sttp.model.StatusCode
import sttp.tapir.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionServerEndpoints.scala
similarity index 79%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionServerEndpoints.scala
index d6f8ff01df..90c1d828ef 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/ConnectionServerEndpoints.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.connect.controller
+package org.hyperledger.identus.connect.controller
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.connect.controller.ConnectionEndpoints.*
-import io.iohk.atala.connect.controller.http.{AcceptConnectionInvitationRequest, CreateConnectionRequest}
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.Authorizer
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.SecurityLogic
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.connect.controller.ConnectionEndpoints.*
+import org.hyperledger.identus.connect.controller.http.{AcceptConnectionInvitationRequest, CreateConnectionRequest}
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.Authorizer
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.SecurityLogic
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/AcceptConnectionInvitationRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/AcceptConnectionInvitationRequest.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/AcceptConnectionInvitationRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/AcceptConnectionInvitationRequest.scala
index 9f98d736ed..f6eeb2da44 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/AcceptConnectionInvitationRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/AcceptConnectionInvitationRequest.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.connect.controller.http
+package org.hyperledger.identus.connect.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.connect.controller.http.AcceptConnectionInvitationRequest.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.connect.controller.http.AcceptConnectionInvitationRequest.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/Connection.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/Connection.scala
similarity index 95%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/Connection.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/Connection.scala
index 543ea9009d..f506c526a3 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/Connection.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/Connection.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.connect.controller.http
+package org.hyperledger.identus.connect.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.connect.controller.http.Connection.annotations
-import io.iohk.atala.connect.core.model
-import io.iohk.atala.connect.core.model.ConnectionRecord.Role
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.connect.controller.http.Connection.annotations
+import org.hyperledger.identus.connect.core.model
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.Role
import sttp.model.Uri
import sttp.tapir.Schema.annotations.{description, encodedExample, validate}
import sttp.tapir.{Schema, Validator}
@@ -11,7 +11,7 @@ import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
import java.time.{OffsetDateTime, ZoneOffset}
import java.util.UUID
-import io.iohk.atala.connect.controller.http.Connection.annotations.goalcode
+import org.hyperledger.identus.connect.controller.http.Connection.annotations.goalcode
case class Connection(
@description(annotations.connectionId.description)
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/ConnectionInvitation.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/ConnectionInvitation.scala
similarity index 92%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/ConnectionInvitation.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/ConnectionInvitation.scala
index bb26e9ac70..32d9c919b1 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/ConnectionInvitation.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/ConnectionInvitation.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.connect.controller.http
+package org.hyperledger.identus.connect.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.connect.controller.http.ConnectionInvitation.annotations
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.connect.controller.http.ConnectionInvitation.annotations
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/ConnectionsPage.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/ConnectionsPage.scala
similarity index 94%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/ConnectionsPage.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/ConnectionsPage.scala
index 15791b6fd4..cddb14d73c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/ConnectionsPage.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/ConnectionsPage.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.connect.controller.http
+package org.hyperledger.identus.connect.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.connect.controller.http.ConnectionsPage.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.connect.controller.http.ConnectionsPage.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/CreateConnectionRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/CreateConnectionRequest.scala
similarity index 89%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/CreateConnectionRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/CreateConnectionRequest.scala
index 1528542f0a..d3fc107514 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/http/CreateConnectionRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/connect/controller/http/CreateConnectionRequest.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.connect.controller.http
+package org.hyperledger.identus.connect.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.connect.controller.http.CreateConnectionRequest.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.connect.controller.http.CreateConnectionRequest.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample, validate, validateEach}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDController.scala
similarity index 76%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDController.scala
index 863618b344..9b9d5bce6e 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDController.scala
@@ -1,11 +1,15 @@
-package io.iohk.atala.castor.controller
+package org.hyperledger.identus.castor.controller
-import io.iohk.atala.castor.controller.http.DIDResolutionResult
+import org.hyperledger.identus.castor.controller.http.DIDResolutionResult
import zio.*
-import io.iohk.atala.castor.controller.http.{DIDDocument, DIDDocumentMetadata, DIDResolutionMetadata}
-import io.iohk.atala.castor.core.model.did.w3c.{DIDDocumentMetadataRepr, DIDDocumentRepr, DIDResolutionErrorRepr}
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.castor.core.model.did.w3c.makeW3CResolver
+import org.hyperledger.identus.castor.controller.http.{DIDDocument, DIDDocumentMetadata, DIDResolutionMetadata}
+import org.hyperledger.identus.castor.core.model.did.w3c.{
+ DIDDocumentMetadataRepr,
+ DIDDocumentRepr,
+ DIDResolutionErrorRepr
+}
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.castor.core.model.did.w3c.makeW3CResolver
import scala.language.implicitConversions
trait DIDController {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDEndpoints.scala
similarity index 92%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDEndpoints.scala
index 8b76be6a7a..1d528676bc 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDEndpoints.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.castor.controller
+package org.hyperledger.identus.castor.controller
-import io.iohk.atala.api.http.codec.DIDCodec.emptyDidJsonLD
-import io.iohk.atala.api.http.codec.DIDCodec.{didJsonLD, didResolutionJsonLD}
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.castor.controller.http.{DIDResolutionResult, DIDInput}
+import org.hyperledger.identus.api.http.codec.DIDCodec.emptyDidJsonLD
+import org.hyperledger.identus.api.http.codec.DIDCodec.{didJsonLD, didResolutionJsonLD}
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.castor.controller.http.{DIDResolutionResult, DIDInput}
import sttp.apispec.Tag
import sttp.model.StatusCode
import sttp.tapir.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDRegistrarController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDRegistrarController.scala
similarity index 82%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDRegistrarController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDRegistrarController.scala
index 1b53a054e5..c1a8eded2d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDRegistrarController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDRegistrarController.scala
@@ -1,24 +1,24 @@
-package io.iohk.atala.castor.controller
-
-import io.iohk.atala.agent.walletapi.model.ManagedDIDDetail
-import io.iohk.atala.agent.walletapi.model.error.CreateManagedDIDError
-import io.iohk.atala.agent.walletapi.model.error.GetManagedDIDError
-import io.iohk.atala.agent.walletapi.model.error.PublishManagedDIDError
-import io.iohk.atala.agent.walletapi.model.error.UpdateManagedDIDError
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.api.http.model.CollectionStats
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.api.util.PaginationUtils
-import io.iohk.atala.castor.controller.http.CreateManagedDIDResponse
-import io.iohk.atala.castor.controller.http.CreateManagedDidRequest
-import io.iohk.atala.castor.controller.http.DIDOperationResponse
-import io.iohk.atala.castor.controller.http.ManagedDID
-import io.iohk.atala.castor.controller.http.ManagedDIDPage
-import io.iohk.atala.castor.controller.http.UpdateManagedDIDRequest
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.utils.Traverse.*
+package org.hyperledger.identus.castor.controller
+
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDDetail
+import org.hyperledger.identus.agent.walletapi.model.error.CreateManagedDIDError
+import org.hyperledger.identus.agent.walletapi.model.error.GetManagedDIDError
+import org.hyperledger.identus.agent.walletapi.model.error.PublishManagedDIDError
+import org.hyperledger.identus.agent.walletapi.model.error.UpdateManagedDIDError
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.api.http.model.CollectionStats
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.api.util.PaginationUtils
+import org.hyperledger.identus.castor.controller.http.CreateManagedDIDResponse
+import org.hyperledger.identus.castor.controller.http.CreateManagedDidRequest
+import org.hyperledger.identus.castor.controller.http.DIDOperationResponse
+import org.hyperledger.identus.castor.controller.http.ManagedDID
+import org.hyperledger.identus.castor.controller.http.ManagedDIDPage
+import org.hyperledger.identus.castor.controller.http.UpdateManagedDIDRequest
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.utils.Traverse.*
import scala.language.implicitConversions
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDRegistrarEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDRegistrarEndpoints.scala
similarity index 89%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDRegistrarEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDRegistrarEndpoints.scala
index 0e7e61936a..172d2b1f40 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDRegistrarEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDRegistrarEndpoints.scala
@@ -1,21 +1,21 @@
-package io.iohk.atala.castor.controller
+package org.hyperledger.identus.castor.controller
-import io.iohk.atala.api.http.EndpointOutputs.FailureVariant
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{EndpointOutputs, ErrorResponse, RequestContext}
-import io.iohk.atala.castor.controller.http.DIDOperationResponse
-import io.iohk.atala.castor.controller.http.UpdateManagedDIDRequest
-import io.iohk.atala.castor.controller.http.{
+import org.hyperledger.identus.api.http.EndpointOutputs.FailureVariant
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{EndpointOutputs, ErrorResponse, RequestContext}
+import org.hyperledger.identus.castor.controller.http.DIDOperationResponse
+import org.hyperledger.identus.castor.controller.http.UpdateManagedDIDRequest
+import org.hyperledger.identus.castor.controller.http.{
CreateManagedDIDResponse,
CreateManagedDidRequest,
DIDInput,
ManagedDID,
ManagedDIDPage
}
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
import sttp.apispec.Tag
import sttp.model.StatusCode
import sttp.tapir.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDRegistrarServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDRegistrarServerEndpoints.scala
similarity index 88%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDRegistrarServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDRegistrarServerEndpoints.scala
index 73eb7189f6..06eb313e7b 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDRegistrarServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDRegistrarServerEndpoints.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.castor.controller
+package org.hyperledger.identus.castor.controller
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.Authorizer
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.SecurityLogic
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.Authorizer
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.SecurityLogic
+import org.hyperledger.identus.shared.models.WalletAccessContext
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDServerEndpoints.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDServerEndpoints.scala
index 3fa30527b3..000f362f33 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/DIDServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/DIDServerEndpoints.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.castor.controller
+package org.hyperledger.identus.castor.controller
-import io.iohk.atala.LogUtils.*
+import org.hyperledger.identus.LogUtils.*
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDDocument.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDDocument.scala
similarity index 92%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDDocument.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDDocument.scala
index 30ec6db675..a1e5942649 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDDocument.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDDocument.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.castor.core.model.did.w3c
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.castor.core.model.did.w3c
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
-import io.iohk.atala.castor.controller.http.DIDDocument.annotations
+import org.hyperledger.identus.castor.controller.http.DIDDocument.annotations
import scala.language.implicitConversions
@description("A W3C compliant Prism DID document representation.")
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDDocumentMetadata.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDDocumentMetadata.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDDocumentMetadata.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDDocumentMetadata.scala
index 52873d164f..d12cc5d645 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDDocumentMetadata.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDDocumentMetadata.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.castor.core.model.did.w3c
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.castor.core.model.did.w3c
import sttp.tapir.Schema
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
import sttp.tapir.Schema.annotations.{description, encodedExample}
-import io.iohk.atala.castor.controller.http.DIDDocumentMetadata.annotations
+import org.hyperledger.identus.castor.controller.http.DIDDocumentMetadata.annotations
@description("[DID document metadata](https://www.w3.org/TR/did-core/#did-document-metadata)")
final case class DIDDocumentMetadata(
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDInput.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDInput.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDInput.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDInput.scala
index 4da2fa8561..f11fed8cd5 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDInput.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDInput.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
import sttp.tapir.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDResolutionMetadata.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDResolutionMetadata.scala
similarity index 89%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDResolutionMetadata.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDResolutionMetadata.scala
index b680ff2ef6..5426b27d58 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDResolutionMetadata.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDResolutionMetadata.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.castor.controller.http.DIDResolutionMetadata.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.castor.controller.http.DIDResolutionMetadata.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDResolutionResult.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDResolutionResult.scala
similarity index 91%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDResolutionResult.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDResolutionResult.scala
index 3fb50cc70a..9fb37052b5 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/DIDResolutionResult.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/DIDResolutionResult.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
import sttp.tapir.Schema
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ManagedDID.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/ManagedDID.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ManagedDID.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/ManagedDID.scala
index 781ef3f607..021275998a 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ManagedDID.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/ManagedDID.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.castor.controller.http
-
-import io.iohk.atala.agent.walletapi.model as walletDomain
-import io.iohk.atala.agent.walletapi.model.DIDPublicKeyTemplate
-import io.iohk.atala.agent.walletapi.model.ManagedDIDDetail
-import io.iohk.atala.agent.walletapi.model.PublicationState
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.castor.core.model.did as castorDomain
-import io.iohk.atala.castor.core.model.did.EllipticCurve
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.shared.utils.Traverse.*
+package org.hyperledger.identus.castor.controller.http
+
+import org.hyperledger.identus.agent.walletapi.model as walletDomain
+import org.hyperledger.identus.agent.walletapi.model.DIDPublicKeyTemplate
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDDetail
+import org.hyperledger.identus.agent.walletapi.model.PublicationState
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.castor.core.model.did as castorDomain
+import org.hyperledger.identus.castor.core.model.did.EllipticCurve
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.shared.utils.Traverse.*
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/PublicKeyJwk.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/PublicKeyJwk.scala
similarity index 86%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/PublicKeyJwk.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/PublicKeyJwk.scala
index 90d5377a89..7142f279d1 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/PublicKeyJwk.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/PublicKeyJwk.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
-import io.iohk.atala.castor.core.model.did.w3c
+import org.hyperledger.identus.castor.core.model.did.w3c
import sttp.tapir.Schema
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ScheduledOperation.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/ScheduledOperation.scala
similarity index 89%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ScheduledOperation.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/ScheduledOperation.scala
index 4da951371d..e1d1fd76f7 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/ScheduledOperation.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/ScheduledOperation.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.castor.core.model.did.ScheduleDIDOperationOutcome
-import io.iohk.atala.shared.models.HexString
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.castor.core.model.did.ScheduleDIDOperationOutcome
+import org.hyperledger.identus.shared.models.HexString
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/Service.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/Service.scala
similarity index 91%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/Service.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/Service.scala
index 84615a56f4..08f47150c7 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/Service.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/Service.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
import io.circe.Json
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.api.http.codec.CirceJsonInterop
-import io.iohk.atala.castor.controller.http.Service.annotations
-import io.iohk.atala.castor.core.model.ProtoModelHelper
-import io.iohk.atala.castor.core.model.did as castorDomain
-import io.iohk.atala.castor.core.model.did.w3c
-import io.iohk.atala.shared.utils.Traverse.*
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.api.http.codec.CirceJsonInterop
+import org.hyperledger.identus.castor.controller.http.Service.annotations
+import org.hyperledger.identus.castor.core.model.ProtoModelHelper
+import org.hyperledger.identus.castor.core.model.did as castorDomain
+import org.hyperledger.identus.castor.core.model.did.w3c
+import org.hyperledger.identus.shared.utils.Traverse.*
import scala.language.implicitConversions
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/UpdateManagedDID.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/UpdateManagedDID.scala
similarity index 95%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/UpdateManagedDID.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/UpdateManagedDID.scala
index b4717084f1..14a76c48d4 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/UpdateManagedDID.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/UpdateManagedDID.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
-import io.iohk.atala.agent.walletapi.model as walletDomain
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.castor.core.model.did as castorDomain
-import io.iohk.atala.shared.utils.Traverse.*
+import org.hyperledger.identus.agent.walletapi.model as walletDomain
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.castor.core.model.did as castorDomain
+import org.hyperledger.identus.shared.utils.Traverse.*
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/VerificationMethod.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/VerificationMethod.scala
similarity index 88%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/VerificationMethod.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/VerificationMethod.scala
index 8456c9f6e2..b4464b4fb1 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/castor/controller/http/VerificationMethod.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/controller/http/VerificationMethod.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.castor.controller.http
+package org.hyperledger.identus.castor.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.castor.core.model.did.w3c
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.castor.core.model.did.w3c
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
-import io.iohk.atala.castor.controller.http.VerificationMethod.annotations
+import org.hyperledger.identus.castor.controller.http.VerificationMethod.annotations
import scala.language.implicitConversions
@description(
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusController.scala
similarity index 74%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusController.scala
index 7091920486..221dce9b9c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusController.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.credentialstatus.controller
+package org.hyperledger.identus.credential.status.controller
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.credentialstatus.controller.http.StatusListCredential
-import io.iohk.atala.pollux.core.model.error.CredentialStatusListServiceError
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.credential.status.controller.http.StatusListCredential
+import org.hyperledger.identus.pollux.core.model.error.CredentialStatusListServiceError
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
-import io.iohk.atala.pollux.core.model.DidCommID
+import org.hyperledger.identus.pollux.core.model.DidCommID
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusControllerImpl.scala
similarity index 69%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusControllerImpl.scala
index c4640f0efa..636935feb4 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusControllerImpl.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.credentialstatus.controller
+package org.hyperledger.identus.credential.status.controller
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.credentialstatus.controller.http.StatusListCredential
-import io.iohk.atala.pollux.core.service.CredentialStatusListService
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.credential.status.controller.http.StatusListCredential
+import org.hyperledger.identus.pollux.core.service.CredentialStatusListService
import zio.*
-import io.iohk.atala.pollux.core.model.DidCommID
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.DidCommID
+import org.hyperledger.identus.shared.models.WalletAccessContext
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusEndpoints.scala
similarity index 68%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusEndpoints.scala
index 675e5ca169..298b5755db 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusEndpoints.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.credentialstatus.controller
+package org.hyperledger.identus.credential.status.controller
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.credentialstatus.controller.http.StatusListCredential
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.credential.status.controller.http.StatusListCredential
import sttp.tapir.*
import sttp.tapir.json.zio.jsonBody
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
import java.util.UUID
-import io.iohk.atala.pollux.core.model.DidCommID
-import io.iohk.atala.api.http.codec.DidCommIDCodec.given
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.pollux.core.model.DidCommID
+import org.hyperledger.identus.api.http.codec.DidCommIDCodec.given
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
object CredentialStatusEndpoints {
val getCredentialStatusListEndpoint: PublicEndpoint[
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusServiceEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusServiceEndpoints.scala
similarity index 73%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusServiceEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusServiceEndpoints.scala
index 3e2a720e84..fc34063704 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/CredentialStatusServiceEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/CredentialStatusServiceEndpoints.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.credentialstatus.controller
+package org.hyperledger.identus.credential.status.controller
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.Authorizer
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.SecurityLogic
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.Authorizer
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.SecurityLogic
+import org.hyperledger.identus.shared.models.WalletAccessContext
import sttp.tapir.ztapir.*
import zio.*
-import io.iohk.atala.credentialstatus.controller.CredentialStatusEndpoints.*
+import org.hyperledger.identus.credential.status.controller.CredentialStatusEndpoints.*
import sttp.model.StatusCode
-import io.iohk.atala.pollux.core.model.DidCommID
+import org.hyperledger.identus.pollux.core.model.DidCommID
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/http/StatusListCredential.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/http/StatusListCredential.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/http/StatusListCredential.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/http/StatusListCredential.scala
index 18cbdc78a8..c6f8497df5 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/credentialstatus/controller/http/StatusListCredential.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/credentialstatus/controller/http/StatusListCredential.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.credentialstatus.controller.http
+package org.hyperledger.identus.credential.status.controller.http
-import io.iohk.atala.pollux.vc.jwt.StatusPurpose
-import io.iohk.atala.api.http.Annotation
+import org.hyperledger.identus.pollux.vc.jwt.StatusPurpose
+import org.hyperledger.identus.api.http.Annotation
import sttp.tapir.Schema.annotations.{description, encodedExample}
-import io.iohk.atala.credentialstatus.controller.http.StatusListCredential.annotations
+import org.hyperledger.identus.credential.status.controller.http.StatusListCredential.annotations
import sttp.tapir.Schema
import zio.json.*
-import io.iohk.atala.pollux.core.model.CredentialStatusList
-import io.iohk.atala.pollux.core.model.error.CredentialStatusListServiceError
+import org.hyperledger.identus.pollux.core.model.CredentialStatusList
+import org.hyperledger.identus.pollux.core.model.error.CredentialStatusListServiceError
import sttp.tapir.json.zio.schemaForZioJsonValue
import zio.json.ast.Json
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/EventController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/EventController.scala
similarity index 73%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/EventController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/EventController.scala
index cb643c6696..0aa9f38ed5 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/EventController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/EventController.scala
@@ -1,18 +1,18 @@
-package io.iohk.atala.event.controller
+package org.hyperledger.identus.event.controller
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceError
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.CollectionStats
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.util.PaginationUtils
-import io.iohk.atala.event.controller.http.CreateWebhookNotification
-import io.iohk.atala.event.controller.http.WebhookNotification
-import io.iohk.atala.event.controller.http.WebhookNotificationPage
-import io.iohk.atala.event.notification.EventNotificationConfig
-import io.iohk.atala.iam.wallet.http.controller.WalletManagementController
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementService
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementServiceError
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.CollectionStats
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.util.PaginationUtils
+import org.hyperledger.identus.event.controller.http.CreateWebhookNotification
+import org.hyperledger.identus.event.controller.http.WebhookNotification
+import org.hyperledger.identus.event.controller.http.WebhookNotificationPage
+import org.hyperledger.identus.event.notification.EventNotificationConfig
+import org.hyperledger.identus.iam.wallet.http.controller.WalletManagementController
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.net.URL
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/EventEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/EventEndpoints.scala
similarity index 68%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/EventEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/EventEndpoints.scala
index 88b886d0f4..0320224faf 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/EventEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/EventEndpoints.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.event.controller
+package org.hyperledger.identus.event.controller
-import io.iohk.atala.api.http.EndpointOutputs
-import io.iohk.atala.api.http.EndpointOutputs.FailureVariant
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.event.controller.http.CreateWebhookNotification
-import io.iohk.atala.event.controller.http.WebhookNotification
-import io.iohk.atala.event.controller.http.WebhookNotificationPage
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.api.http.EndpointOutputs
+import org.hyperledger.identus.api.http.EndpointOutputs.FailureVariant
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.event.controller.http.CreateWebhookNotification
+import org.hyperledger.identus.event.controller.http.WebhookNotification
+import org.hyperledger.identus.event.controller.http.WebhookNotificationPage
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
import sttp.model.StatusCode
import sttp.tapir.*
import sttp.tapir.json.zio.jsonBody
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/EventServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/EventServerEndpoints.scala
similarity index 81%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/EventServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/EventServerEndpoints.scala
index 806bc2a3f6..c05d23e22c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/EventServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/EventServerEndpoints.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.event.controller
+package org.hyperledger.identus.event.controller
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.Authorizer
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.Authorizer
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.shared.models.WalletAccessContext
import sttp.tapir.ztapir.*
import zio.*
-import io.iohk.atala.iam.authentication.SecurityLogic
+import org.hyperledger.identus.iam.authentication.SecurityLogic
class EventServerEndpoints(
eventController: EventController,
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/http/CreateWebhookNotification.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/http/CreateWebhookNotification.scala
similarity index 90%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/http/CreateWebhookNotification.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/http/CreateWebhookNotification.scala
index a3e01269de..e6e413bfc4 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/http/CreateWebhookNotification.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/http/CreateWebhookNotification.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.event.controller.http
+package org.hyperledger.identus.event.controller.http
import sttp.tapir.Schema
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonEncoder, JsonDecoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/http/WebhookNotification.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/http/WebhookNotification.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/http/WebhookNotification.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/http/WebhookNotification.scala
index eca0db157f..27fbbbefcc 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/event/controller/http/WebhookNotification.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/event/controller/http/WebhookNotification.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.event.controller.http
+package org.hyperledger.identus.event.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.event.notification.EventNotificationConfig
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.event.notification.EventNotificationConfig
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample, validate, validateEach}
import zio.json.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/AuthenticationConfig.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/AuthenticationConfig.scala
similarity index 52%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/AuthenticationConfig.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/AuthenticationConfig.scala
index f229687de1..debadc9492 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/AuthenticationConfig.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/AuthenticationConfig.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.iam.authentication
+package org.hyperledger.identus.iam.authentication
-import io.iohk.atala.iam.authentication.admin.AdminConfig
-import io.iohk.atala.iam.authentication.apikey.ApiKeyConfig
-import io.iohk.atala.iam.authentication.oidc.KeycloakConfig
+import org.hyperledger.identus.iam.authentication.admin.AdminConfig
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyConfig
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakConfig
final case class AuthenticationConfig(
admin: AdminConfig,
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/Authenticator.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/Authenticator.scala
similarity index 86%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/Authenticator.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/Authenticator.scala
index 6ed48dcc11..8b34c79f6c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/Authenticator.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/Authenticator.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.iam.authentication
-
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.EntityRole
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
+package org.hyperledger.identus.iam.authentication
+
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.EntityRole
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.{IO, ZIO, ZLayer}
trait Credentials
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/DefaultAuthenticator.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/DefaultAuthenticator.scala
similarity index 69%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/DefaultAuthenticator.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/DefaultAuthenticator.scala
index a47b510c1c..2bb447171a 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/DefaultAuthenticator.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/DefaultAuthenticator.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.iam.authentication
-
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.iam.authentication.admin.{AdminApiKeyAuthenticator, AdminApiKeyCredentials}
-import io.iohk.atala.iam.authentication.apikey.{ApiKeyAuthenticator, ApiKeyCredentials}
-import io.iohk.atala.iam.authentication.oidc.KeycloakEntity
-import io.iohk.atala.iam.authentication.oidc.{KeycloakAuthenticator, JwtCredentials}
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
+package org.hyperledger.identus.iam.authentication
+
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.iam.authentication.admin.{AdminApiKeyAuthenticator, AdminApiKeyCredentials}
+import org.hyperledger.identus.iam.authentication.apikey.{ApiKeyAuthenticator, ApiKeyCredentials}
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakEntity
+import org.hyperledger.identus.iam.authentication.oidc.{KeycloakAuthenticator, JwtCredentials}
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
import zio.*
case class DefaultAuthenticator(
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/SecurityLogic.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/SecurityLogic.scala
similarity index 83%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/SecurityLogic.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/SecurityLogic.scala
index 52e4434d9a..a98daa970a 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/SecurityLogic.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/SecurityLogic.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.iam.authentication
+package org.hyperledger.identus.iam.authentication
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.EntityRole
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.iam.authentication.AuthenticationError.AuthenticationMethodNotEnabled
-import io.iohk.atala.iam.authentication.admin.AdminApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.EntityRole
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.iam.authentication.AuthenticationError.AuthenticationMethodNotEnabled
+import org.hyperledger.identus.iam.authentication.admin.AdminApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
import zio.*
object SecurityLogic {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeyAuthenticator.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeyAuthenticator.scala
similarity index 63%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeyAuthenticator.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeyAuthenticator.scala
index 1444e29d08..500873d90b 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeyAuthenticator.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeyAuthenticator.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.iam.authentication.admin
+package org.hyperledger.identus.iam.authentication.admin
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.iam.authentication.EntityAuthorizer
-import io.iohk.atala.iam.authentication.{AuthenticationError, Credentials}
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.iam.authentication.EntityAuthorizer
+import org.hyperledger.identus.iam.authentication.{AuthenticationError, Credentials}
import zio.*
trait AdminApiKeyAuthenticator extends AuthenticatorWithAuthZ[Entity], EntityAuthorizer {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeyAuthenticatorImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeyAuthenticatorImpl.scala
similarity index 78%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeyAuthenticatorImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeyAuthenticatorImpl.scala
index e0f62655e4..c4e32d4b3f 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeyAuthenticatorImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeyAuthenticatorImpl.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.iam.authentication.admin
+package org.hyperledger.identus.iam.authentication.admin
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.iam.authentication.AuthenticationError
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.iam.authentication.AuthenticationError
import zio.{IO, URLayer, ZIO, ZLayer}
case class AdminApiKeyAuthenticatorImpl(adminConfig: AdminConfig) extends AdminApiKeyAuthenticator {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeyCredentials.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeyCredentials.scala
similarity index 74%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeyCredentials.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeyCredentials.scala
index d255043a36..9903edac58 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeyCredentials.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeyCredentials.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.iam.authentication.admin
+package org.hyperledger.identus.iam.authentication.admin
-import io.iohk.atala.iam.authentication.{AuthenticationError, Credentials}
+import org.hyperledger.identus.iam.authentication.{AuthenticationError, Credentials}
case class AdminApiKeyAuthenticationError(message: String) extends AuthenticationError
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeySecurityLogic.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeySecurityLogic.scala
similarity index 88%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeySecurityLogic.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeySecurityLogic.scala
index 2c6a5db656..1e351d494c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminApiKeySecurityLogic.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminApiKeySecurityLogic.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.iam.authentication.admin
+package org.hyperledger.identus.iam.authentication.admin
import sttp.tapir.EndpointIO
import sttp.tapir.EndpointInput.Auth
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminConfig.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminConfig.scala
similarity index 73%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminConfig.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminConfig.scala
index f1de628d5b..ba0920ab67 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/admin/AdminConfig.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/admin/AdminConfig.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.iam.authentication.admin
+package org.hyperledger.identus.iam.authentication.admin
-import io.iohk.atala.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.config.AppConfig
import zio.{URLayer, ZLayer}
final case class AdminConfig(token: String)
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyAuthenticator.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyAuthenticator.scala
similarity index 79%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyAuthenticator.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyAuthenticator.scala
index 8a60e147df..fea47359e4 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyAuthenticator.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyAuthenticator.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.iam.authentication.apikey
+package org.hyperledger.identus.iam.authentication.apikey
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.iam.authentication.AuthenticationError.*
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.iam.authentication.EntityAuthorizer
-import io.iohk.atala.iam.authentication.{AuthenticationError, Credentials}
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.iam.authentication.AuthenticationError.*
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.iam.authentication.EntityAuthorizer
+import org.hyperledger.identus.iam.authentication.{AuthenticationError, Credentials}
import zio.{IO, ZIO}
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyAuthenticatorImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyAuthenticatorImpl.scala
similarity index 90%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyAuthenticatorImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyAuthenticatorImpl.scala
index 2707795a51..364b0b1468 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyAuthenticatorImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyAuthenticatorImpl.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.iam.authentication.apikey
+package org.hyperledger.identus.iam.authentication.apikey
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.service.{EntityService, WalletManagementService}
-import io.iohk.atala.iam.authentication.AuthenticationError
-import io.iohk.atala.iam.authentication.AuthenticationError.*
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.service.{EntityService, WalletManagementService}
+import org.hyperledger.identus.iam.authentication.AuthenticationError
+import org.hyperledger.identus.iam.authentication.AuthenticationError.*
import io.iohk.atala.prism.crypto.Sha256
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.{IO, URLayer, ZIO, ZLayer}
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyConfig.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyConfig.scala
similarity index 70%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyConfig.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyConfig.scala
index ec760b5d6f..5efbad7147 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyConfig.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyConfig.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.iam.authentication.apikey
+package org.hyperledger.identus.iam.authentication.apikey
-import io.iohk.atala.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.config.AppConfig
import zio.*
case class ApiKeyConfig(salt: String, enabled: Boolean, authenticateAsDefaultUser: Boolean, autoProvisioning: Boolean)
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyEndpointSecurityLogic.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyEndpointSecurityLogic.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyEndpointSecurityLogic.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyEndpointSecurityLogic.scala
index cc8585ef6d..1821c291a2 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyEndpointSecurityLogic.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyEndpointSecurityLogic.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.iam.authentication.apikey
+package org.hyperledger.identus.iam.authentication.apikey
import sttp.tapir.EndpointIO
import sttp.tapir.EndpointInput.Auth
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/AuthenticationRepository.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/AuthenticationRepository.scala
similarity index 98%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/AuthenticationRepository.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/AuthenticationRepository.scala
index d52d27ab1b..411847c7f9 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/AuthenticationRepository.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/AuthenticationRepository.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.iam.authentication.apikey
+package org.hyperledger.identus.iam.authentication.apikey
import io.getquill.context.json.PostgresJsonExtensions
import io.getquill.doobie.DoobieContext
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/JdbcAuthenticationRepository.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/JdbcAuthenticationRepository.scala
similarity index 98%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/JdbcAuthenticationRepository.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/JdbcAuthenticationRepository.scala
index e96cfc8d58..55a440b26f 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/JdbcAuthenticationRepository.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/JdbcAuthenticationRepository.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.iam.authentication.apikey
+package org.hyperledger.identus.iam.authentication.apikey
import doobie.*
import doobie.implicits.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/package.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/package.scala
similarity index 88%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/package.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/package.scala
index d9aca0200a..e1dd6716e7 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/apikey/package.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/apikey/package.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.iam.authentication
+package org.hyperledger.identus.iam.authentication
package object apikey {
case class ApiKeyCredentials(apiKey: Option[String]) extends Credentials
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/JwtCredentials.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/JwtCredentials.scala
similarity index 59%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/JwtCredentials.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/JwtCredentials.scala
index a303dfd522..099550fdd6 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/JwtCredentials.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/JwtCredentials.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.iam.authentication.oidc
+package org.hyperledger.identus.iam.authentication.oidc
-import io.iohk.atala.iam.authentication.AuthenticationError
-import io.iohk.atala.iam.authentication.Credentials
+import org.hyperledger.identus.iam.authentication.AuthenticationError
+import org.hyperledger.identus.iam.authentication.Credentials
final case class JwtCredentials(token: Option[String]) extends Credentials
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/JwtSecurityLogic.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/JwtSecurityLogic.scala
similarity index 83%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/JwtSecurityLogic.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/JwtSecurityLogic.scala
index 64a141d803..2925d87ba9 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/JwtSecurityLogic.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/JwtSecurityLogic.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.iam.authentication.oidc
+package org.hyperledger.identus.iam.authentication.oidc
import sttp.tapir.EndpointInput.Auth
import sttp.tapir.EndpointInput.AuthType.Http
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakAuthenticator.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakAuthenticator.scala
similarity index 83%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakAuthenticator.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakAuthenticator.scala
index 9bce9e564f..9567a53cf1 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakAuthenticator.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakAuthenticator.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.iam.authentication.oidc
+package org.hyperledger.identus.iam.authentication.oidc
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.EntityRole
-import io.iohk.atala.iam.authentication.AuthenticationError
-import io.iohk.atala.iam.authentication.AuthenticationError.AuthenticationMethodNotEnabled
-import io.iohk.atala.iam.authentication.AuthenticationError.InvalidCredentials
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.iam.authentication.Credentials
-import io.iohk.atala.shared.utils.Traverse.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.EntityRole
+import org.hyperledger.identus.iam.authentication.AuthenticationError
+import org.hyperledger.identus.iam.authentication.AuthenticationError.AuthenticationMethodNotEnabled
+import org.hyperledger.identus.iam.authentication.AuthenticationError.InvalidCredentials
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.iam.authentication.Credentials
+import org.hyperledger.identus.shared.utils.Traverse.*
import pdi.jwt.JwtCirce
import pdi.jwt.JwtClaim
import pdi.jwt.JwtOptions
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakAuthenticatorImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakAuthenticatorImpl.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakAuthenticatorImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakAuthenticatorImpl.scala
index 4d9f5156d8..35f46c440d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakAuthenticatorImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakAuthenticatorImpl.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.iam.authentication.oidc
+package org.hyperledger.identus.iam.authentication.oidc
-import io.iohk.atala.agent.walletapi.model.EntityRole
-import io.iohk.atala.iam.authentication.AuthenticationError
-import io.iohk.atala.iam.authentication.AuthenticationError.AuthenticationMethodNotEnabled
-import io.iohk.atala.iam.authorization.core.PermissionManagement
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error.PermissionNotAvailable
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.agent.walletapi.model.EntityRole
+import org.hyperledger.identus.iam.authentication.AuthenticationError
+import org.hyperledger.identus.iam.authentication.AuthenticationError.AuthenticationMethodNotEnabled
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error.PermissionNotAvailable
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
import zio.*
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakClient.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakClient.scala
similarity index 99%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakClient.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakClient.scala
index 88260265c7..935531d25f 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakClient.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakClient.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.iam.authentication.oidc
+package org.hyperledger.identus.iam.authentication.oidc
import org.keycloak.authorization.client.{AuthzClient, Configuration as KeycloakAuthzConfig}
import org.keycloak.representations.idm.authorization.AuthorizationRequest
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakConfig.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakConfig.scala
similarity index 80%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakConfig.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakConfig.scala
index 6612b34e2e..463a8751a5 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authentication/oidc/KeycloakConfig.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakConfig.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.iam.authentication.oidc
+package org.hyperledger.identus.iam.authentication.oidc
import zio.*
-import io.iohk.atala.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.config.AppConfig
import java.net.URL
final case class KeycloakConfig(
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/DefaultPermissionManagementService.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/DefaultPermissionManagementService.scala
similarity index 74%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/DefaultPermissionManagementService.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/DefaultPermissionManagementService.scala
index b685bd438e..a885e83f5c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/DefaultPermissionManagementService.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/DefaultPermissionManagementService.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.iam.authorization
+package org.hyperledger.identus.iam.authorization
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.iam.authentication.oidc.KeycloakEntity
-import io.iohk.atala.iam.authorization.core.PermissionManagement
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakEntity
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
class DefaultPermissionManagementService(
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/core/EntityPermissionManagementService.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/core/EntityPermissionManagementService.scala
similarity index 69%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/core/EntityPermissionManagementService.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/core/EntityPermissionManagementService.scala
index e2a8d9a68a..b3977b642b 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/core/EntityPermissionManagementService.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/core/EntityPermissionManagementService.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.iam.authorization.core
-
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.service.EntityService
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error.ServiceError
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error.WalletNotFoundById
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
+package org.hyperledger.identus.iam.authorization.core
+
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.service.EntityService
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error.ServiceError
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error.WalletNotFoundById
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import scala.language.implicitConversions
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/core/PermissionManagement.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/core/PermissionManagement.scala
similarity index 72%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/core/PermissionManagement.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/core/PermissionManagement.scala
index b3d6c922f1..c4581dcb5e 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/core/PermissionManagement.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/core/PermissionManagement.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.iam.authorization.core
-
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError.EntityAlreadyExists
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError.EntityNotFound
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError.EntityStorageError
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError.EntityWalletNotFound
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
+package org.hyperledger.identus.iam.authorization.core
+
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError.EntityAlreadyExists
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError.EntityNotFound
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError.EntityStorageError
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError.EntityWalletNotFound
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakPermissionManagementService.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakPermissionManagementService.scala
similarity index 91%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakPermissionManagementService.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakPermissionManagementService.scala
index 04169b92e7..771f914911 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakPermissionManagementService.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakPermissionManagementService.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.iam.authorization.keycloak.admin
-
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.iam.authentication.oidc.KeycloakClient
-import io.iohk.atala.iam.authentication.oidc.KeycloakEntity
-import io.iohk.atala.iam.authorization.core.PermissionManagement
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error.*
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
+package org.hyperledger.identus.iam.authorization.keycloak.admin
+
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementService
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakClient
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakEntity
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error.*
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
import org.keycloak.authorization.client.AuthzClient
import org.keycloak.representations.idm.authorization.{ResourceRepresentation, UmaPermissionRepresentation}
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/EntityEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/EntityEndpoints.scala
similarity index 92%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/EntityEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/EntityEndpoints.scala
index 21a20edc2e..d8e5014d3d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/EntityEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/EntityEndpoints.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.iam.entity.http
+package org.hyperledger.identus.iam.entity.http
-import io.iohk.atala.api.http.*
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.iam.authentication.admin.AdminApiKeyCredentials
-import io.iohk.atala.iam.authentication.admin.AdminApiKeySecurityLogic.adminApiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
-import io.iohk.atala.iam.entity.http.model.*
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.iam.authentication.admin.AdminApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.admin.AdminApiKeySecurityLogic.adminApiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.iam.entity.http.model.*
import sttp.model.StatusCode
import sttp.tapir.json.zio.jsonBody
import sttp.tapir.{Endpoint, EndpointInput, endpoint, extractFromRequest, path, query, statusCode, stringToPath}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/EntityServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/EntityServerEndpoints.scala
similarity index 82%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/EntityServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/EntityServerEndpoints.scala
index 922517388a..f6901760c6 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/EntityServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/EntityServerEndpoints.scala
@@ -1,18 +1,18 @@
-package io.iohk.atala.iam.entity.http
+package org.hyperledger.identus.iam.entity.http
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.EntityRole
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.SecurityLogic
-import io.iohk.atala.iam.authentication.admin.{AdminApiKeyCredentials}
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.entity.http.EntityEndpoints.*
-import io.iohk.atala.iam.entity.http.controller.EntityController
-import io.iohk.atala.iam.entity.http.model.{
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.EntityRole
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.SecurityLogic
+import org.hyperledger.identus.iam.authentication.admin.{AdminApiKeyCredentials}
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.entity.http.EntityEndpoints.*
+import org.hyperledger.identus.iam.entity.http.controller.EntityController
+import org.hyperledger.identus.iam.entity.http.model.{
ApiKeyAuthenticationRequest,
CreateEntityRequest,
UpdateEntityNameRequest,
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/controller/EntityController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/controller/EntityController.scala
similarity index 80%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/controller/EntityController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/controller/EntityController.scala
index 6058585e48..d48dac5486 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/controller/EntityController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/controller/EntityController.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.iam.entity.http.controller
+package org.hyperledger.identus.iam.entity.http.controller
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.iam.entity.http.model.{CreateEntityRequest, EntityResponse, EntityResponsePage}
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.iam.entity.http.model.{CreateEntityRequest, EntityResponse, EntityResponsePage}
import zio.*
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/controller/EntityControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/controller/EntityControllerImpl.scala
similarity index 84%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/controller/EntityControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/controller/EntityControllerImpl.scala
index 44ff91c78b..1bb20be18e 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/controller/EntityControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/controller/EntityControllerImpl.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.iam.entity.http.controller
+package org.hyperledger.identus.iam.entity.http.controller
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError
-import io.iohk.atala.agent.walletapi.service.EntityService
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.iam.authentication.AuthenticationError
-import io.iohk.atala.iam.entity.http.model.{CreateEntityRequest, EntityResponse, EntityResponsePage}
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError
+import org.hyperledger.identus.agent.walletapi.service.EntityService
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.iam.authentication.AuthenticationError
+import org.hyperledger.identus.iam.entity.http.model.{CreateEntityRequest, EntityResponse, EntityResponsePage}
import zio.ZIO.succeed
import zio.{IO, URLayer, ZLayer}
-import io.iohk.atala.iam.authentication.apikey.ApiKeyAuthenticator
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyAuthenticator
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/ApiKeyAuthenticationRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/ApiKeyAuthenticationRequest.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/ApiKeyAuthenticationRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/ApiKeyAuthenticationRequest.scala
index 7be26f004a..d5b274b31d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/ApiKeyAuthenticationRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/ApiKeyAuthenticationRequest.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.iam.entity.http.model
+package org.hyperledger.identus.iam.entity.http.model
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.iam.entity.http.model.ApiKeyAuthenticationRequest.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.iam.entity.http.model.ApiKeyAuthenticationRequest.annotations
import sttp.tapir.{Schema, Validator}
import sttp.tapir.Schema.annotations.{description, encodedExample, validate, validateEach}
import sttp.tapir.Validator.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/CreateEntityRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/CreateEntityRequest.scala
similarity index 91%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/CreateEntityRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/CreateEntityRequest.scala
index 294af25bca..650dfae862 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/CreateEntityRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/CreateEntityRequest.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.iam.entity.http.model
+package org.hyperledger.identus.iam.entity.http.model
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.iam.entity.http.model.CreateEntityRequest.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.iam.entity.http.model.CreateEntityRequest.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample, validate, validateEach}
import sttp.tapir.Validator
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/EntityResponse.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/EntityResponse.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/EntityResponse.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/EntityResponse.scala
index e32650e333..72d03d34bb 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/EntityResponse.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/EntityResponse.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.iam.entity.http.model
+package org.hyperledger.identus.iam.entity.http.model
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.iam.entity.http.model.EntityResponse.annotations
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.iam.entity.http.model.EntityResponse.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample, validate, validateEach}
import sttp.tapir.Validator.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/EntityResponsePage.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/EntityResponsePage.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/EntityResponsePage.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/EntityResponsePage.scala
index b3a6a34751..63bfae19da 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/EntityResponsePage.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/EntityResponsePage.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.iam.entity.http.model
+package org.hyperledger.identus.iam.entity.http.model
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.iam.entity.http.model.EntityResponsePage.annotations
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.iam.entity.http.model.EntityResponsePage.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample, validate, validateEach}
import sttp.tapir.Validator.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/UpdateEntityNameRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/UpdateEntityNameRequest.scala
similarity index 83%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/UpdateEntityNameRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/UpdateEntityNameRequest.scala
index d25ff39157..a9c78ec7a1 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/UpdateEntityNameRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/UpdateEntityNameRequest.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.iam.entity.http.model
+package org.hyperledger.identus.iam.entity.http.model
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.iam.entity.http.model.UpdateEntityNameRequest.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.iam.entity.http.model.UpdateEntityNameRequest.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample, validate, validateEach}
import sttp.tapir.Validator
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/UpdateEntityWalletIdRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/UpdateEntityWalletIdRequest.scala
similarity index 83%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/UpdateEntityWalletIdRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/UpdateEntityWalletIdRequest.scala
index dfc815d363..b8f3e797f2 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/entity/http/model/UpdateEntityWalletIdRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/entity/http/model/UpdateEntityWalletIdRequest.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.iam.entity.http.model
+package org.hyperledger.identus.iam.entity.http.model
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.iam.entity.http.model.UpdateEntityWalletIdRequest.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.iam.entity.http.model.UpdateEntityWalletIdRequest.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample, validate, validateEach}
import sttp.tapir.Validator.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/WalletManagementEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/WalletManagementEndpoints.scala
similarity index 85%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/WalletManagementEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/WalletManagementEndpoints.scala
index e846c02c1f..1259f43e8d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/WalletManagementEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/WalletManagementEndpoints.scala
@@ -1,19 +1,19 @@
-package io.iohk.atala.iam.wallet.http
+package org.hyperledger.identus.iam.wallet.http
-import io.iohk.atala.api.http.EndpointOutputs
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.iam.authentication.admin.AdminApiKeyCredentials
-import io.iohk.atala.iam.authentication.admin.AdminApiKeySecurityLogic.adminApiKeyHeader
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
-import io.iohk.atala.iam.wallet.http.model.CreateWalletRequest
-import io.iohk.atala.iam.wallet.http.model.CreateWalletUmaPermissionRequest
-import io.iohk.atala.iam.wallet.http.model.WalletDetail
-import io.iohk.atala.iam.wallet.http.model.WalletDetailPage
+import org.hyperledger.identus.api.http.EndpointOutputs
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.iam.authentication.admin.AdminApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.admin.AdminApiKeySecurityLogic.adminApiKeyHeader
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.iam.wallet.http.model.CreateWalletRequest
+import org.hyperledger.identus.iam.wallet.http.model.CreateWalletUmaPermissionRequest
+import org.hyperledger.identus.iam.wallet.http.model.WalletDetail
+import org.hyperledger.identus.iam.wallet.http.model.WalletDetailPage
import sttp.apispec.Tag
import sttp.model.StatusCode
import sttp.tapir.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/WalletManagementServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/WalletManagementServerEndpoints.scala
similarity index 83%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/WalletManagementServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/WalletManagementServerEndpoints.scala
index 08fed5ca8f..066a402489 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/WalletManagementServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/WalletManagementServerEndpoints.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.iam.wallet.http
+package org.hyperledger.identus.iam.wallet.http
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.Authorizer
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.SecurityLogic
-import io.iohk.atala.iam.wallet.http.controller.WalletManagementController
-import io.iohk.atala.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.Authorizer
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.SecurityLogic
+import org.hyperledger.identus.iam.wallet.http.controller.WalletManagementController
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/controller/WalletManagementController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/controller/WalletManagementController.scala
similarity index 82%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/controller/WalletManagementController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/controller/WalletManagementController.scala
index 13d01d95d4..4ab7cc239d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/controller/WalletManagementController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/controller/WalletManagementController.scala
@@ -1,26 +1,26 @@
-package io.iohk.atala.iam.wallet.http.controller
-
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceError
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceError.TooManyPermittedWallet
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.CollectionStats
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.util.PaginationUtils
-import io.iohk.atala.iam.authentication.oidc.KeycloakEntity
-import io.iohk.atala.iam.authorization.core.PermissionManagement
-import io.iohk.atala.iam.wallet.http.model.CreateWalletRequest
-import io.iohk.atala.iam.wallet.http.model.CreateWalletUmaPermissionRequest
-import io.iohk.atala.iam.wallet.http.model.WalletDetail
-import io.iohk.atala.iam.wallet.http.model.WalletDetailPage
-import io.iohk.atala.shared.models.HexString
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletAdministrationContext.Admin
-import io.iohk.atala.shared.models.WalletId
+package org.hyperledger.identus.iam.wallet.http.controller
+
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementService
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementServiceError
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementServiceError.TooManyPermittedWallet
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.CollectionStats
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.util.PaginationUtils
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakEntity
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement
+import org.hyperledger.identus.iam.wallet.http.model.CreateWalletRequest
+import org.hyperledger.identus.iam.wallet.http.model.CreateWalletUmaPermissionRequest
+import org.hyperledger.identus.iam.wallet.http.model.WalletDetail
+import org.hyperledger.identus.iam.wallet.http.model.WalletDetailPage
+import org.hyperledger.identus.shared.models.HexString
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext.Admin
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/model/CreateWalletRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/model/CreateWalletRequest.scala
similarity index 94%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/model/CreateWalletRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/model/CreateWalletRequest.scala
index f7d5a42240..848eb496e9 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/model/CreateWalletRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/model/CreateWalletRequest.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.iam.wallet.http.model
+package org.hyperledger.identus.iam.wallet.http.model
-import io.iohk.atala.api.http.Annotation
+import org.hyperledger.identus.api.http.Annotation
import sttp.tapir.*
import sttp.tapir.Schema.annotations.{description, encodedExample, validate}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/model/CreateWalletUmaPermissionRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/model/CreateWalletUmaPermissionRequest.scala
similarity index 90%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/model/CreateWalletUmaPermissionRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/model/CreateWalletUmaPermissionRequest.scala
index 488e75b0e4..b46073e80a 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/model/CreateWalletUmaPermissionRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/model/CreateWalletUmaPermissionRequest.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.iam.wallet.http.model
+package org.hyperledger.identus.iam.wallet.http.model
-import io.iohk.atala.api.http.Annotation
+import org.hyperledger.identus.api.http.Annotation
import sttp.tapir.*
import sttp.tapir.Schema.annotations.{description, encodedExample, validate}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/model/WalletDetail.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/model/WalletDetail.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/model/WalletDetail.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/model/WalletDetail.scala
index 75fbfbac8d..5fb82b45cc 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/iam/wallet/http/model/WalletDetail.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/iam/wallet/http/model/WalletDetail.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.iam.wallet.http.model
+package org.hyperledger.identus.iam.wallet.http.model
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.api.http.Annotation
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.api.http.Annotation
import sttp.tapir.*
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueController.scala
similarity index 91%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueController.scala
index 6fec924fc2..e6b73579b7 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueController.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.issue.controller
+package org.hyperledger.identus.issue.controller
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.issue.controller.http.{
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.issue.controller.http.{
AcceptCredentialOfferRequest,
CreateIssueCredentialRecordRequest,
IssueCredentialRecord,
IssueCredentialRecordPage
}
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
trait IssueController {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueControllerImpl.scala
similarity index 85%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueControllerImpl.scala
index fe86612a7a..ac28323511 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueControllerImpl.scala
@@ -1,32 +1,32 @@
-package io.iohk.atala.issue.controller
-
-import io.iohk.atala.agent.server.ControllerHelper
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.walletapi.model.PublicationState
-import io.iohk.atala.agent.walletapi.model.PublicationState.{Created, PublicationPending, Published}
-import io.iohk.atala.agent.walletapi.model.error.GetManagedDIDError
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.api.http.model.{CollectionStats, PaginationInput}
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.api.util.PaginationUtils
-import io.iohk.atala.castor.core.model.did.{DIDData, DIDMetadata, PrismDID, VerificationRelationship}
-import io.iohk.atala.castor.core.model.error.DIDResolutionError
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.service.ConnectionService
-import io.iohk.atala.issue.controller.IssueController.toHttpError
-import io.iohk.atala.issue.controller.http.{
+package org.hyperledger.identus.issue.controller
+
+import org.hyperledger.identus.agent.server.ControllerHelper
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.walletapi.model.PublicationState
+import org.hyperledger.identus.agent.walletapi.model.PublicationState.{Created, PublicationPending, Published}
+import org.hyperledger.identus.agent.walletapi.model.error.GetManagedDIDError
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.api.http.model.{CollectionStats, PaginationInput}
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.api.util.PaginationUtils
+import org.hyperledger.identus.castor.core.model.did.{PrismDID, VerificationRelationship}
+import org.hyperledger.identus.castor.core.model.error.DIDResolutionError
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.service.ConnectionService
+import org.hyperledger.identus.issue.controller.IssueController.toHttpError
+import org.hyperledger.identus.issue.controller.http.{
AcceptCredentialOfferRequest,
CreateIssueCredentialRecordRequest,
IssueCredentialRecord,
IssueCredentialRecordPage
}
-import io.iohk.atala.pollux.core.model.CredentialFormat.{AnonCreds, JWT}
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.pollux.core.model.{CredentialFormat, DidCommID}
-import io.iohk.atala.pollux.core.service.CredentialService
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.Role
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.CredentialFormat.{AnonCreds, JWT}
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.pollux.core.model.{CredentialFormat, DidCommID}
+import org.hyperledger.identus.pollux.core.service.CredentialService
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.Role
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{URLayer, ZIO, ZLayer}
class IssueControllerImpl(
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueEndpoints.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueEndpoints.scala
index ff8f6cd680..3c98092582 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueEndpoints.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.issue.controller
+package org.hyperledger.identus.issue.controller
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
-import io.iohk.atala.issue.controller.http.*
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.issue.controller.http.*
import sttp.apispec.Tag
import sttp.model.StatusCode
import sttp.tapir.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueServerEndpoints.scala
similarity index 80%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueServerEndpoints.scala
index ed0f1bf4e3..3819417d30 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/IssueServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/IssueServerEndpoints.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.issue.controller
+package org.hyperledger.identus.issue.controller
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.Authorizer
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.SecurityLogic
-import io.iohk.atala.issue.controller.IssueEndpoints.*
-import io.iohk.atala.issue.controller.http.{AcceptCredentialOfferRequest, CreateIssueCredentialRecordRequest}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.Authorizer
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.SecurityLogic
+import org.hyperledger.identus.issue.controller.IssueEndpoints.*
+import org.hyperledger.identus.issue.controller.http.{AcceptCredentialOfferRequest, CreateIssueCredentialRecordRequest}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/AcceptCredentialOfferRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/AcceptCredentialOfferRequest.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/AcceptCredentialOfferRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/AcceptCredentialOfferRequest.scala
index d482e92251..3593e8c20e 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/AcceptCredentialOfferRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/AcceptCredentialOfferRequest.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.issue.controller.http
+package org.hyperledger.identus.issue.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.issue.controller.http.AcceptCredentialOfferRequest.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.issue.controller.http.AcceptCredentialOfferRequest.annotations
import sttp.tapir.Schema.annotations.{description, encodedExample, validate}
import sttp.tapir.{Schema, Validator}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/CreateIssueCredentialRecordRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/CreateIssueCredentialRecordRequest.scala
similarity index 96%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/CreateIssueCredentialRecordRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/CreateIssueCredentialRecordRequest.scala
index 793d0758f7..89b043b7a2 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/CreateIssueCredentialRecordRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/CreateIssueCredentialRecordRequest.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.issue.controller.http
+package org.hyperledger.identus.issue.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.issue.controller.http.CreateIssueCredentialRecordRequest.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.issue.controller.http.CreateIssueCredentialRecordRequest.annotations
import sttp.tapir.Schema.annotations.{description, encodedExample}
import sttp.tapir.json.zio.schemaForZioJsonValue
import sttp.tapir.{Schema, Validator}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/IssueCredentialRecord.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/IssueCredentialRecord.scala
similarity index 97%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/IssueCredentialRecord.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/IssueCredentialRecord.scala
index 84af0fc85b..2ff17cb402 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/IssueCredentialRecord.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/IssueCredentialRecord.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.issue.controller.http
+package org.hyperledger.identus.issue.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.issue.controller.http.IssueCredentialRecord.annotations
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, Base64}
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord as PolluxIssueCredentialRecord
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.issue.controller.http.IssueCredentialRecord.annotations
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, Base64}
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord as PolluxIssueCredentialRecord
import sttp.tapir.Schema.annotations.{description, encodedExample, validate}
import sttp.tapir.json.zio.schemaForZioJsonValue
import sttp.tapir.{Schema, Validator}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/IssueCredentialRecordPage.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/IssueCredentialRecordPage.scala
similarity index 95%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/IssueCredentialRecordPage.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/IssueCredentialRecordPage.scala
index 4a390ac536..dfc3a94ab0 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/issue/controller/http/IssueCredentialRecordPage.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/issue/controller/http/IssueCredentialRecordPage.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.issue.controller.http
+package org.hyperledger.identus.issue.controller.http
import sttp.tapir.Schema
-import io.iohk.atala.issue.controller.http.IssueCredentialRecordPage.annotations
+import org.hyperledger.identus.issue.controller.http.IssueCredentialRecordPage.annotations
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
-import io.iohk.atala.api.http.Annotation
+import org.hyperledger.identus.api.http.Annotation
/** @param self
* The reference to the connection collection itself. for example: ''https://atala-prism-products.io/dids''
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionRegistryEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionRegistryEndpoints.scala
similarity index 89%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionRegistryEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionRegistryEndpoints.scala
index 937c90301f..6510aae06f 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionRegistryEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionRegistryEndpoints.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.pollux.credentialdefinition
+package org.hyperledger.identus.pollux.credentialdefinition
-import io.iohk.atala.api.http.*
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.api.http.codec.OrderCodec.*
-import io.iohk.atala.api.http.model.{Order, PaginationInput}
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
-import io.iohk.atala.pollux.credentialdefinition.http.{
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.api.http.codec.OrderCodec.*
+import org.hyperledger.identus.api.http.model.{Order, PaginationInput}
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.pollux.credentialdefinition.http.{
CredentialDefinitionInput,
CredentialDefinitionResponse,
CredentialDefinitionResponsePage,
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionRegistryServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionRegistryServerEndpoints.scala
similarity index 77%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionRegistryServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionRegistryServerEndpoints.scala
index e68d7ccacb..cd2ef7be33 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionRegistryServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionRegistryServerEndpoints.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.pollux.credentialdefinition
+package org.hyperledger.identus.pollux.credentialdefinition
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.model.{Order, PaginationInput}
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.Authorizer
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.SecurityLogic
-import io.iohk.atala.pollux.credentialdefinition
-import io.iohk.atala.pollux.credentialdefinition.CredentialDefinitionRegistryEndpoints.*
-import io.iohk.atala.pollux.credentialdefinition.controller.CredentialDefinitionController
-import io.iohk.atala.pollux.credentialdefinition.http.{CredentialDefinitionInput, FilterInput}
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.model.{Order, PaginationInput}
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.Authorizer
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.SecurityLogic
+import org.hyperledger.identus.pollux.credentialdefinition
+import org.hyperledger.identus.pollux.credentialdefinition.CredentialDefinitionRegistryEndpoints.*
+import org.hyperledger.identus.pollux.credentialdefinition.controller.CredentialDefinitionController
+import org.hyperledger.identus.pollux.credentialdefinition.http.{CredentialDefinitionInput, FilterInput}
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/controller/CredentialDefinitionController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/controller/CredentialDefinitionController.scala
similarity index 82%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/controller/CredentialDefinitionController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/controller/CredentialDefinitionController.scala
index 0300f22415..39f3655866 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/controller/CredentialDefinitionController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/controller/CredentialDefinitionController.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.pollux.credentialdefinition.controller
+package org.hyperledger.identus.pollux.credentialdefinition.controller
-import io.iohk.atala.api.http.*
-import io.iohk.atala.api.http.model.{Order, Pagination}
-import io.iohk.atala.pollux.core.service.CredentialDefinitionService
-import io.iohk.atala.pollux.core.service.CredentialDefinitionService.Error.*
-import io.iohk.atala.pollux.credentialdefinition.http.{
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.api.http.model.{Order, Pagination}
+import org.hyperledger.identus.pollux.core.service.CredentialDefinitionService
+import org.hyperledger.identus.pollux.core.service.CredentialDefinitionService.Error.*
+import org.hyperledger.identus.pollux.credentialdefinition.http.{
CredentialDefinitionInput,
CredentialDefinitionResponse,
CredentialDefinitionResponsePage,
FilterInput
}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/controller/CredentialDefinitionControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/controller/CredentialDefinitionControllerImpl.scala
similarity index 76%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/controller/CredentialDefinitionControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/controller/CredentialDefinitionControllerImpl.scala
index c849db4f38..9eceb54fef 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/controller/CredentialDefinitionControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/controller/CredentialDefinitionControllerImpl.scala
@@ -1,24 +1,24 @@
-package io.iohk.atala.pollux.credentialdefinition.controller
+package org.hyperledger.identus.pollux.credentialdefinition.controller
-import io.iohk.atala.agent.walletapi.model.{ManagedDIDState, PublicationState}
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.api.http.*
-import io.iohk.atala.api.http.model.{CollectionStats, Order, Pagination}
-import io.iohk.atala.castor.core.model.did.{LongFormPrismDID, PrismDID}
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition.FilteredEntries
-import io.iohk.atala.pollux.core.service.CredentialDefinitionService
-import io.iohk.atala.pollux.core.service.CredentialDefinitionService.Error.*
-import io.iohk.atala.pollux.credentialdefinition
-import io.iohk.atala.pollux.credentialdefinition.controller.CredentialDefinitionController.domainToHttpErrorIO
-import io.iohk.atala.pollux.credentialdefinition.http.CredentialDefinitionInput.toDomain
-import io.iohk.atala.pollux.credentialdefinition.http.CredentialDefinitionResponse.fromDomain
-import io.iohk.atala.pollux.credentialdefinition.http.{
+import org.hyperledger.identus.agent.walletapi.model.{ManagedDIDState, PublicationState}
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.api.http.model.{CollectionStats, Order, Pagination}
+import org.hyperledger.identus.castor.core.model.did.{LongFormPrismDID, PrismDID}
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition.FilteredEntries
+import org.hyperledger.identus.pollux.core.service.CredentialDefinitionService
+import org.hyperledger.identus.pollux.core.service.CredentialDefinitionService.Error.*
+import org.hyperledger.identus.pollux.credentialdefinition
+import org.hyperledger.identus.pollux.credentialdefinition.controller.CredentialDefinitionController.domainToHttpErrorIO
+import org.hyperledger.identus.pollux.credentialdefinition.http.CredentialDefinitionInput.toDomain
+import org.hyperledger.identus.pollux.credentialdefinition.http.CredentialDefinitionResponse.fromDomain
+import org.hyperledger.identus.pollux.credentialdefinition.http.{
CredentialDefinitionInput,
CredentialDefinitionResponse,
CredentialDefinitionResponsePage,
FilterInput
}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.json.ast.Json
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/controller/CredentialDefinitionControllerLogic.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/controller/CredentialDefinitionControllerLogic.scala
similarity index 72%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/controller/CredentialDefinitionControllerLogic.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/controller/CredentialDefinitionControllerLogic.scala
index 3ca826f26a..6a46a7338b 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/controller/CredentialDefinitionControllerLogic.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/controller/CredentialDefinitionControllerLogic.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.credentialdefinition.controller
+package org.hyperledger.identus.pollux.credentialdefinition.controller
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.CollectionStats
-import io.iohk.atala.api.http.model.Pagination
-import io.iohk.atala.api.util.PaginationUtils
-import io.iohk.atala.pollux.credentialdefinition.http.CredentialDefinitionResponsePage
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.CollectionStats
+import org.hyperledger.identus.api.http.model.Pagination
+import org.hyperledger.identus.api.util.PaginationUtils
+import org.hyperledger.identus.pollux.credentialdefinition.http.CredentialDefinitionResponsePage
import sttp.model.Uri
case class CredentialDefinitionControllerLogic(
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/CredentialDefinitionInput.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/CredentialDefinitionInput.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/CredentialDefinitionInput.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/CredentialDefinitionInput.scala
index a3077891cb..462fa11c45 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/CredentialDefinitionInput.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/CredentialDefinitionInput.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.credentialdefinition.http
+package org.hyperledger.identus.pollux.credentialdefinition.http
-import io.iohk.atala.api.http.*
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition.Input
-import io.iohk.atala.pollux.credentialdefinition.http.CredentialDefinitionResponse.annotations
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition.Input
+import org.hyperledger.identus.pollux.credentialdefinition.http.CredentialDefinitionResponse.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.description
import sttp.tapir.Schema.annotations.encodedExample
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/CredentialDefinitionResponse.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/CredentialDefinitionResponse.scala
similarity index 96%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/CredentialDefinitionResponse.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/CredentialDefinitionResponse.scala
index f9365df062..bb2c470672 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/CredentialDefinitionResponse.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/CredentialDefinitionResponse.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.credentialdefinition.http
+package org.hyperledger.identus.pollux.credentialdefinition.http
-import io.iohk.atala.api.http.*
-import io.iohk.atala.pollux.core.model
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition
-import io.iohk.atala.pollux.credentialdefinition.http.CredentialDefinitionResponse.annotations
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.pollux.core.model
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition
+import org.hyperledger.identus.pollux.credentialdefinition.http.CredentialDefinitionResponse.annotations
import sttp.model.Uri
import sttp.model.Uri.*
import sttp.tapir.Schema
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/CredentialDefinitionResponsePage.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/CredentialDefinitionResponsePage.scala
similarity index 94%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/CredentialDefinitionResponsePage.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/CredentialDefinitionResponsePage.scala
index cfa8017dc6..e1502c1213 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/CredentialDefinitionResponsePage.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/CredentialDefinitionResponsePage.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.credentialdefinition.http
+package org.hyperledger.identus.pollux.credentialdefinition.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.pollux.credentialschema.http.CredentialSchemaResponsePage.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.pollux.credentialschema.http.CredentialSchemaResponsePage.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.description
import sttp.tapir.Schema.annotations.encodedExample
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/FilterInput.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/FilterInput.scala
similarity index 85%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/FilterInput.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/FilterInput.scala
index b7a1cf5826..047817c6e4 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/FilterInput.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/FilterInput.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.credentialdefinition.http
+package org.hyperledger.identus.pollux.credentialdefinition.http
-import io.iohk.atala.api.http.*
-import io.iohk.atala.pollux.core.model
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition
-import io.iohk.atala.pollux.credentialdefinition.http.FilterInput.annotations
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.pollux.core.model
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition
+import org.hyperledger.identus.pollux.credentialdefinition.http.FilterInput.annotations
import sttp.tapir.EndpointIO.annotations.example
import sttp.tapir.EndpointIO.annotations.query
import sttp.tapir.Validator.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/Proof.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/Proof.scala
similarity index 95%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/Proof.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/Proof.scala
index 5ee4087eec..638842345f 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialdefinition/http/Proof.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialdefinition/http/Proof.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.credentialdefinition.http
+package org.hyperledger.identus.pollux.credentialdefinition.http
-import io.iohk.atala.api.http.*
-import io.iohk.atala.pollux.credentialdefinition.http.Proof.annotations
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.pollux.credentialdefinition.http.Proof.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.description
import sttp.tapir.Schema.annotations.encodedExample
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/SchemaRegistryEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/SchemaRegistryEndpoints.scala
similarity index 92%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/SchemaRegistryEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/SchemaRegistryEndpoints.scala
index b3fd988a93..3f2e42f3ea 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/SchemaRegistryEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/SchemaRegistryEndpoints.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.pollux.credentialschema
+package org.hyperledger.identus.pollux.credentialschema
-import io.iohk.atala.api.http.*
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.api.http.codec.OrderCodec.*
-import io.iohk.atala.api.http.model.{Order, PaginationInput}
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
-import io.iohk.atala.pollux.credentialschema.http.{
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.api.http.codec.OrderCodec.*
+import org.hyperledger.identus.api.http.model.{Order, PaginationInput}
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.pollux.credentialschema.http.{
CredentialSchemaInput,
CredentialSchemaResponse,
CredentialSchemaResponsePage,
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/SchemaRegistryServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/SchemaRegistryServerEndpoints.scala
similarity index 81%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/SchemaRegistryServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/SchemaRegistryServerEndpoints.scala
index daa1493d43..29e5518773 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/SchemaRegistryServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/SchemaRegistryServerEndpoints.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.pollux.credentialschema
+package org.hyperledger.identus.pollux.credentialschema
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.{Order, PaginationInput}
-import io.iohk.atala.iam.authentication.{Authenticator, Authorizer, DefaultAuthenticator, SecurityLogic}
-import io.iohk.atala.pollux.credentialschema.SchemaRegistryEndpoints.*
-import io.iohk.atala.pollux.credentialschema.controller.CredentialSchemaController
-import io.iohk.atala.pollux.credentialschema.http.{CredentialSchemaInput, FilterInput}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.{Order, PaginationInput}
+import org.hyperledger.identus.iam.authentication.{Authenticator, Authorizer, DefaultAuthenticator, SecurityLogic}
+import org.hyperledger.identus.pollux.credentialschema.SchemaRegistryEndpoints.*
+import org.hyperledger.identus.pollux.credentialschema.controller.CredentialSchemaController
+import org.hyperledger.identus.pollux.credentialschema.http.{CredentialSchemaInput, FilterInput}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/VerificationPolicyEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/VerificationPolicyEndpoints.scala
similarity index 89%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/VerificationPolicyEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/VerificationPolicyEndpoints.scala
index 82030b0cda..b84dd1b4d9 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/VerificationPolicyEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/VerificationPolicyEndpoints.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.pollux.credentialschema
+package org.hyperledger.identus.pollux.credentialschema
-import io.iohk.atala.api.http.*
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.api.http.codec.OrderCodec.*
-import io.iohk.atala.api.http.model.{Order, PaginationInput}
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
-import io.iohk.atala.pollux.credentialschema.http.*
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.api.http.codec.OrderCodec.*
+import org.hyperledger.identus.api.http.model.{Order, PaginationInput}
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.pollux.credentialschema.http.*
import sttp.apispec.Tag
import sttp.model.StatusCode
import sttp.tapir.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/VerificationPolicyServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/VerificationPolicyServerEndpoints.scala
similarity index 81%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/VerificationPolicyServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/VerificationPolicyServerEndpoints.scala
index 3f81b6a596..78c79da40d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/VerificationPolicyServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/VerificationPolicyServerEndpoints.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.pollux.credentialschema
+package org.hyperledger.identus.pollux.credentialschema
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.model.{Order, PaginationInput}
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.Authorizer
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.SecurityLogic
-import io.iohk.atala.pollux.credentialschema.VerificationPolicyEndpoints.*
-import io.iohk.atala.pollux.credentialschema.controller.VerificationPolicyController
-import io.iohk.atala.pollux.credentialschema.http.{VerificationPolicyResponse, VerificationPolicyInput}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.model.{Order, PaginationInput}
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.Authorizer
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.SecurityLogic
+import org.hyperledger.identus.pollux.credentialschema.VerificationPolicyEndpoints.*
+import org.hyperledger.identus.pollux.credentialschema.controller.VerificationPolicyController
+import org.hyperledger.identus.pollux.credentialschema.http.{VerificationPolicyResponse, VerificationPolicyInput}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import java.util.UUID
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/CredentialSchemaController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/CredentialSchemaController.scala
similarity index 82%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/CredentialSchemaController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/CredentialSchemaController.scala
index 5413779eee..303dbe1b4d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/CredentialSchemaController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/CredentialSchemaController.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.pollux.credentialschema.controller
+package org.hyperledger.identus.pollux.credentialschema.controller
-import io.iohk.atala.api.http.*
-import io.iohk.atala.api.http.model.{Order, Pagination}
-import io.iohk.atala.pollux.core.service.CredentialSchemaService
-import io.iohk.atala.pollux.core.service.CredentialSchemaService.Error.*
-import io.iohk.atala.pollux.credentialschema.http.{
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.api.http.model.{Order, Pagination}
+import org.hyperledger.identus.pollux.core.service.CredentialSchemaService
+import org.hyperledger.identus.pollux.core.service.CredentialSchemaService.Error.*
+import org.hyperledger.identus.pollux.credentialschema.http.{
CredentialSchemaInput,
CredentialSchemaResponse,
CredentialSchemaResponsePage,
FilterInput
}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.json.ast.Json
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/CredentialSchemaControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/CredentialSchemaControllerImpl.scala
similarity index 79%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/CredentialSchemaControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/CredentialSchemaControllerImpl.scala
index 6aef51728c..eff4eb100f 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/CredentialSchemaControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/CredentialSchemaControllerImpl.scala
@@ -1,23 +1,23 @@
-package io.iohk.atala.pollux.credentialschema.controller
+package org.hyperledger.identus.pollux.credentialschema.controller
-import io.iohk.atala.agent.walletapi.model.{ManagedDIDState, PublicationState}
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.api.http.*
-import io.iohk.atala.api.http.model.{CollectionStats, Order, Pagination}
-import io.iohk.atala.castor.core.model.did.{LongFormPrismDID, PrismDID}
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema.FilteredEntries
-import io.iohk.atala.pollux.core.service.CredentialSchemaService
-import io.iohk.atala.pollux.core.service.CredentialSchemaService.Error.*
-import io.iohk.atala.pollux.credentialschema.controller.CredentialSchemaController.domainToHttpErrorIO
-import io.iohk.atala.pollux.credentialschema.http.CredentialSchemaInput.toDomain
-import io.iohk.atala.pollux.credentialschema.http.CredentialSchemaResponse.fromDomain
-import io.iohk.atala.pollux.credentialschema.http.{
+import org.hyperledger.identus.agent.walletapi.model.{ManagedDIDState, PublicationState}
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.api.http.model.{CollectionStats, Order, Pagination}
+import org.hyperledger.identus.castor.core.model.did.{LongFormPrismDID, PrismDID}
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema.FilteredEntries
+import org.hyperledger.identus.pollux.core.service.CredentialSchemaService
+import org.hyperledger.identus.pollux.core.service.CredentialSchemaService.Error.*
+import org.hyperledger.identus.pollux.credentialschema.controller.CredentialSchemaController.domainToHttpErrorIO
+import org.hyperledger.identus.pollux.credentialschema.http.CredentialSchemaInput.toDomain
+import org.hyperledger.identus.pollux.credentialschema.http.CredentialSchemaResponse.fromDomain
+import org.hyperledger.identus.pollux.credentialschema.http.{
CredentialSchemaInput,
CredentialSchemaResponse,
CredentialSchemaResponsePage,
FilterInput
}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.json.ast.Json
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/CredentialSchemaControllerLogic.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/CredentialSchemaControllerLogic.scala
similarity index 75%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/CredentialSchemaControllerLogic.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/CredentialSchemaControllerLogic.scala
index f07bccd338..14ed20b287 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/CredentialSchemaControllerLogic.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/CredentialSchemaControllerLogic.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.credentialschema.controller
+package org.hyperledger.identus.pollux.credentialschema.controller
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.{CollectionStats, Pagination}
-import io.iohk.atala.pollux.credentialschema.http.CredentialSchemaResponsePage
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.{CollectionStats, Pagination}
+import org.hyperledger.identus.pollux.credentialschema.http.CredentialSchemaResponsePage
import sttp.model.Uri
-import io.iohk.atala.api.util.PaginationUtils
+import org.hyperledger.identus.api.util.PaginationUtils
case class CredentialSchemaControllerLogic(
ctx: RequestContext,
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/VerificationPolicyController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/VerificationPolicyController.scala
similarity index 76%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/VerificationPolicyController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/VerificationPolicyController.scala
index 1c5eb92b3c..43e2624805 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/VerificationPolicyController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/VerificationPolicyController.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.pollux.credentialschema.controller
+package org.hyperledger.identus.pollux.credentialschema.controller
-import io.iohk.atala.api.http.model.{Order, Pagination}
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.pollux.credentialschema.http.{
+import org.hyperledger.identus.api.http.model.{Order, Pagination}
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.pollux.credentialschema.http.{
VerificationPolicyResponse,
VerificationPolicyInput,
VerificationPolicyResponsePage
}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/VerificationPolicyControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/VerificationPolicyControllerImpl.scala
similarity index 84%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/VerificationPolicyControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/VerificationPolicyControllerImpl.scala
index 05723af890..ffade947f9 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/VerificationPolicyControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/VerificationPolicyControllerImpl.scala
@@ -1,19 +1,19 @@
-package io.iohk.atala.pollux.credentialschema.controller
+package org.hyperledger.identus.pollux.credentialschema.controller
-import io.iohk.atala.api.http.*
-import io.iohk.atala.api.http.model.{CollectionStats, Order, Pagination}
-import io.iohk.atala.pollux.core.model
-import io.iohk.atala.pollux.core.model.CredentialSchemaAndTrustedIssuersConstraint
-import io.iohk.atala.pollux.core.model.error.VerificationPolicyError
-import io.iohk.atala.pollux.core.model.error.VerificationPolicyError.*
-import io.iohk.atala.pollux.core.service.VerificationPolicyService
-import io.iohk.atala.pollux.credentialschema.http.VerificationPolicyResponse.*
-import io.iohk.atala.pollux.credentialschema.http.{
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.api.http.model.{CollectionStats, Order, Pagination}
+import org.hyperledger.identus.pollux.core.model
+import org.hyperledger.identus.pollux.core.model.CredentialSchemaAndTrustedIssuersConstraint
+import org.hyperledger.identus.pollux.core.model.error.VerificationPolicyError
+import org.hyperledger.identus.pollux.core.model.error.VerificationPolicyError.*
+import org.hyperledger.identus.pollux.core.service.VerificationPolicyService
+import org.hyperledger.identus.pollux.credentialschema.http.VerificationPolicyResponse.*
+import org.hyperledger.identus.pollux.credentialschema.http.{
VerificationPolicyResponse,
VerificationPolicyInput,
VerificationPolicyResponsePage
}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.ZIO.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/VerificationPolicyPageRequestLogic.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/VerificationPolicyPageRequestLogic.scala
similarity index 73%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/VerificationPolicyPageRequestLogic.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/VerificationPolicyPageRequestLogic.scala
index 7c142990df..2495879ec8 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/controller/VerificationPolicyPageRequestLogic.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/controller/VerificationPolicyPageRequestLogic.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.credentialschema.controller
+package org.hyperledger.identus.pollux.credentialschema.controller
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.{CollectionStats, Pagination}
-import io.iohk.atala.pollux.credentialschema.http.{VerificationPolicyResponse, VerificationPolicyResponsePage}
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.{CollectionStats, Pagination}
+import org.hyperledger.identus.pollux.credentialschema.http.{VerificationPolicyResponse, VerificationPolicyResponsePage}
import sttp.model.Uri
-import io.iohk.atala.api.util.PaginationUtils
+import org.hyperledger.identus.api.util.PaginationUtils
case class VerificationPolicyPageRequestLogic(
ctx: RequestContext,
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/CredentialSchemaInput.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/CredentialSchemaInput.scala
similarity index 86%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/CredentialSchemaInput.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/CredentialSchemaInput.scala
index 70f94fc7ad..e54257f9db 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/CredentialSchemaInput.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/CredentialSchemaInput.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.credentialschema.http
+package org.hyperledger.identus.pollux.credentialschema.http
-import io.iohk.atala.api.http.*
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema.Input
-import io.iohk.atala.pollux.credentialschema.http.CredentialSchemaResponse.annotations
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema.Input
+import org.hyperledger.identus.pollux.credentialschema.http.CredentialSchemaResponse.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample, validate, validateEach}
import sttp.tapir.Validator.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/CredentialSchemaResponse.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/CredentialSchemaResponse.scala
similarity index 96%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/CredentialSchemaResponse.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/CredentialSchemaResponse.scala
index dfcad7c714..ee53873913 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/CredentialSchemaResponse.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/CredentialSchemaResponse.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.credentialschema.http
+package org.hyperledger.identus.pollux.credentialschema.http
-import io.iohk.atala.api.http.*
-import io.iohk.atala.pollux.core.model
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema
-import io.iohk.atala.pollux.credentialschema.http.CredentialSchemaResponse.annotations
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.pollux.core.model
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema
+import org.hyperledger.identus.pollux.credentialschema.http.CredentialSchemaResponse.annotations
import sttp.model.Uri
import sttp.model.Uri.*
import sttp.tapir.Schema
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/CredentialSchemaResponsePage.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/CredentialSchemaResponsePage.scala
similarity index 94%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/CredentialSchemaResponsePage.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/CredentialSchemaResponsePage.scala
index 310dac52d5..f54d7e8106 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/CredentialSchemaResponsePage.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/CredentialSchemaResponsePage.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.credentialschema.http
+package org.hyperledger.identus.pollux.credentialschema.http
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
-import io.iohk.atala.pollux.credentialschema.http.CredentialSchemaResponsePage.annotations
-import io.iohk.atala.api.http.Annotation
+import org.hyperledger.identus.pollux.credentialschema.http.CredentialSchemaResponsePage.annotations
+import org.hyperledger.identus.api.http.Annotation
case class CredentialSchemaResponsePage(
@description(annotations.contents.description)
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/FilterInput.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/FilterInput.scala
similarity index 85%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/FilterInput.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/FilterInput.scala
index c85b366863..46f539b53c 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/FilterInput.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/FilterInput.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.credentialschema.http
+package org.hyperledger.identus.pollux.credentialschema.http
-import io.iohk.atala.api.http.*
-import io.iohk.atala.pollux.core.model
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema
-import io.iohk.atala.pollux.credentialschema.http.FilterInput.annotations
+import org.hyperledger.identus.api.http.*
+import org.hyperledger.identus.pollux.core.model
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema
+import org.hyperledger.identus.pollux.credentialschema.http.FilterInput.annotations
import sttp.tapir.EndpointIO.annotations.example
import sttp.tapir.EndpointIO.annotations.query
import sttp.tapir.Validator.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/Proof.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/Proof.scala
similarity index 95%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/Proof.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/Proof.scala
index 435281112c..602fbb70df 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/Proof.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/Proof.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.credentialschema.http
+package org.hyperledger.identus.pollux.credentialschema.http
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import sttp.tapir.generic.auto.*
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
-import io.iohk.atala.pollux.credentialschema.http.Proof.annotations
-import io.iohk.atala.api.http.*
+import org.hyperledger.identus.pollux.credentialschema.http.Proof.annotations
+import org.hyperledger.identus.api.http.*
import java.time.OffsetDateTime
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/VerificationPolicyResponse.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/VerificationPolicyResponse.scala
similarity index 97%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/VerificationPolicyResponse.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/VerificationPolicyResponse.scala
index 543ed83e59..df234f3098 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/pollux/credentialschema/http/VerificationPolicyResponse.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/pollux/credentialschema/http/VerificationPolicyResponse.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.credentialschema.http
+package org.hyperledger.identus.pollux.credentialschema.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.pollux.core.model
-import io.iohk.atala.pollux.core.model.CredentialSchemaAndTrustedIssuersConstraint
-import io.iohk.atala.pollux.credentialschema.http
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.pollux.core.model
+import org.hyperledger.identus.pollux.core.model.CredentialSchemaAndTrustedIssuersConstraint
+import org.hyperledger.identus.pollux.credentialschema.http
import sttp.model.Uri
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample, encodedName, validate}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofController.scala
similarity index 87%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofController.scala
index 12b4c74c09..f1c6dfcf23 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofController.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.presentproof.controller
+package org.hyperledger.identus.presentproof.controller
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.pollux.core.model.error.PresentationError
-import io.iohk.atala.presentproof.controller.http.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.pollux.core.model.error.PresentationError
+import org.hyperledger.identus.presentproof.controller.http.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.ZIO
import java.util.UUID
@@ -86,8 +86,8 @@ object PresentProofController {
detail = Some(s"The Credential format '$format' is not Unsupported")
)
- def toDidCommID(str: String): ZIO[Any, ErrorResponse, io.iohk.atala.pollux.core.model.DidCommID] =
+ def toDidCommID(str: String): ZIO[Any, ErrorResponse, org.hyperledger.identus.pollux.core.model.DidCommID] =
ZIO
- .fromTry(Try(io.iohk.atala.pollux.core.model.DidCommID(str)))
+ .fromTry(Try(org.hyperledger.identus.pollux.core.model.DidCommID(str)))
.mapError(e => ErrorResponse.badRequest(s"Error parsing string as DidCommID: ${e.getMessage}"))
}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofControllerImpl.scala
similarity index 84%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofControllerImpl.scala
index dde895e22a..2992d35ca1 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofControllerImpl.scala
@@ -1,19 +1,19 @@
-package io.iohk.atala.presentproof.controller
+package org.hyperledger.identus.presentproof.controller
-import io.iohk.atala.agent.server.ControllerHelper
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.service.ConnectionService
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.presentproof.ProofType
-import io.iohk.atala.pollux.core.model.error.PresentationError
-import io.iohk.atala.pollux.core.model.presentation.Options
-import io.iohk.atala.pollux.core.model.{CredentialFormat, DidCommID, PresentationRecord}
-import io.iohk.atala.pollux.core.service.PresentationService
-import io.iohk.atala.presentproof.controller.PresentProofController.toDidCommID
-import io.iohk.atala.presentproof.controller.http.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.server.ControllerHelper
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.service.ConnectionService
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.presentproof.ProofType
+import org.hyperledger.identus.pollux.core.model.error.PresentationError
+import org.hyperledger.identus.pollux.core.model.presentation.Options
+import org.hyperledger.identus.pollux.core.model.{CredentialFormat, DidCommID, PresentationRecord}
+import org.hyperledger.identus.pollux.core.service.PresentationService
+import org.hyperledger.identus.presentproof.controller.PresentProofController.toDidCommID
+import org.hyperledger.identus.presentproof.controller.http.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{URLayer, ZIO, ZLayer}
import java.util.UUID
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofEndpoints.scala
similarity index 86%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofEndpoints.scala
index 03a98d29ef..aa61c68ff4 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofEndpoints.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.presentproof.controller
+package org.hyperledger.identus.presentproof.controller
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
-import io.iohk.atala.presentproof.controller.http.*
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.presentproof.controller.http.*
import sttp.model.StatusCode
import sttp.tapir.*
import sttp.tapir.json.zio.jsonBody
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofServerEndpoints.scala
similarity index 78%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofServerEndpoints.scala
index e566fbd742..903ed8e22d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/PresentProofServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/PresentProofServerEndpoints.scala
@@ -1,21 +1,21 @@
-package io.iohk.atala.presentproof.controller
+package org.hyperledger.identus.presentproof.controller
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.api.http.model.PaginationInput
-import io.iohk.atala.iam.authentication.Authenticator
-import io.iohk.atala.iam.authentication.Authorizer
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.authentication.SecurityLogic
-import io.iohk.atala.presentproof.controller.PresentProofEndpoints.{
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.api.http.model.PaginationInput
+import org.hyperledger.identus.iam.authentication.Authenticator
+import org.hyperledger.identus.iam.authentication.Authorizer
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.authentication.SecurityLogic
+import org.hyperledger.identus.presentproof.controller.PresentProofEndpoints.{
getAllPresentations,
getPresentation,
requestPresentation,
updatePresentation
}
-import io.iohk.atala.presentproof.controller.http.{RequestPresentationAction, RequestPresentationInput}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.presentproof.controller.http.{RequestPresentationAction, RequestPresentationInput}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/Options.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/Options.scala
similarity index 86%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/Options.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/Options.scala
index 7f55dc8580..3f49c8349d 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/Options.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/Options.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.presentproof.controller.http
+package org.hyperledger.identus.presentproof.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.presentproof.controller.http.Options.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.presentproof.controller.http.Options.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/PresentationStatus.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/PresentationStatus.scala
similarity index 93%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/PresentationStatus.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/PresentationStatus.scala
index 58b006c4d3..597348aef7 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/PresentationStatus.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/PresentationStatus.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.presentproof.controller.http
+package org.hyperledger.identus.presentproof.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.mercury.model.Base64
-import io.iohk.atala.pollux.core.model.PresentationRecord
-import io.iohk.atala.presentproof.controller.http.PresentationStatus.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.mercury.model.Base64
+import org.hyperledger.identus.pollux.core.model.PresentationRecord
+import org.hyperledger.identus.presentproof.controller.http.PresentationStatus.annotations
import sttp.tapir.Schema.annotations.{description, encodedExample, validate}
import sttp.tapir.{Schema, Validator}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/PresentationStatusPage.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/PresentationStatusPage.scala
similarity index 91%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/PresentationStatusPage.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/PresentationStatusPage.scala
index 1dc5be057a..7fa6593c6a 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/PresentationStatusPage.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/PresentationStatusPage.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.presentproof.controller.http
+package org.hyperledger.identus.presentproof.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.presentproof.controller.http.PresentationStatusPage.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.presentproof.controller.http.PresentationStatusPage.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/ProofRequestAux.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/ProofRequestAux.scala
similarity index 86%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/ProofRequestAux.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/ProofRequestAux.scala
index f134b37268..3d48eca4f9 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/ProofRequestAux.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/ProofRequestAux.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.presentproof.controller.http
+package org.hyperledger.identus.presentproof.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.presentproof.controller.http.ProofRequestAux.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.presentproof.controller.http.ProofRequestAux.annotations
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/RequestPresentationAction.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/RequestPresentationAction.scala
similarity index 90%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/RequestPresentationAction.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/RequestPresentationAction.scala
index 114b08893a..d104cce7a0 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/RequestPresentationAction.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/RequestPresentationAction.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.presentproof.controller.http
+package org.hyperledger.identus.presentproof.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.pollux.core.service.serdes.*
-import io.iohk.atala.presentproof.controller.http.RequestPresentationAction.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.pollux.core.service.serdes.*
+import org.hyperledger.identus.presentproof.controller.http.RequestPresentationAction.annotations
import sttp.tapir.Schema.annotations.{description, encodedExample, validate}
import sttp.tapir.{Schema, Validator}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/RequestPresentationInput.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/RequestPresentationInput.scala
similarity index 94%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/RequestPresentationInput.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/RequestPresentationInput.scala
index 9f3c677fa8..239925f999 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/presentproof/controller/http/RequestPresentationInput.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/presentproof/controller/http/RequestPresentationInput.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.presentproof.controller.http
+package org.hyperledger.identus.presentproof.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.pollux.core.service.serdes.*
-import io.iohk.atala.presentproof.controller.http.RequestPresentationInput.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.pollux.core.service.serdes.*
+import org.hyperledger.identus.presentproof.controller.http.RequestPresentationInput.annotations
import sttp.tapir.Schema.annotations.{description, encodedExample}
import sttp.tapir.{Schema, Validator}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemController.scala
similarity index 50%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemController.scala
index 1821eabf4e..21bf841708 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemController.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.system.controller
+package org.hyperledger.identus.system.controller
import zio.*
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.system.controller.http.HealthInfo
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.system.controller.http.HealthInfo
trait SystemController {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemControllerImpl.scala
similarity index 70%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemControllerImpl.scala
index 15c2bcb0d5..7ad16c53a3 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemControllerImpl.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.system.controller
+package org.hyperledger.identus.system.controller
-import io.iohk.atala.agent.server.buildinfo.BuildInfo
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.system.controller.http.HealthInfo
+import org.hyperledger.identus.agent.server.buildinfo.BuildInfo
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.system.controller.http.HealthInfo
import io.micrometer.prometheus.PrometheusMeterRegistry
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemEndpoints.scala
similarity index 88%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemEndpoints.scala
index d0da17fbf8..73cf6a6c85 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemEndpoints.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.system.controller
+package org.hyperledger.identus.system.controller
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.system.controller.http.HealthInfo
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.system.controller.http.HealthInfo
import sttp.apispec.Tag
import sttp.tapir.ztapir.stringBody
import sttp.tapir.json.zio.jsonBody
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemServerEndpoints.scala
similarity index 80%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemServerEndpoints.scala
index 738e31946e..6b693a9553 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/SystemServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/SystemServerEndpoints.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.system.controller
+package org.hyperledger.identus.system.controller
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.system.controller.SystemEndpoints.*
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.system.controller.SystemEndpoints.*
import sttp.tapir.ztapir.*
import zio.{URIO, ZIO}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/http/HealthInfo.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/http/HealthInfo.scala
similarity index 83%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/http/HealthInfo.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/http/HealthInfo.scala
index ffb9fa9e35..f5eec8783a 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/system/controller/http/HealthInfo.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/system/controller/http/HealthInfo.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.system.controller.http
+package org.hyperledger.identus.system.controller.http
-import io.iohk.atala.api.http.Annotation
-import io.iohk.atala.system.controller.http.HealthInfo.annotations
+import org.hyperledger.identus.api.http.Annotation
+import org.hyperledger.identus.system.controller.http.HealthInfo.annotations
import sttp.tapir.Schema.annotations.{description, encodedExample}
import sttp.tapir.Schema
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationController.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationController.scala
similarity index 64%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationController.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationController.scala
index b08e735a77..c9bad74bd3 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationController.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationController.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.verification.controller
+package org.hyperledger.identus.verification.controller
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.pollux.core.service.verification.VcVerificationServiceError
-import io.iohk.atala.verification.controller
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.pollux.core.service.verification.VcVerificationServiceError
+import org.hyperledger.identus.verification.controller
import zio.*
trait VcVerificationController {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationControllerImpl.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImpl.scala
similarity index 79%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationControllerImpl.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImpl.scala
index 200cb4e421..d1df630242 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationControllerImpl.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImpl.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.verification.controller
+package org.hyperledger.identus.verification.controller
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.pollux.core.service.verification.VcVerificationService
-import io.iohk.atala.verification.controller
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.pollux.core.service.verification.VcVerificationService
+import org.hyperledger.identus.verification.controller
import zio.*
class VcVerificationControllerImpl(vcVerificationService: VcVerificationService) extends VcVerificationController {
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationEndpoints.scala
similarity index 65%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationEndpoints.scala
index f81c951fec..e32d445485 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationEndpoints.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.verification.controller
+package org.hyperledger.identus.verification.controller
-import io.iohk.atala.api.http.EndpointOutputs.*
-import io.iohk.atala.api.http.{ErrorResponse, RequestContext}
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
-import io.iohk.atala.iam.authentication.oidc.JwtCredentials
-import io.iohk.atala.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
+import org.hyperledger.identus.api.http.EndpointOutputs.*
+import org.hyperledger.identus.api.http.{ErrorResponse, RequestContext}
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyEndpointSecurityLogic.apiKeyHeader
+import org.hyperledger.identus.iam.authentication.oidc.JwtCredentials
+import org.hyperledger.identus.iam.authentication.oidc.JwtSecurityLogic.jwtAuthHeader
import sttp.model.StatusCode
import sttp.tapir.*
import sttp.tapir.json.zio.jsonBody
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationServerEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationServerEndpoints.scala
similarity index 70%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationServerEndpoints.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationServerEndpoints.scala
index 2cc01ce215..7f3a114f9e 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/VcVerificationServerEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationServerEndpoints.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.verification.controller
+package org.hyperledger.identus.verification.controller
-import io.iohk.atala.LogUtils.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.RequestContext
-import io.iohk.atala.iam.authentication.{Authenticator, Authorizer, DefaultAuthenticator, SecurityLogic}
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.verification.controller
-import io.iohk.atala.verification.controller.VcVerificationEndpoints.verify
+import org.hyperledger.identus.LogUtils.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.RequestContext
+import org.hyperledger.identus.iam.authentication.{Authenticator, Authorizer, DefaultAuthenticator, SecurityLogic}
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.verification.controller
+import org.hyperledger.identus.verification.controller.VcVerificationEndpoints.verify
import sttp.tapir.ztapir.*
import zio.*
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/ParameterizableVcVerification.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/ParameterizableVcVerification.scala
similarity index 90%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/ParameterizableVcVerification.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/ParameterizableVcVerification.scala
index 8994cedf77..7200824ec0 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/ParameterizableVcVerification.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/ParameterizableVcVerification.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.verification.controller.http
+package org.hyperledger.identus.verification.controller.http
import sttp.tapir.Schema
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerification.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerification.scala
similarity index 92%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerification.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerification.scala
index 345e582714..159d86cf62 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerification.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerification.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.verification.controller.http
+package org.hyperledger.identus.verification.controller.http
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.pollux.core.service
-import io.iohk.atala.pollux.core.service.verification.VcVerification as ServiceVcVerification
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.pollux.core.service
+import org.hyperledger.identus.pollux.core.service.verification.VcVerification as ServiceVcVerification
import sttp.tapir.Schema
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
import zio.{IO, *}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationParameter.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationParameter.scala
similarity index 95%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationParameter.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationParameter.scala
index 66ca951fcb..4821fa3ba8 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationParameter.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationParameter.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.verification.controller.http
+package org.hyperledger.identus.verification.controller.http
import sttp.tapir.Schema
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationRequest.scala
similarity index 91%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationRequest.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationRequest.scala
index dd7602b3d0..2fbbfa57ec 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationRequest.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.verification.controller.http
+package org.hyperledger.identus.verification.controller.http
-import io.iohk.atala.api.http.{Annotation, ErrorResponse}
-import io.iohk.atala.pollux.core.service.verification.VcVerificationRequest as ServiceVcVerificationRequest
+import org.hyperledger.identus.api.http.{Annotation, ErrorResponse}
+import org.hyperledger.identus.pollux.core.service.verification.VcVerificationRequest as ServiceVcVerificationRequest
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResponse.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResponse.scala
similarity index 97%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResponse.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResponse.scala
index 70e4ee35bc..99b25d7170 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResponse.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResponse.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.verification.controller.http
+package org.hyperledger.identus.verification.controller.http
-import io.iohk.atala.api.http.Annotation
+import org.hyperledger.identus.api.http.Annotation
import sttp.tapir.Schema
import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResult.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResult.scala
similarity index 80%
rename from prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResult.scala
rename to cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResult.scala
index 99158682da..3eab310e22 100644
--- a/prism-agent/service/server/src/main/scala/io/iohk/atala/verification/controller/http/VcVerificationResult.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResult.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.verification.controller.http
+package org.hyperledger.identus.verification.controller.http
-import io.iohk.atala.pollux.core.service.verification.VcVerificationResult as ServiceVcVerificationResult
+import org.hyperledger.identus.pollux.core.service.verification.VcVerificationResult as ServiceVcVerificationResult
import sttp.tapir.Schema
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
diff --git a/prism-agent/service/server/src/test/resources/anoncred-schema-example.json b/cloud-agent/service/server/src/test/resources/anoncred-schema-example.json
similarity index 100%
rename from prism-agent/service/server/src/test/resources/anoncred-schema-example.json
rename to cloud-agent/service/server/src/test/resources/anoncred-schema-example.json
diff --git a/prism-agent/service/server/src/test/resources/logback.xml b/cloud-agent/service/server/src/test/resources/logback.xml
similarity index 100%
rename from prism-agent/service/server/src/test/resources/logback.xml
rename to cloud-agent/service/server/src/test/resources/logback.xml
diff --git a/pollux/lib/core/src/test/resources/vc-schema-example.json b/cloud-agent/service/server/src/test/resources/vc-schema-example.json
similarity index 100%
rename from pollux/lib/core/src/test/resources/vc-schema-example.json
rename to cloud-agent/service/server/src/test/resources/vc-schema-example.json
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/ZioHttpTest.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/ZioHttpTest.scala
similarity index 98%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/ZioHttpTest.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/ZioHttpTest.scala
index c218bb0243..eb28c2cba9 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/ZioHttpTest.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/ZioHttpTest.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala
+package org.hyperledger.identus
import zio.*
import zio.http.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/AgentInitializationSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/agent/server/AgentInitializationSpec.scala
similarity index 81%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/AgentInitializationSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/agent/server/AgentInitializationSpec.scala
index c43fc1f3e1..028bca98cf 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/AgentInitializationSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/agent/server/AgentInitializationSpec.scala
@@ -1,23 +1,23 @@
-package io.iohk.atala.agent.server
+package org.hyperledger.identus.agent.server
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.server.config.SecretStorageBackend
-import io.iohk.atala.agent.walletapi.service.EntityServiceImpl
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceImpl
-import io.iohk.atala.agent.walletapi.sql.JdbcEntityRepository
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletSecretStorage
-import io.iohk.atala.agent.walletapi.storage.WalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.iam.authentication.apikey.ApiKeyAuthenticatorImpl
-import io.iohk.atala.iam.authentication.apikey.JdbcAuthenticationRepository
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.DBTestUtils
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.config.SecretStorageBackend
+import org.hyperledger.identus.agent.walletapi.service.EntityServiceImpl
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementService
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementServiceImpl
+import org.hyperledger.identus.agent.walletapi.sql.JdbcEntityRepository
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.WalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyAuthenticatorImpl
+import org.hyperledger.identus.iam.authentication.apikey.JdbcAuthenticationRepository
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.DBTestUtils
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/config/AppConfigSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/agent/server/config/AppConfigSpec.scala
similarity index 98%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/config/AppConfigSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/agent/server/config/AppConfigSpec.scala
index f5c4dde185..e967551ed5 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/agent/server/config/AppConfigSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/agent/server/config/AppConfigSpec.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.server.config
+package org.hyperledger.identus.agent.server.config
-import io.iohk.atala.agent.server.SystemModule
+import org.hyperledger.identus.agent.server.SystemModule
import monocle.syntax.all.*
import zio.*
import zio.test.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/PaginationUtilsSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/api/util/PaginationUtilsSpec.scala
similarity index 94%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/PaginationUtilsSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/api/util/PaginationUtilsSpec.scala
index 54f4ef22f9..b81b64696f 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/PaginationUtilsSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/api/util/PaginationUtilsSpec.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.api.util
+package org.hyperledger.identus.api.util
import zio.*
import zio.test.*
import zio.test.Assertion.*
import sttp.model.Uri
-import io.iohk.atala.api.http.model.CollectionStats
-import io.iohk.atala.api.http.model.Pagination
+import org.hyperledger.identus.api.http.model.CollectionStats
+import org.hyperledger.identus.api.http.model.Pagination
object PaginationUtilsSpec extends ZIOSpecDefault {
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/Tapir2StaticOAS.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/api/util/Tapir2StaticOAS.scala
similarity index 60%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/Tapir2StaticOAS.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/api/util/Tapir2StaticOAS.scala
index 68b510f62e..3506f95cae 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/api/util/Tapir2StaticOAS.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/api/util/Tapir2StaticOAS.scala
@@ -1,20 +1,23 @@
-package io.iohk.atala.api.util
+package org.hyperledger.identus.api.util
-import io.iohk.atala.agent.server.AgentHttpServer
-import io.iohk.atala.agent.server.http.DocModels
-import io.iohk.atala.castor.controller.{DIDController, DIDRegistrarController}
-import io.iohk.atala.connect.controller.ConnectionController
-import io.iohk.atala.credentialstatus.controller.CredentialStatusController
-import io.iohk.atala.event.controller.EventController
-import io.iohk.atala.iam.authentication.DefaultAuthenticator
-import io.iohk.atala.iam.entity.http.controller.EntityController
-import io.iohk.atala.iam.wallet.http.controller.WalletManagementController
-import io.iohk.atala.issue.controller.IssueController
-import io.iohk.atala.pollux.credentialdefinition.controller.CredentialDefinitionController
-import io.iohk.atala.pollux.credentialschema.controller.{CredentialSchemaController, VerificationPolicyController}
-import io.iohk.atala.presentproof.controller.PresentProofController
-import io.iohk.atala.system.controller.SystemController
-import io.iohk.atala.verification.controller.VcVerificationController
+import org.hyperledger.identus.agent.server.AgentHttpServer
+import org.hyperledger.identus.agent.server.http.DocModels
+import org.hyperledger.identus.castor.controller.{DIDController, DIDRegistrarController}
+import org.hyperledger.identus.connect.controller.ConnectionController
+import org.hyperledger.identus.credential.status.controller.CredentialStatusController
+import org.hyperledger.identus.event.controller.EventController
+import org.hyperledger.identus.iam.authentication.DefaultAuthenticator
+import org.hyperledger.identus.iam.entity.http.controller.EntityController
+import org.hyperledger.identus.iam.wallet.http.controller.WalletManagementController
+import org.hyperledger.identus.issue.controller.IssueController
+import org.hyperledger.identus.pollux.credentialdefinition.controller.CredentialDefinitionController
+import org.hyperledger.identus.pollux.credentialschema.controller.{
+ CredentialSchemaController,
+ VerificationPolicyController
+}
+import org.hyperledger.identus.presentproof.controller.PresentProofController
+import org.hyperledger.identus.system.controller.SystemController
+import org.hyperledger.identus.verification.controller.VcVerificationController
import org.scalatestplus.mockito.MockitoSugar.*
import sttp.tapir.docs.openapi.OpenAPIDocsInterpreter
import zio.{Scope, ZIO, ZIOAppArgs, ZIOAppDefault, ZLayer}
diff --git a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container/MigrationAspect.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/container/util/MigrationAspect.scala
similarity index 96%
rename from pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container/MigrationAspect.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/container/util/MigrationAspect.scala
index b12338d17f..fe5bf1cbc7 100644
--- a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container/MigrationAspect.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/container/util/MigrationAspect.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.test.container
+package org.hyperledger.identus.container.util
import com.dimafeng.testcontainers.PostgreSQLContainer
import org.flywaydb.core.Flyway
import zio.ZIO
-import zio.test.{TestAspect, TestAspectAtLeastR}
import zio.test.TestAspect.{beforeAll, before}
+import zio.test.{TestAspect, TestAspectAtLeastR}
object MigrationAspects {
def migrate(schema: String, paths: String*): TestAspectAtLeastR[PostgreSQLContainer] = {
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/SecurityLogicSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/SecurityLogicSpec.scala
similarity index 94%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/SecurityLogicSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/SecurityLogicSpec.scala
index e5bfbcfabb..3437e896a9 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/SecurityLogicSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/SecurityLogicSpec.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.iam.authentication
+package org.hyperledger.identus.iam.authentication
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.EntityRole
-import io.iohk.atala.iam.authentication.AuthenticationError.InvalidCredentials
-import io.iohk.atala.iam.authentication.apikey.ApiKeyCredentials
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.EntityRole
+import org.hyperledger.identus.iam.authentication.AuthenticationError.InvalidCredentials
+import org.hyperledger.identus.iam.authentication.apikey.ApiKeyCredentials
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyAuthenticatorSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyAuthenticatorSpec.scala
similarity index 90%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyAuthenticatorSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyAuthenticatorSpec.scala
index 23aa3096e7..2ee8d718c7 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/apikey/ApiKeyAuthenticatorSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/apikey/ApiKeyAuthenticatorSpec.scala
@@ -1,21 +1,25 @@
-package io.iohk.atala.iam.authentication.apikey
+package org.hyperledger.identus.iam.authentication.apikey
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.agent.walletapi.model.{Entity, Wallet}
-import io.iohk.atala.agent.walletapi.service.{
+import org.hyperledger.identus.agent.walletapi.model.{Entity, Wallet}
+import org.hyperledger.identus.agent.walletapi.service.{
EntityService,
EntityServiceImpl,
WalletManagementService,
WalletManagementServiceImpl
}
-import io.iohk.atala.agent.walletapi.sql.{JdbcEntityRepository, JdbcWalletNonSecretStorage, JdbcWalletSecretStorage}
-import io.iohk.atala.container.util.MigrationAspects.*
-import io.iohk.atala.iam.authentication.AuthenticationError
-import io.iohk.atala.iam.authentication.AuthenticationError.InvalidCredentials
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.agent.walletapi.sql.{
+ JdbcEntityRepository,
+ JdbcWalletNonSecretStorage,
+ JdbcWalletSecretStorage
+}
+import org.hyperledger.identus.container.util.MigrationAspects.*
+import org.hyperledger.identus.iam.authentication.AuthenticationError
+import org.hyperledger.identus.iam.authentication.AuthenticationError.InvalidCredentials
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
import zio.Runtime.removeDefaultLoggers
import zio.test.Assertion.*
import zio.test.TestAspect.sequential
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/apikey/JdbcAuthenticationRepositorySpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/apikey/JdbcAuthenticationRepositorySpec.scala
similarity index 93%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/apikey/JdbcAuthenticationRepositorySpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/apikey/JdbcAuthenticationRepositorySpec.scala
index b5e2f0626b..18d14280f8 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/apikey/JdbcAuthenticationRepositorySpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/apikey/JdbcAuthenticationRepositorySpec.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.iam.authentication.apikey
+package org.hyperledger.identus.iam.authentication.apikey
-import io.iohk.atala.container.util.MigrationAspects.migrate
-import io.iohk.atala.iam.authentication.apikey.AuthenticationMethodType.ApiKey
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.container.util.MigrationAspects.migrate
+import org.hyperledger.identus.iam.authentication.apikey.AuthenticationMethodType.ApiKey
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
import zio.Runtime.removeDefaultLoggers
import zio.ZIO
import zio.test.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/oidc/KeycloakAuthenticatorSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakAuthenticatorSpec.scala
similarity index 91%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/oidc/KeycloakAuthenticatorSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakAuthenticatorSpec.scala
index 24a7f1b6c7..5ccde5e29d 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authentication/oidc/KeycloakAuthenticatorSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authentication/oidc/KeycloakAuthenticatorSpec.scala
@@ -1,21 +1,21 @@
-package io.iohk.atala.iam.authentication.oidc
+package org.hyperledger.identus.iam.authentication.oidc
-import io.iohk.atala.agent.walletapi.model.EntityRole
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceImpl
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletSecretStorage
-import io.iohk.atala.iam.authentication.AuthenticationError
-import io.iohk.atala.iam.authorization.keycloak.admin.KeycloakPermissionManagementService
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
-import io.iohk.atala.sharedtest.containers.KeycloakAdminClient
-import io.iohk.atala.sharedtest.containers.KeycloakContainerCustom
-import io.iohk.atala.sharedtest.containers.KeycloakTestContainerSupport
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.DBTestUtils
+import org.hyperledger.identus.agent.walletapi.model.EntityRole
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementService
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementServiceImpl
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletSecretStorage
+import org.hyperledger.identus.iam.authentication.AuthenticationError
+import org.hyperledger.identus.iam.authorization.keycloak.admin.KeycloakPermissionManagementService
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
+import org.hyperledger.identus.sharedtest.containers.KeycloakAdminClient
+import org.hyperledger.identus.sharedtest.containers.KeycloakContainerCustom
+import org.hyperledger.identus.sharedtest.containers.KeycloakTestContainerSupport
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.DBTestUtils
import org.keycloak.authorization.client.AuthzClient
import org.keycloak.representations.idm.authorization.ResourceRepresentation
import org.keycloak.representations.idm.authorization.UmaPermissionRepresentation
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/core/EntityPermissionManagementSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/core/EntityPermissionManagementSpec.scala
similarity index 79%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/core/EntityPermissionManagementSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/core/EntityPermissionManagementSpec.scala
index 0fa7d18ab7..46fc963ca3 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/core/EntityPermissionManagementSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/core/EntityPermissionManagementSpec.scala
@@ -1,21 +1,21 @@
-package io.iohk.atala.iam.authorization.core
+package org.hyperledger.identus.iam.authorization.core
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.service.EntityService
-import io.iohk.atala.agent.walletapi.service.EntityServiceImpl
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceImpl
-import io.iohk.atala.agent.walletapi.sql.JdbcEntityRepository
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletSecretStorage
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error.ServiceError
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error.WalletNotFoundById
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.DBTestUtils
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.service.EntityService
+import org.hyperledger.identus.agent.walletapi.service.EntityServiceImpl
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementService
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementServiceImpl
+import org.hyperledger.identus.agent.walletapi.sql.JdbcEntityRepository
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletSecretStorage
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error.ServiceError
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error.WalletNotFoundById
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.DBTestUtils
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakAdmin.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakAdmin.scala
similarity index 95%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakAdmin.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakAdmin.scala
index 60abc23456..bbab0c3545 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakAdmin.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakAdmin.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.iam.authorization.keycloak.admin
+package org.hyperledger.identus.iam.authorization.keycloak.admin
import org.keycloak.admin.client.Keycloak
import zio.{RLayer, Task, ZIO, ZLayer}
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakAdminSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakAdminSpec.scala
similarity index 83%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakAdminSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakAdminSpec.scala
index 2f98cb9ef4..ed92b74522 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakAdminSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakAdminSpec.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.iam.authorization.keycloak.admin
+package org.hyperledger.identus.iam.authorization.keycloak.admin
-import io.iohk.atala.sharedtest.containers.{KeycloakContainerCustom, KeycloakTestContainerSupport}
+import org.hyperledger.identus.sharedtest.containers.{KeycloakContainerCustom, KeycloakTestContainerSupport}
import zio.*
import zio.ZIO.*
import zio.test.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakConfigUtils.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakConfigUtils.scala
similarity index 85%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakConfigUtils.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakConfigUtils.scala
index 5ee11525cb..a64f067240 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakConfigUtils.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakConfigUtils.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.iam.authorization.keycloak.admin
+package org.hyperledger.identus.iam.authorization.keycloak.admin
-import io.iohk.atala.iam.authentication.oidc.KeycloakConfig
-import io.iohk.atala.sharedtest.containers.{KeycloakContainerCustom, KeycloakTestContainerSupport}
+import org.hyperledger.identus.iam.authentication.oidc.KeycloakConfig
+import org.hyperledger.identus.sharedtest.containers.{KeycloakContainerCustom, KeycloakTestContainerSupport}
import zio.*
import zio.ZIO.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakPermissionManagementServiceSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakPermissionManagementServiceSpec.scala
similarity index 88%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakPermissionManagementServiceSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakPermissionManagementServiceSpec.scala
index 65fd8084d3..cd8e01ba95 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/iam/authorization/keycloak/admin/KeycloakPermissionManagementServiceSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/iam/authorization/keycloak/admin/KeycloakPermissionManagementServiceSpec.scala
@@ -1,27 +1,27 @@
-package io.iohk.atala.iam.authorization.keycloak.admin
-
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceImpl
-import io.iohk.atala.agent.walletapi.service.{WalletManagementService, WalletManagementServiceError}
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletSecretStorage
-import io.iohk.atala.iam.authentication.AuthenticationError.ResourceNotPermitted
-import io.iohk.atala.iam.authentication.oidc.{
+package org.hyperledger.identus.iam.authorization.keycloak.admin
+
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementServiceImpl
+import org.hyperledger.identus.agent.walletapi.service.{WalletManagementService, WalletManagementServiceError}
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletSecretStorage
+import org.hyperledger.identus.iam.authentication.AuthenticationError.ResourceNotPermitted
+import org.hyperledger.identus.iam.authentication.oidc.{
KeycloakAuthenticator,
KeycloakAuthenticatorImpl,
KeycloakClient,
KeycloakClientImpl,
KeycloakEntity
}
-import io.iohk.atala.iam.authorization.core.PermissionManagement
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error.UnexpectedError
-import io.iohk.atala.iam.authorization.core.PermissionManagement.Error.WalletNotFoundById
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.sharedtest.containers.{KeycloakContainerCustom, KeycloakTestContainerSupport}
-import io.iohk.atala.test.container.DBTestUtils
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error.UnexpectedError
+import org.hyperledger.identus.iam.authorization.core.PermissionManagement.Error.WalletNotFoundById
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.sharedtest.containers.{KeycloakContainerCustom, KeycloakTestContainerSupport}
+import org.hyperledger.identus.test.container.DBTestUtils
import zio.*
import zio.ZIO.*
import zio.http.Client
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/issue/controller/IssueControllerImplSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/issue/controller/IssueControllerImplSpec.scala
similarity index 88%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/issue/controller/IssueControllerImplSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/issue/controller/IssueControllerImplSpec.scala
index e4bc47825a..341ba9f99d 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/issue/controller/IssueControllerImplSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/issue/controller/IssueControllerImplSpec.scala
@@ -1,23 +1,23 @@
-package io.iohk.atala.issue.controller
+package org.hyperledger.identus.issue.controller
-import io.iohk.atala.agent.walletapi.model.{BaseEntity, ManagedDIDState, PublicationState}
-import io.iohk.atala.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.castor.core.model.did.{DIDData, DIDMetadata, PrismDIDOperation, VerificationRelationship}
-import io.iohk.atala.castor.core.service.MockDIDService
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.ConnectionRecord.ProtocolState
-import io.iohk.atala.connect.core.service
-import io.iohk.atala.connect.core.service.MockConnectionService
-import io.iohk.atala.container.util.MigrationAspects.migrate
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.issue.controller.http.{AcceptCredentialOfferRequest, CreateIssueCredentialRecordRequest}
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.connection.ConnectionResponse
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.{ProtocolState, Role}
-import io.iohk.atala.pollux.core.model.{CredentialFormat, DidCommID, IssueCredentialRecord}
-import io.iohk.atala.pollux.core.service.MockCredentialService
+import org.hyperledger.identus.agent.walletapi.model.{BaseEntity, ManagedDIDState, PublicationState}
+import org.hyperledger.identus.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.castor.core.model.did.{DIDData, DIDMetadata, PrismDIDOperation, VerificationRelationship}
+import org.hyperledger.identus.castor.core.service.MockDIDService
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.ProtocolState
+import org.hyperledger.identus.connect.core.service
+import org.hyperledger.identus.connect.core.service.MockConnectionService
+import org.hyperledger.identus.container.util.MigrationAspects.migrate
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.issue.controller.http.{AcceptCredentialOfferRequest, CreateIssueCredentialRecordRequest}
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.connection.ConnectionResponse
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.{ProtocolState, Role}
+import org.hyperledger.identus.pollux.core.model.{CredentialFormat, DidCommID, IssueCredentialRecord}
+import org.hyperledger.identus.pollux.core.service.MockCredentialService
import sttp.client3.ziojson.*
import sttp.client3.{DeserializationException, UriContext, basicRequest}
import sttp.model.StatusCode
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/issue/controller/IssueControllerSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/issue/controller/IssueControllerSpec.scala
similarity index 94%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/issue/controller/IssueControllerSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/issue/controller/IssueControllerSpec.scala
index 2f9da9fc74..9dc27f430e 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/issue/controller/IssueControllerSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/issue/controller/IssueControllerSpec.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.issue.controller
+package org.hyperledger.identus.issue.controller
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.pollux.core.model.DidCommID
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.pollux.vc.jwt.W3cCredentialPayload
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.pollux.core.model.DidCommID
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.pollux.vc.jwt.W3cCredentialPayload
import zio.*
import zio.test.*
import zio.test.Assertion.*
-import io.iohk.atala.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.*
import io.circe.*
import java.time.Instant
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/issue/controller/IssueControllerTestTools.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/issue/controller/IssueControllerTestTools.scala
similarity index 77%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/issue/controller/IssueControllerTestTools.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/issue/controller/IssueControllerTestTools.scala
index bbe016b0a1..0d454fcba8 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/issue/controller/IssueControllerTestTools.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/issue/controller/IssueControllerTestTools.scala
@@ -1,20 +1,20 @@
-package io.iohk.atala.issue.controller
+package org.hyperledger.identus.issue.controller
import com.dimafeng.testcontainers.PostgreSQLContainer
import com.typesafe.config.ConfigFactory
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.server.http.CustomServerInterceptors
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.connect.core.service.ConnectionService
-import io.iohk.atala.iam.authentication.{AuthenticatorWithAuthZ, DefaultEntityAuthenticator}
-import io.iohk.atala.issue.controller.http.IssueCredentialRecordPage
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord
-import io.iohk.atala.pollux.core.service.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.http.CustomServerInterceptors
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.connect.core.service.ConnectionService
+import org.hyperledger.identus.iam.authentication.{AuthenticatorWithAuthZ, DefaultEntityAuthenticator}
+import org.hyperledger.identus.issue.controller.http.IssueCredentialRecordPage
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord
+import org.hyperledger.identus.pollux.core.service.*
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
import sttp.client3.testing.SttpBackendStub
import sttp.client3.{DeserializationException, Response, UriContext}
import sttp.monad.MonadError
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionBasicSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionBasicSpec.scala
similarity index 87%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionBasicSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionBasicSpec.scala
index ffabec1c77..f991a36b63 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionBasicSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionBasicSpec.scala
@@ -1,18 +1,21 @@
-package io.iohk.atala.pollux.credentialdefinition
+package org.hyperledger.identus.pollux.credentialdefinition
-import io.iohk.atala.agent.walletapi.model.{BaseEntity, Entity}
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.container.util.MigrationAspects.*
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.pollux.core.model.secret.CredentialDefinitionSecret
-import io.iohk.atala.pollux.core.service.serdes.{
+import org.hyperledger.identus.agent.walletapi.model.{BaseEntity, Entity}
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.container.util.MigrationAspects.*
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.pollux.core.model.secret.CredentialDefinitionSecret
+import org.hyperledger.identus.pollux.core.service.serdes.{
PrivateCredentialDefinitionSchemaSerDesV1,
ProofKeyCredentialDefinitionSchemaSerDesV1,
PublicCredentialDefinitionSerDesV1
}
-import io.iohk.atala.pollux.credentialdefinition.controller.CredentialDefinitionController
-import io.iohk.atala.pollux.credentialdefinition.http.{CredentialDefinitionInput, CredentialDefinitionResponse}
+import org.hyperledger.identus.pollux.credentialdefinition.controller.CredentialDefinitionController
+import org.hyperledger.identus.pollux.credentialdefinition.http.{
+ CredentialDefinitionInput,
+ CredentialDefinitionResponse
+}
import sttp.client3.basicRequest
import sttp.client3.ziojson.*
import sttp.model.StatusCode
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionFailureSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionFailureSpec.scala
similarity index 76%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionFailureSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionFailureSpec.scala
index ba8202862f..ae94a94941 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionFailureSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionFailureSpec.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.credentialdefinition
+package org.hyperledger.identus.pollux.credentialdefinition
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.service.MockManagedDIDService
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.container.util.MigrationAspects.migrate
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.pollux.credentialdefinition.controller.CredentialDefinitionController
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.service.MockManagedDIDService
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.container.util.MigrationAspects.migrate
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.pollux.credentialdefinition.controller.CredentialDefinitionController
import sttp.client3.ziojson.*
import sttp.client3.{DeserializationException, basicRequest}
import sttp.model.StatusCode
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionLookupAndPaginationSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionLookupAndPaginationSpec.scala
similarity index 89%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionLookupAndPaginationSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionLookupAndPaginationSpec.scala
index 525b7bfa70..84b142a0c8 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionLookupAndPaginationSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionLookupAndPaginationSpec.scala
@@ -1,11 +1,14 @@
-package io.iohk.atala.pollux.credentialdefinition
+package org.hyperledger.identus.pollux.credentialdefinition
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.container.util.MigrationAspects.migrate
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.pollux.credentialdefinition.controller.CredentialDefinitionController
-import io.iohk.atala.pollux.credentialdefinition.http.{CredentialDefinitionResponse, CredentialDefinitionResponsePage}
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.container.util.MigrationAspects.migrate
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.pollux.credentialdefinition.controller.CredentialDefinitionController
+import org.hyperledger.identus.pollux.credentialdefinition.http.{
+ CredentialDefinitionResponse,
+ CredentialDefinitionResponsePage
+}
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import sttp.client3.ziojson.*
import sttp.client3.{DeserializationException, Response, UriContext, basicRequest}
import sttp.model.{StatusCode, Uri}
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionTestTools.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionTestTools.scala
similarity index 84%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionTestTools.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionTestTools.scala
index d38a9d28d0..c39e35749c 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/credentialdefinition/CredentialDefinitionTestTools.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/credentialdefinition/CredentialDefinitionTestTools.scala
@@ -1,34 +1,34 @@
-package io.iohk.atala.pollux.credentialdefinition
+package org.hyperledger.identus.pollux.credentialdefinition
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.agent.server.http.CustomServerInterceptors
-import io.iohk.atala.agent.walletapi.memory.GenericSecretStorageInMemory
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.{ManagedDIDState, PublicationState}
-import io.iohk.atala.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.castor.core.model.did.PrismDIDOperation
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.iam.authentication.DefaultEntityAuthenticator
-import io.iohk.atala.pollux.core.repository.CredentialDefinitionRepository
-import io.iohk.atala.pollux.core.service.{
+import org.hyperledger.identus.agent.server.http.CustomServerInterceptors
+import org.hyperledger.identus.agent.walletapi.memory.GenericSecretStorageInMemory
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.{ManagedDIDState, PublicationState}
+import org.hyperledger.identus.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.castor.core.model.did.PrismDIDOperation
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.iam.authentication.DefaultEntityAuthenticator
+import org.hyperledger.identus.pollux.core.repository.CredentialDefinitionRepository
+import org.hyperledger.identus.pollux.core.service.{
CredentialDefinitionService,
CredentialDefinitionServiceImpl,
ResourceURIDereferencerImpl
}
-import io.iohk.atala.pollux.credentialdefinition.controller.{
+import org.hyperledger.identus.pollux.credentialdefinition.controller.{
CredentialDefinitionController,
CredentialDefinitionControllerImpl
}
-import io.iohk.atala.pollux.credentialdefinition.http.{
+import org.hyperledger.identus.pollux.credentialdefinition.http.{
CredentialDefinitionInput,
CredentialDefinitionResponse,
CredentialDefinitionResponsePage
}
-import io.iohk.atala.pollux.sql.repository.JdbcCredentialDefinitionRepository
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.pollux.sql.repository.JdbcCredentialDefinitionRepository
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
import sttp.client3.testing.SttpBackendStub
import sttp.client3.ziojson.*
import sttp.client3.{DeserializationException, Response, UriContext, basicRequest}
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaAnoncredSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaAnoncredSpec.scala
similarity index 85%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaAnoncredSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaAnoncredSpec.scala
index 87fd6726cb..58aaaacfd9 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaAnoncredSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaAnoncredSpec.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.pollux.schema
-
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.container.util.MigrationAspects.*
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
-import io.iohk.atala.pollux.core.model.schema.`type`.{AnoncredSchemaType, CredentialJsonSchemaType}
-import io.iohk.atala.pollux.credentialschema.*
-import io.iohk.atala.pollux.credentialschema.controller.CredentialSchemaController
-import io.iohk.atala.pollux.credentialschema.http.{CredentialSchemaInput, CredentialSchemaResponse}
+package org.hyperledger.identus.pollux.schema
+
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.container.util.MigrationAspects.*
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
+import org.hyperledger.identus.pollux.core.model.schema.`type`.{AnoncredSchemaType, CredentialJsonSchemaType}
+import org.hyperledger.identus.pollux.credentialschema.*
+import org.hyperledger.identus.pollux.credentialschema.controller.CredentialSchemaController
+import org.hyperledger.identus.pollux.credentialschema.http.{CredentialSchemaInput, CredentialSchemaResponse}
import sttp.client3.basicRequest
import sttp.client3.ziojson.{asJsonAlways, *}
import sttp.model.StatusCode
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaBasicSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaBasicSpec.scala
similarity index 85%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaBasicSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaBasicSpec.scala
index b2e7822f11..d5dd2bc21f 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaBasicSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaBasicSpec.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.pollux.schema
+package org.hyperledger.identus.pollux.schema
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.container.util.MigrationAspects.*
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.pollux.core.model.schema.`type`.CredentialJsonSchemaType
-import io.iohk.atala.pollux.credentialschema.*
-import io.iohk.atala.pollux.credentialschema.controller.CredentialSchemaController
-import io.iohk.atala.pollux.credentialschema.http.{CredentialSchemaInput, CredentialSchemaResponse}
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.container.util.MigrationAspects.*
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.pollux.core.model.schema.`type`.CredentialJsonSchemaType
+import org.hyperledger.identus.pollux.credentialschema.*
+import org.hyperledger.identus.pollux.credentialschema.controller.CredentialSchemaController
+import org.hyperledger.identus.pollux.credentialschema.http.{CredentialSchemaInput, CredentialSchemaResponse}
import sttp.client3.basicRequest
import sttp.client3.ziojson.*
import sttp.model.StatusCode
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaFailureSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaFailureSpec.scala
similarity index 72%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaFailureSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaFailureSpec.scala
index 49312e9591..c2cfd861bc 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaFailureSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaFailureSpec.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.pollux.schema
+package org.hyperledger.identus.pollux.schema
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.service.MockManagedDIDService
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.container.util.MigrationAspects.migrate
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.pollux.credentialschema.*
-import io.iohk.atala.pollux.credentialschema.controller.CredentialSchemaController
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.service.MockManagedDIDService
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.container.util.MigrationAspects.migrate
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.pollux.credentialschema.*
+import org.hyperledger.identus.pollux.credentialschema.controller.CredentialSchemaController
import sttp.client3.DeserializationException
import sttp.client3.basicRequest
import sttp.client3.ziojson.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaLookupAndPaginationSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaLookupAndPaginationSpec.scala
similarity index 89%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaLookupAndPaginationSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaLookupAndPaginationSpec.scala
index 160bc75633..f8e3a192a4 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaLookupAndPaginationSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaLookupAndPaginationSpec.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.pollux.schema
+package org.hyperledger.identus.pollux.schema
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.container.util.MigrationAspects.migrate
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.pollux.credentialschema.*
-import io.iohk.atala.pollux.credentialschema.controller.CredentialSchemaController
-import io.iohk.atala.pollux.credentialschema.http.{
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.container.util.MigrationAspects.migrate
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.pollux.credentialschema.*
+import org.hyperledger.identus.pollux.credentialschema.controller.CredentialSchemaController
+import org.hyperledger.identus.pollux.credentialschema.http.{
CredentialSchemaInput,
CredentialSchemaResponse,
CredentialSchemaResponsePage
}
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import sttp.client3.ziojson.*
import sttp.client3.{DeserializationException, Response, UriContext, basicRequest}
import sttp.model.{StatusCode, Uri}
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaMultiTenancySpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaMultiTenancySpec.scala
similarity index 89%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaMultiTenancySpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaMultiTenancySpec.scala
index 706784b68c..bead3f57b0 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaMultiTenancySpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaMultiTenancySpec.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.pollux.schema
+package org.hyperledger.identus.pollux.schema
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.container.util.MigrationAspects.*
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema
-import io.iohk.atala.pollux.core.model.schema.`type`.CredentialJsonSchemaType
-import io.iohk.atala.pollux.core.service.{CredentialSchemaService, CredentialSchemaServiceImpl}
-import io.iohk.atala.pollux.sql.repository.JdbcCredentialSchemaRepository
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.container.util.MigrationAspects.*
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema
+import org.hyperledger.identus.pollux.core.model.schema.`type`.CredentialJsonSchemaType
+import org.hyperledger.identus.pollux.core.service.{CredentialSchemaService, CredentialSchemaServiceImpl}
+import org.hyperledger.identus.pollux.sql.repository.JdbcCredentialSchemaRepository
import zio.*
import zio.ZIO.*
import zio.json.*
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaTestTools.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaTestTools.scala
similarity index 81%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaTestTools.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaTestTools.scala
index 498e198d39..9236536421 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/pollux/schema/CredentialSchemaTestTools.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/pollux/schema/CredentialSchemaTestTools.scala
@@ -1,27 +1,30 @@
-package io.iohk.atala.pollux.schema
+package org.hyperledger.identus.pollux.schema
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.agent.server.http.CustomServerInterceptors
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.model.{ManagedDIDState, PublicationState}
-import io.iohk.atala.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
-import io.iohk.atala.api.http.ErrorResponse
-import io.iohk.atala.castor.core.model.did.PrismDIDOperation
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.iam.authentication.DefaultEntityAuthenticator
-import io.iohk.atala.pollux.core.model.schema.`type`.CredentialJsonSchemaType
-import io.iohk.atala.pollux.core.repository.CredentialSchemaRepository
-import io.iohk.atala.pollux.core.service.{CredentialSchemaService, CredentialSchemaServiceImpl}
-import io.iohk.atala.pollux.credentialschema.SchemaRegistryServerEndpoints
-import io.iohk.atala.pollux.credentialschema.controller.{CredentialSchemaController, CredentialSchemaControllerImpl}
-import io.iohk.atala.pollux.credentialschema.http.{
+import org.hyperledger.identus.agent.server.http.CustomServerInterceptors
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.model.{ManagedDIDState, PublicationState}
+import org.hyperledger.identus.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
+import org.hyperledger.identus.api.http.ErrorResponse
+import org.hyperledger.identus.castor.core.model.did.PrismDIDOperation
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.iam.authentication.DefaultEntityAuthenticator
+import org.hyperledger.identus.pollux.core.model.schema.`type`.CredentialJsonSchemaType
+import org.hyperledger.identus.pollux.core.repository.CredentialSchemaRepository
+import org.hyperledger.identus.pollux.core.service.{CredentialSchemaService, CredentialSchemaServiceImpl}
+import org.hyperledger.identus.pollux.credentialschema.SchemaRegistryServerEndpoints
+import org.hyperledger.identus.pollux.credentialschema.controller.{
+ CredentialSchemaController,
+ CredentialSchemaControllerImpl
+}
+import org.hyperledger.identus.pollux.credentialschema.http.{
CredentialSchemaInput,
CredentialSchemaResponse,
CredentialSchemaResponsePage
}
-import io.iohk.atala.pollux.sql.repository.JdbcCredentialSchemaRepository
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.pollux.sql.repository.JdbcCredentialSchemaRepository
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
import sttp.client3.testing.SttpBackendStub
import sttp.client3.ziojson.*
import sttp.client3.{DeserializationException, Response, UriContext, basicRequest}
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/system/controller/SystemControllerImplSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/system/controller/SystemControllerImplSpec.scala
similarity index 94%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/system/controller/SystemControllerImplSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/system/controller/SystemControllerImplSpec.scala
index 363386c81a..d1b45f9968 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/system/controller/SystemControllerImplSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/system/controller/SystemControllerImplSpec.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.system.controller
+package org.hyperledger.identus.system.controller
-import io.iohk.atala.system.controller.http.HealthInfo
+import org.hyperledger.identus.system.controller.http.HealthInfo
import sttp.client3.ziojson.*
import sttp.client3.{DeserializationException, UriContext, asString, basicRequest}
import sttp.model.StatusCode
import zio.test.*
import zio.test.Assertion.*
-import io.iohk.atala.agent.server.buildinfo.BuildInfo
+import org.hyperledger.identus.agent.server.buildinfo.BuildInfo
import zio.*
object SystemControllerImplSpec extends ZIOSpecDefault with SystemControllerTestTools {
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/system/controller/SystemControllerTestTools.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/system/controller/SystemControllerTestTools.scala
similarity index 86%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/system/controller/SystemControllerTestTools.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/system/controller/SystemControllerTestTools.scala
index 930007b7bf..325accbf56 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/system/controller/SystemControllerTestTools.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/system/controller/SystemControllerTestTools.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.system.controller
+package org.hyperledger.identus.system.controller
import sttp.client3.testing.SttpBackendStub
import sttp.client3.{DeserializationException, Response, UriContext}
@@ -8,10 +8,10 @@ import sttp.tapir.ztapir.RIOMonadError
import zio.metrics.connectors.micrometer
import zio.*
import zio.metrics.jvm.DefaultJvmMetrics
-import io.iohk.atala.system.controller.http.HealthInfo
-import io.iohk.atala.agent.server.SystemModule.configLayer
-import io.iohk.atala.agent.server.config.AppConfig
-import io.iohk.atala.agent.server.http.CustomServerInterceptors
+import org.hyperledger.identus.system.controller.http.HealthInfo
+import org.hyperledger.identus.agent.server.SystemModule.configLayer
+import org.hyperledger.identus.agent.server.config.AppConfig
+import org.hyperledger.identus.agent.server.http.CustomServerInterceptors
import sttp.monad.MonadError
import zio.metrics.connectors.micrometer.MicrometerConfig
import zio.test.ZIOSpecDefault
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerImplSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImplSpec.scala
similarity index 90%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerImplSpec.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImplSpec.scala
index 4e67ad59bf..1efbe9e153 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerImplSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImplSpec.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.verification.controller
+package org.hyperledger.identus.verification.controller
import io.circe.*
import io.circe.syntax.*
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
-import io.iohk.atala.castor.core.service.MockDIDService
-import io.iohk.atala.iam.authentication.AuthenticatorWithAuthZ
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
-import io.iohk.atala.verification.controller.http.*
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
+import org.hyperledger.identus.castor.core.service.MockDIDService
+import org.hyperledger.identus.iam.authentication.AuthenticatorWithAuthZ
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
+import org.hyperledger.identus.verification.controller.http.*
import sttp.client3.ziojson.*
import sttp.client3.{DeserializationException, Response, UriContext, basicRequest}
import sttp.model.StatusCode
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerTestTools.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerTestTools.scala
similarity index 71%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerTestTools.scala
rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerTestTools.scala
index 30bce18ce2..666e3de51a 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/verification/controller/VcVerificationControllerTestTools.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerTestTools.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.verification.controller
+package org.hyperledger.identus.verification.controller
-import io.iohk.atala.agent.server.http.CustomServerInterceptors
-import io.iohk.atala.agent.walletapi.model.BaseEntity
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.castor.core.service.MockDIDService
-import io.iohk.atala.iam.authentication.{AuthenticatorWithAuthZ, DefaultEntityAuthenticator}
-import io.iohk.atala.pollux.core.service.*
-import io.iohk.atala.pollux.core.service.verification.{VcVerificationService, VcVerificationServiceImpl}
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.shared.models.WalletId.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.agent.server.http.CustomServerInterceptors
+import org.hyperledger.identus.agent.walletapi.model.BaseEntity
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.castor.core.service.MockDIDService
+import org.hyperledger.identus.iam.authentication.{AuthenticatorWithAuthZ, DefaultEntityAuthenticator}
+import org.hyperledger.identus.pollux.core.service.*
+import org.hyperledger.identus.pollux.core.service.verification.{VcVerificationService, VcVerificationServiceImpl}
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.shared.models.WalletId.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
import sttp.client3.UriContext
import sttp.client3.testing.SttpBackendStub
import sttp.monad.MonadError
@@ -29,7 +29,7 @@ trait VcVerificationControllerTestTools extends PostgresTestContainerSupport {
protected val issuer =
Issuer(
- did = io.iohk.atala.pollux.vc.jwt.DID(issuerDidData.id.did.toString),
+ did = org.hyperledger.identus.pollux.vc.jwt.DID(issuerDidData.id.did.toString),
signer = ES256KSigner(issuerKp.privateKey.toJavaPrivateKey),
publicKey = issuerKp.publicKey.toJavaPublicKey
)
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V10__create_peer_did_table.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V10__create_peer_did_table.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V10__create_peer_did_table.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V10__create_peer_did_table.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V11__wallet_seed_digest.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V11__wallet_seed_digest.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V11__wallet_seed_digest.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V11__wallet_seed_digest.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V12__generic_secret.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V12__generic_secret.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V12__generic_secret.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V12__generic_secret.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V13__apikey_authentication_improvements.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V13__apikey_authentication_improvements.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V13__apikey_authentication_improvements.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V13__apikey_authentication_improvements.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V14__multiple_did_key_types.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V14__multiple_did_key_types.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V14__multiple_did_key_types.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V14__multiple_did_key_types.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V1__init_tables.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V1__init_tables.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V1__init_tables.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V1__init_tables.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V2__did_nonsecret_storage.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V2__did_nonsecret_storage.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V2__did_nonsecret_storage.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V2__did_nonsecret_storage.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V3__did_update_state.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V3__did_update_state.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V3__did_update_state.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V3__did_update_state.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V4__did_hd_key.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V4__did_hd_key.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V4__did_hd_key.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V4__did_hd_key.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V5__remove_did_rand_key.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V5__remove_did_rand_key.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V5__remove_did_rand_key.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V5__remove_did_rand_key.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V6__add_schema_id_to_secret_table.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V6__add_schema_id_to_secret_table.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V6__add_schema_id_to_secret_table.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V6__add_schema_id_to_secret_table.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V7__mutitenant_wallet.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V7__mutitenant_wallet.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V7__mutitenant_wallet.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V7__mutitenant_wallet.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V8__init_entity_repository_tables.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V8__init_entity_repository_tables.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V8__init_entity_repository_tables.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V8__init_entity_repository_tables.sql
diff --git a/prism-agent/service/wallet-api/src/main/resources/sql/agent/V9__init_authentication_repository_tables.sql b/cloud-agent/service/wallet-api/src/main/resources/sql/agent/V9__init_authentication_repository_tables.sql
similarity index 100%
rename from prism-agent/service/wallet-api/src/main/resources/sql/agent/V9__init_authentication_repository_tables.sql
rename to cloud-agent/service/wallet-api/src/main/resources/sql/agent/V9__init_authentication_repository_tables.sql
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/GenericSecretStorageInMemory.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/memory/GenericSecretStorageInMemory.scala
similarity index 84%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/GenericSecretStorageInMemory.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/memory/GenericSecretStorageInMemory.scala
index 954c02af25..75d6d93660 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/GenericSecretStorageInMemory.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/memory/GenericSecretStorageInMemory.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.agent.walletapi.memory
+package org.hyperledger.identus.agent.walletapi.memory
-import io.iohk.atala.agent.walletapi.storage.GenericSecret
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecret
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import zio.json.ast.Json
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/WalletSecretStorageInMemory.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/memory/WalletSecretStorageInMemory.scala
similarity index 71%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/WalletSecretStorageInMemory.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/memory/WalletSecretStorageInMemory.scala
index aae6a1aa44..a2eef53a13 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/memory/WalletSecretStorageInMemory.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/memory/WalletSecretStorageInMemory.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.agent.walletapi.memory
+package org.hyperledger.identus.agent.walletapi.memory
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
class WalletSecretStorageInMemory(storeRef: Ref[Map[WalletId, WalletSeed]]) extends WalletSecretStorage {
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/Entity.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/Entity.scala
similarity index 93%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/Entity.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/Entity.scala
index 8dd665f084..182ef7afc1 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/Entity.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/Entity.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.walletapi.model
+package org.hyperledger.identus.agent.walletapi.model
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import java.time.Instant
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/KeyManagement.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/KeyManagement.scala
similarity index 93%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/KeyManagement.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/KeyManagement.scala
index 95c7b6105c..baa03202cb 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/KeyManagement.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/KeyManagement.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.agent.walletapi.model
+package org.hyperledger.identus.agent.walletapi.model
-import io.iohk.atala.castor.core.model.did.EllipticCurve
-import io.iohk.atala.castor.core.model.did.InternalKeyPurpose
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.castor.core.model.did.EllipticCurve
+import org.hyperledger.identus.castor.core.model.did.InternalKeyPurpose
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
import io.iohk.atala.prism.crypto.Sha256
-import io.iohk.atala.shared.crypto.DerivationPath
-import io.iohk.atala.shared.crypto.Ed25519KeyPair
-import io.iohk.atala.shared.crypto.X25519KeyPair
+import org.hyperledger.identus.shared.crypto.DerivationPath
+import org.hyperledger.identus.shared.crypto.Ed25519KeyPair
+import org.hyperledger.identus.shared.crypto.X25519KeyPair
import scala.collection.immutable.ArraySeq
import scala.language.implicitConversions
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDID.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/ManagedDID.scala
similarity index 84%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDID.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/ManagedDID.scala
index 582a6d599e..b95f43cb9b 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDID.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/ManagedDID.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.walletapi.model
+package org.hyperledger.identus.agent.walletapi.model
-import io.iohk.atala.castor.core.model.did.{CanonicalPrismDID, PrismDIDOperation, ScheduledDIDOperationStatus}
+import org.hyperledger.identus.castor.core.model.did.{CanonicalPrismDID, PrismDIDOperation, ScheduledDIDOperationStatus}
import java.time.Instant
import scala.collection.immutable.ArraySeq
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDIDTemplate.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/ManagedDIDTemplate.scala
similarity index 90%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDIDTemplate.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/ManagedDIDTemplate.scala
index a17d47da65..08903f209e 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/ManagedDIDTemplate.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/ManagedDIDTemplate.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.walletapi.model
+package org.hyperledger.identus.agent.walletapi.model
-import io.iohk.atala.castor.core.model.did.{
+import org.hyperledger.identus.castor.core.model.did.{
EllipticCurve,
Service,
ServiceEndpoint,
diff --git a/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/PeerDIDRecord.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/PeerDIDRecord.scala
new file mode 100644
index 0000000000..f9bd9e36d9
--- /dev/null
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/PeerDIDRecord.scala
@@ -0,0 +1,8 @@
+package org.hyperledger.identus.agent.walletapi.model
+
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.shared.models.WalletId
+
+import java.time.Instant
+
+case class PeerDIDRecord(did: DidId, createdAt: Instant, walletId: WalletId)
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/Wallet.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/Wallet.scala
similarity index 87%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/Wallet.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/Wallet.scala
index 6e22772f13..8cbb164065 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/Wallet.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/Wallet.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.walletapi.model
+package org.hyperledger.identus.agent.walletapi.model
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletId
import java.time.Instant
import java.time.temporal.ChronoUnit
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/CreateManagedDIDError.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/CreateManagedDIDError.scala
similarity index 63%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/CreateManagedDIDError.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/CreateManagedDIDError.scala
index c2390f97ea..9dcb20cd4b 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/CreateManagedDIDError.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/CreateManagedDIDError.scala
@@ -1,6 +1,7 @@
-package io.iohk.atala.agent.walletapi.model.error
+package org.hyperledger.identus.agent.walletapi.model.error
-import io.iohk.atala.castor.core.model.error as castor
+import org.hyperledger.identus.castor.core.model.error as castor
+import org.hyperledger.identus.castor.core.model.error.OperationValidationError
sealed trait CreateManagedDIDError extends Throwable
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/DIDSecretStorageError.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/DIDSecretStorageError.scala
similarity index 69%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/DIDSecretStorageError.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/DIDSecretStorageError.scala
index 5f062bbb10..779d8fbde0 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/DIDSecretStorageError.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/DIDSecretStorageError.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.walletapi.model.error
+package org.hyperledger.identus.agent.walletapi.model.error
-import io.iohk.atala.mercury.model.DidId
+import org.hyperledger.identus.mercury.model.DidId
sealed trait DIDSecretStorageError extends Throwable
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/EntityServiceError.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/EntityServiceError.scala
similarity index 90%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/EntityServiceError.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/EntityServiceError.scala
index eb047bc49d..e2fef2dd9f 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/EntityServiceError.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/EntityServiceError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.agent.walletapi.model.error
+package org.hyperledger.identus.agent.walletapi.model.error
import java.util.UUID
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/GetKeyError.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/GetKeyError.scala
similarity index 77%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/GetKeyError.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/GetKeyError.scala
index 486f845923..b7c4439f04 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/GetKeyError.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/GetKeyError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.agent.walletapi.model.error
+package org.hyperledger.identus.agent.walletapi.model.error
sealed trait GetKeyError
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/GetManagedDIDError.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/GetManagedDIDError.scala
similarity index 63%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/GetManagedDIDError.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/GetManagedDIDError.scala
index a714d7bd16..effa4ef0c6 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/GetManagedDIDError.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/GetManagedDIDError.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.walletapi.model.error
+package org.hyperledger.identus.agent.walletapi.model.error
-import io.iohk.atala.castor.core.model.error.DIDOperationError
+import org.hyperledger.identus.castor.core.model.error.DIDOperationError
sealed trait GetManagedDIDError
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/PublishManagedDIDError.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/PublishManagedDIDError.scala
similarity index 67%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/PublishManagedDIDError.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/PublishManagedDIDError.scala
index c171ac5787..dde6740066 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/PublishManagedDIDError.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/PublishManagedDIDError.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.agent.walletapi.model.error
+package org.hyperledger.identus.agent.walletapi.model.error
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.castor.core.model.error.DIDOperationError
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+import org.hyperledger.identus.castor.core.model.error.DIDOperationError
sealed trait PublishManagedDIDError
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/UpdateManagedDIDError.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/UpdateManagedDIDError.scala
similarity index 77%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/UpdateManagedDIDError.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/UpdateManagedDIDError.scala
index ba317f40db..59975df2d1 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/UpdateManagedDIDError.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/UpdateManagedDIDError.scala
@@ -1,7 +1,8 @@
-package io.iohk.atala.agent.walletapi.model.error
+package org.hyperledger.identus.agent.walletapi.model.error
-import io.iohk.atala.castor.core.model.did.CanonicalPrismDID
-import io.iohk.atala.castor.core.model.error as castor
+import org.hyperledger.identus.castor.core.model.did.CanonicalPrismDID
+import org.hyperledger.identus.castor.core.model.error as castor
+import org.hyperledger.identus.castor.core.model.error.{OperationValidationError, DIDOperationError, DIDResolutionError}
sealed trait UpdateManagedDIDError
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/package.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/package.scala
similarity index 89%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/package.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/package.scala
index d6cb574b43..dc6869139e 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/error/package.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/error/package.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.walletapi.model
+package org.hyperledger.identus.agent.walletapi.model
-import io.iohk.atala.castor.core.model.error.DIDOperationError
+import org.hyperledger.identus.castor.core.model.error.DIDOperationError
package object error {
final case class CommonWalletStorageError(cause: Throwable)
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/EntityService.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/EntityService.scala
similarity index 72%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/EntityService.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/EntityService.scala
index 8b3df2fdc1..1899072ff1 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/EntityService.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/EntityService.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.agent.walletapi.service
+package org.hyperledger.identus.agent.walletapi.service
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError
import zio.IO
import java.util.UUID
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/EntityServiceImpl.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/EntityServiceImpl.scala
similarity index 86%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/EntityServiceImpl.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/EntityServiceImpl.scala
index 5cd5839171..7dad1c1f97 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/EntityServiceImpl.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/EntityServiceImpl.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.agent.walletapi.service
+package org.hyperledger.identus.agent.walletapi.service
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError
-import io.iohk.atala.agent.walletapi.sql.EntityRepository
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError
+import org.hyperledger.identus.agent.walletapi.sql.EntityRepository
import zio.{IO, URLayer, ZIO, ZLayer}
import java.util.UUID
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDService.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDService.scala
similarity index 77%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDService.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDService.scala
index 229ea7aafb..8d58fa4aec 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDService.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDService.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.agent.walletapi.service
-
-import io.iohk.atala.agent.walletapi.model.*
-import io.iohk.atala.agent.walletapi.model.error.*
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.mercury.PeerDID
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.crypto.Ed25519KeyPair
-import io.iohk.atala.shared.crypto.Secp256k1KeyPair
-import io.iohk.atala.shared.crypto.X25519KeyPair
-import io.iohk.atala.shared.models.WalletAccessContext
+package org.hyperledger.identus.agent.walletapi.service
+
+import org.hyperledger.identus.agent.walletapi.model.*
+import org.hyperledger.identus.agent.walletapi.model.error.*
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.mercury.PeerDID
+import org.hyperledger.identus.mercury.model.*
+import org.hyperledger.identus.shared.crypto.Ed25519KeyPair
+import org.hyperledger.identus.shared.crypto.Secp256k1KeyPair
+import org.hyperledger.identus.shared.crypto.X25519KeyPair
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.security.{PrivateKey as JavaPrivateKey, PublicKey as JavaPublicKey}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceImpl.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceImpl.scala
similarity index 93%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceImpl.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceImpl.scala
index 521f6f7a30..0fc7657186 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceImpl.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceImpl.scala
@@ -1,22 +1,22 @@
-package io.iohk.atala.agent.walletapi.service
+package org.hyperledger.identus.agent.walletapi.service
-import io.iohk.atala.agent.walletapi.model.*
-import io.iohk.atala.agent.walletapi.model.error.{*, given}
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService.DEFAULT_MASTER_KEY_ID
-import io.iohk.atala.agent.walletapi.service.handler.{DIDCreateHandler, DIDUpdateHandler, PublicationHandler}
-import io.iohk.atala.agent.walletapi.storage.{DIDSecretStorage, DIDNonSecretStorage, WalletSecretStorage}
-import io.iohk.atala.agent.walletapi.util.*
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.castor.core.model.error.DIDOperationError
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.castor.core.util.DIDOperationValidator
-import io.iohk.atala.mercury.PeerDID
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.crypto.Ed25519KeyPair
-import io.iohk.atala.shared.crypto.Secp256k1KeyPair
-import io.iohk.atala.shared.crypto.X25519KeyPair
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.*
+import org.hyperledger.identus.agent.walletapi.model.error.{*, given}
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService.DEFAULT_MASTER_KEY_ID
+import org.hyperledger.identus.agent.walletapi.service.handler.{DIDCreateHandler, DIDUpdateHandler, PublicationHandler}
+import org.hyperledger.identus.agent.walletapi.storage.{DIDSecretStorage, DIDNonSecretStorage, WalletSecretStorage}
+import org.hyperledger.identus.agent.walletapi.util.*
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.castor.core.model.error.DIDOperationError
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.castor.core.util.DIDOperationValidator
+import org.hyperledger.identus.mercury.PeerDID
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.crypto.Ed25519KeyPair
+import org.hyperledger.identus.shared.crypto.Secp256k1KeyPair
+import org.hyperledger.identus.shared.crypto.X25519KeyPair
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.security.{PrivateKey as JavaPrivateKey, PublicKey as JavaPublicKey}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceWithEventNotificationImpl.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceWithEventNotificationImpl.scala
similarity index 73%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceWithEventNotificationImpl.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceWithEventNotificationImpl.scala
index b22b5da747..5e5bc4f76a 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceWithEventNotificationImpl.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceWithEventNotificationImpl.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.agent.walletapi.service
+package org.hyperledger.identus.agent.walletapi.service
-import io.iohk.atala.agent.walletapi.model.ManagedDIDDetail
-import io.iohk.atala.agent.walletapi.model.error.CommonWalletStorageError
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.agent.walletapi.storage.{DIDNonSecretStorage, DIDSecretStorage}
-import io.iohk.atala.castor.core.model.did.CanonicalPrismDID
-import io.iohk.atala.castor.core.model.error
-import io.iohk.atala.castor.core.model.error.DIDOperationError
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.castor.core.util.DIDOperationValidator
-import io.iohk.atala.event.notification.{Event, EventNotificationService}
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDDetail
+import org.hyperledger.identus.agent.walletapi.model.error.CommonWalletStorageError
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.{DIDNonSecretStorage, DIDSecretStorage}
+import org.hyperledger.identus.castor.core.model.did.CanonicalPrismDID
+import org.hyperledger.identus.castor.core.model.error
+import org.hyperledger.identus.castor.core.model.error.DIDOperationError
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.castor.core.util.DIDOperationValidator
+import org.hyperledger.identus.event.notification.{Event, EventNotificationService}
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
class ManagedDIDServiceWithEventNotificationImpl(
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/MockManagedDIDService.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/MockManagedDIDService.scala
similarity index 85%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/MockManagedDIDService.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/MockManagedDIDService.scala
index ea3128b884..e19677c513 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/MockManagedDIDService.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/MockManagedDIDService.scala
@@ -1,19 +1,19 @@
-package io.iohk.atala.agent.walletapi.service
+package org.hyperledger.identus.agent.walletapi.service
-import io.iohk.atala.agent.walletapi.model.*
-import io.iohk.atala.agent.walletapi.model.error.*
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.castor.core.model.did.{
+import org.hyperledger.identus.agent.walletapi.model.*
+import org.hyperledger.identus.agent.walletapi.model.error.*
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.castor.core.model.did.{
CanonicalPrismDID,
LongFormPrismDID,
PrismDIDOperation,
ScheduleDIDOperationOutcome
}
-import io.iohk.atala.mercury.PeerDID
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.crypto.Ed25519KeyPair
-import io.iohk.atala.shared.crypto.Secp256k1KeyPair
-import io.iohk.atala.shared.crypto.X25519KeyPair
+import org.hyperledger.identus.mercury.PeerDID
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.shared.crypto.Ed25519KeyPair
+import org.hyperledger.identus.shared.crypto.Secp256k1KeyPair
+import org.hyperledger.identus.shared.crypto.X25519KeyPair
import zio.mock.*
import zio.test.Assertion
import zio.{mock, *}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/WalletManagementService.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/WalletManagementService.scala
similarity index 84%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/WalletManagementService.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/WalletManagementService.scala
index 3b7b9e47b0..635fd826f3 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/WalletManagementService.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/WalletManagementService.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.agent.walletapi.service
+package org.hyperledger.identus.agent.walletapi.service
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.storage.WalletNonSecretStorageError
-import io.iohk.atala.event.notification.EventNotificationConfig
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.storage.WalletNonSecretStorageError
+import org.hyperledger.identus.event.notification.EventNotificationConfig
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import java.util.UUID
import scala.language.implicitConversions
-import io.iohk.atala.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
sealed trait WalletManagementServiceError {
final def toThrowable: Throwable = this
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/WalletManagementServiceImpl.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/WalletManagementServiceImpl.scala
similarity index 84%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/WalletManagementServiceImpl.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/WalletManagementServiceImpl.scala
index 082178ac82..355eb543b3 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/WalletManagementServiceImpl.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/WalletManagementServiceImpl.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.agent.walletapi.service
+package org.hyperledger.identus.agent.walletapi.service
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.storage.WalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.event.notification.EventNotificationConfig
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.storage.WalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.event.notification.EventNotificationConfig
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import java.util.UUID
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDCreateHandler.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDCreateHandler.scala
similarity index 68%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDCreateHandler.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDCreateHandler.scala
index 59e3dcc5f7..360377f8e8 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDCreateHandler.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDCreateHandler.scala
@@ -1,20 +1,20 @@
-package io.iohk.atala.agent.walletapi.service.handler
+package org.hyperledger.identus.agent.walletapi.service.handler
-import io.iohk.atala.agent.walletapi.model.CreateDIDKey
-import io.iohk.atala.agent.walletapi.model.ManagedDIDState
-import io.iohk.atala.agent.walletapi.model.ManagedDIDTemplate
-import io.iohk.atala.agent.walletapi.model.PublicationState
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.model.error.CreateManagedDIDError
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.agent.walletapi.util.OperationFactory
-import io.iohk.atala.castor.core.model.did.PrismDIDOperation
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.crypto.Ed25519KeyPair
-import io.iohk.atala.shared.crypto.X25519KeyPair
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.CreateDIDKey
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDState
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDTemplate
+import org.hyperledger.identus.agent.walletapi.model.PublicationState
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.model.error.CreateManagedDIDError
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.DIDSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.agent.walletapi.util.OperationFactory
+import org.hyperledger.identus.castor.core.model.did.PrismDIDOperation
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.crypto.Ed25519KeyPair
+import org.hyperledger.identus.shared.crypto.X25519KeyPair
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
private[walletapi] class DIDCreateHandler(
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDUpdateHandler.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDUpdateHandler.scala
similarity index 72%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDUpdateHandler.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDUpdateHandler.scala
index f6ae6dfbf3..c55bae5116 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDUpdateHandler.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDUpdateHandler.scala
@@ -1,25 +1,25 @@
-package io.iohk.atala.agent.walletapi.service.handler
+package org.hyperledger.identus.agent.walletapi.service.handler
-import io.iohk.atala.agent.walletapi.model.DIDUpdateLineage
-import io.iohk.atala.agent.walletapi.model.ManagedDIDKeyMeta
-import io.iohk.atala.agent.walletapi.model.ManagedDIDState
-import io.iohk.atala.agent.walletapi.model.UpdateDIDKey
-import io.iohk.atala.agent.walletapi.model.UpdateManagedDIDAction
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.model.error.UpdateManagedDIDError
-import io.iohk.atala.agent.walletapi.model.error.{*, given}
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.agent.walletapi.util.OperationFactory
-import io.iohk.atala.castor.core.model.did.PrismDIDOperation
-import io.iohk.atala.castor.core.model.did.PrismDIDOperation.Update
-import io.iohk.atala.castor.core.model.did.ScheduledDIDOperationStatus
-import io.iohk.atala.castor.core.model.did.SignedPrismDIDOperation
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.crypto.Ed25519KeyPair
-import io.iohk.atala.shared.crypto.X25519KeyPair
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.DIDUpdateLineage
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDKeyMeta
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDState
+import org.hyperledger.identus.agent.walletapi.model.UpdateDIDKey
+import org.hyperledger.identus.agent.walletapi.model.UpdateManagedDIDAction
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.model.error.UpdateManagedDIDError
+import org.hyperledger.identus.agent.walletapi.model.error.{*, given}
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.DIDSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.agent.walletapi.util.OperationFactory
+import org.hyperledger.identus.castor.core.model.did.PrismDIDOperation
+import org.hyperledger.identus.castor.core.model.did.PrismDIDOperation.Update
+import org.hyperledger.identus.castor.core.model.did.ScheduledDIDOperationStatus
+import org.hyperledger.identus.castor.core.model.did.SignedPrismDIDOperation
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.crypto.Ed25519KeyPair
+import org.hyperledger.identus.shared.crypto.X25519KeyPair
+import org.hyperledger.identus.shared.models.WalletAccessContext
import scala.collection.immutable.ArraySeq
import zio.*
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/PublicationHandler.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/PublicationHandler.scala
similarity index 61%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/PublicationHandler.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/PublicationHandler.scala
index 1cdf639732..8eb17c65c0 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/PublicationHandler.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/PublicationHandler.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.agent.walletapi.service.handler
+package org.hyperledger.identus.agent.walletapi.service.handler
-import io.iohk.atala.agent.walletapi.model.ManagedDIDState
-import io.iohk.atala.agent.walletapi.model.error.CommonCryptographyError
-import io.iohk.atala.agent.walletapi.model.error.CommonWalletStorageError
-import io.iohk.atala.agent.walletapi.util.KeyResolver
-import io.iohk.atala.castor.core.model.did.PrismDIDOperation
-import io.iohk.atala.castor.core.model.did.ScheduleDIDOperationOutcome
-import io.iohk.atala.castor.core.model.did.SignedPrismDIDOperation
-import io.iohk.atala.castor.core.model.error.DIDOperationError
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.shared.crypto.Secp256k1KeyPair
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDState
+import org.hyperledger.identus.agent.walletapi.model.error.CommonCryptographyError
+import org.hyperledger.identus.agent.walletapi.model.error.CommonWalletStorageError
+import org.hyperledger.identus.agent.walletapi.util.KeyResolver
+import org.hyperledger.identus.castor.core.model.did.PrismDIDOperation
+import org.hyperledger.identus.castor.core.model.did.ScheduleDIDOperationOutcome
+import org.hyperledger.identus.castor.core.model.did.SignedPrismDIDOperation
+import org.hyperledger.identus.castor.core.model.error.DIDOperationError
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.shared.crypto.Secp256k1KeyPair
+import org.hyperledger.identus.shared.models.WalletAccessContext
import scala.collection.immutable.ArraySeq
import scala.language.implicitConversions
import zio.*
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/EntityRepository.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/EntityRepository.scala
similarity index 94%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/EntityRepository.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/EntityRepository.scala
index 8c9082f639..073526e55e 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/EntityRepository.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/EntityRepository.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.agent.walletapi.sql
+package org.hyperledger.identus.agent.walletapi.sql
import io.getquill.*
import io.getquill.doobie.DoobieContext
import io.getquill.idiom.*
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError
import zio.{IO, ZIO}
import java.time.Instant
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala
similarity index 96%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala
index 8ec4b39311..efaaea1d36 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcDIDNonSecretStorage.scala
@@ -1,21 +1,21 @@
-package io.iohk.atala.agent.walletapi.sql
+package org.hyperledger.identus.agent.walletapi.sql
import doobie.*
import doobie.implicits.*
import doobie.postgres.implicits.*
-import io.iohk.atala.agent.walletapi.model.*
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.castor.core.model.did.{
+import org.hyperledger.identus.agent.walletapi.model.*
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.castor.core.model.did.{
EllipticCurve,
InternalKeyPurpose,
PrismDID,
ScheduledDIDOperationStatus,
VerificationRelationship
}
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.{*, given}
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.{*, given}
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import zio.interop.catz.*
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcDIDSecretStorage.scala
similarity index 85%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcDIDSecretStorage.scala
index dfba408e2e..75a3ff77d3 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcDIDSecretStorage.scala
@@ -1,17 +1,17 @@
-package io.iohk.atala.agent.walletapi.sql
+package org.hyperledger.identus.agent.walletapi.sql
import com.nimbusds.jose.jwk.OctetKeyPair
import doobie.*
import doobie.implicits.*
import doobie.postgres.implicits.*
-import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.crypto.jwk.FromJWK
-import io.iohk.atala.shared.crypto.jwk.JWK
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.storage.DIDSecretStorage
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+import org.hyperledger.identus.shared.crypto.jwk.FromJWK
+import org.hyperledger.identus.shared.crypto.jwk.JWK
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.time.Instant
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcEntityRepository.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcEntityRepository.scala
similarity index 93%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcEntityRepository.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcEntityRepository.scala
index 6420f7f0e0..d67f250096 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcEntityRepository.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcEntityRepository.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.agent.walletapi.sql
+package org.hyperledger.identus.agent.walletapi.sql
import doobie.*
import doobie.implicits.*
-import io.iohk.atala.agent.walletapi.model.Entity
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError.{
+import org.hyperledger.identus.agent.walletapi.model.Entity
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError.{
EntityAlreadyExists,
EntityNotFound,
EntityStorageError,
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcGenericSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcGenericSecretStorage.scala
similarity index 80%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcGenericSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcGenericSecretStorage.scala
index e67756911a..bb828565b1 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcGenericSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcGenericSecretStorage.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.agent.walletapi.sql
+package org.hyperledger.identus.agent.walletapi.sql
import doobie.*
import doobie.implicits.*
import doobie.postgres.implicits.*
-import io.iohk.atala.agent.walletapi.storage.GenericSecret
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecret
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.json.ast.Json
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcWalletNonSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcWalletNonSecretStorage.scala
similarity index 88%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcWalletNonSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcWalletNonSecretStorage.scala
index d760776156..645d716408 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcWalletNonSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcWalletNonSecretStorage.scala
@@ -1,20 +1,20 @@
-package io.iohk.atala.agent.walletapi.sql
+package org.hyperledger.identus.agent.walletapi.sql
import cats.implicits.*
import doobie.*
import doobie.implicits.*
import doobie.postgres.implicits.*
import doobie.util.transactor.Transactor
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletNonSecretStorage.MAX_WEBHOOK_PER_WALLET
-import io.iohk.atala.agent.walletapi.storage.WalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.storage.WalletNonSecretStorageError
-import io.iohk.atala.agent.walletapi.storage.WalletNonSecretStorageError.TooManyWebhook
-import io.iohk.atala.event.notification.EventNotificationConfig
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.{*, given}
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletNonSecretStorage.MAX_WEBHOOK_PER_WALLET
+import org.hyperledger.identus.agent.walletapi.storage.WalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.WalletNonSecretStorageError
+import org.hyperledger.identus.agent.walletapi.storage.WalletNonSecretStorageError.TooManyWebhook
+import org.hyperledger.identus.event.notification.EventNotificationConfig
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.{*, given}
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import java.net.URL
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcWalletSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcWalletSecretStorage.scala
similarity index 77%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcWalletSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcWalletSecretStorage.scala
index 8fdcac36aa..eee2225312 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcWalletSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcWalletSecretStorage.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.agent.walletapi.sql
+package org.hyperledger.identus.agent.walletapi.sql
import doobie.*
import doobie.implicits.*
import doobie.postgres.implicits.*
import doobie.util.transactor.Transactor
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.{*, given}
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.{*, given}
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import java.time.Instant
import zio.*
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/package.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/package.scala
similarity index 92%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/package.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/package.scala
index b1330ecd6c..aa0cd77a42 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/package.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/package.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.agent.walletapi
+package org.hyperledger.identus.agent.walletapi
import com.nimbusds.jose.jwk.OctetKeyPair
import doobie.*
@@ -7,17 +7,17 @@ import doobie.util.invariant.InvalidEnum
import io.circe.*
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.model.{ManagedDIDState, PublicationState, KeyManagementMode}
-import io.iohk.atala.castor.core.model.ProtoModelHelper.*
-import io.iohk.atala.castor.core.model.did.EllipticCurve
-import io.iohk.atala.castor.core.model.did.InternalKeyPurpose
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.castor.core.model.did.{PrismDID, PrismDIDOperation, ScheduledDIDOperationStatus}
-import io.iohk.atala.event.notification.EventNotificationConfig
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.model.{ManagedDIDState, PublicationState, KeyManagementMode}
+import org.hyperledger.identus.castor.core.model.ProtoModelHelper.*
+import org.hyperledger.identus.castor.core.model.did.EllipticCurve
+import org.hyperledger.identus.castor.core.model.did.InternalKeyPurpose
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.castor.core.model.did.{PrismDID, PrismDIDOperation, ScheduledDIDOperationStatus}
+import org.hyperledger.identus.event.notification.EventNotificationConfig
import io.iohk.atala.prism.protos.node_models
-import io.iohk.atala.shared.crypto.jwk.JWK
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.crypto.jwk.JWK
+import org.hyperledger.identus.shared.models.WalletId
import zio.json.*
import zio.json.ast.Json
import zio.json.ast.Json.*
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDNonSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDNonSecretStorage.scala
similarity index 84%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDNonSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDNonSecretStorage.scala
index 91a0106567..a4abb78c33 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDNonSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDNonSecretStorage.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.agent.walletapi.storage
+package org.hyperledger.identus.agent.walletapi.storage
-import io.iohk.atala.agent.walletapi.model.*
-import io.iohk.atala.castor.core.model.did.{PrismDID, ScheduledDIDOperationStatus}
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.*
+import org.hyperledger.identus.castor.core.model.did.{PrismDID, ScheduledDIDOperationStatus}
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import scala.collection.immutable.ArraySeq
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDSecretStorage.scala
similarity index 65%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDSecretStorage.scala
index 52f84e3ed1..f9835c0d04 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDSecretStorage.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.agent.walletapi.storage
+package org.hyperledger.identus.agent.walletapi.storage
import com.nimbusds.jose.jwk.OctetKeyPair
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.crypto.jwk.FromJWK
-import io.iohk.atala.shared.crypto.jwk.JWK
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+import org.hyperledger.identus.shared.crypto.jwk.FromJWK
+import org.hyperledger.identus.shared.crypto.jwk.JWK
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
/** A simple single-user DID key storage */
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/GenericSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/GenericSecretStorage.scala
similarity index 77%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/GenericSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/GenericSecretStorage.scala
index 28b29d2612..8a2ec07201 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/GenericSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/GenericSecretStorage.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.agent.walletapi.storage
+package org.hyperledger.identus.agent.walletapi.storage
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.json.ast.Json
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/WalletNonSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/WalletNonSecretStorage.scala
similarity index 86%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/WalletNonSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/WalletNonSecretStorage.scala
index 7c48f4f506..c0cbda6d72 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/WalletNonSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/WalletNonSecretStorage.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.agent.walletapi.storage
+package org.hyperledger.identus.agent.walletapi.storage
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.event.notification.EventNotificationConfig
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.event.notification.EventNotificationConfig
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import org.postgresql.util.PSQLException
import zio.*
diff --git a/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/WalletSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/WalletSecretStorage.scala
new file mode 100644
index 0000000000..4121868293
--- /dev/null
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/WalletSecretStorage.scala
@@ -0,0 +1,10 @@
+package org.hyperledger.identus.agent.walletapi.storage
+
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import zio.*
+
+trait WalletSecretStorage {
+ def setWalletSeed(seed: WalletSeed): RIO[WalletAccessContext, Unit]
+ def getWalletSeed: RIO[WalletAccessContext, Option[WalletSeed]]
+}
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/KeyResolver.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/KeyResolver.scala
similarity index 60%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/KeyResolver.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/KeyResolver.scala
index 487060a96b..a8a033db8c 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/KeyResolver.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/KeyResolver.scala
@@ -1,19 +1,19 @@
-package io.iohk.atala.agent.walletapi.util
+package org.hyperledger.identus.agent.walletapi.util
-import io.iohk.atala.agent.walletapi.model.ManagedDIDHdKeyPath
-import io.iohk.atala.agent.walletapi.model.ManagedDIDKeyMeta
-import io.iohk.atala.agent.walletapi.model.ManagedDIDRandKeyMeta
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage
-import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.castor.core.model.did.EllipticCurve
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.crypto.Ed25519KeyPair
-import io.iohk.atala.shared.crypto.Secp256k1KeyPair
-import io.iohk.atala.shared.crypto.X25519KeyPair
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDHdKeyPath
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDKeyMeta
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDRandKeyMeta
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.storage.DIDNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.DIDSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.castor.core.model.did.EllipticCurve
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.crypto.Ed25519KeyPair
+import org.hyperledger.identus.shared.crypto.Secp256k1KeyPair
+import org.hyperledger.identus.shared.crypto.X25519KeyPair
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
class KeyResolver(
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidator.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/ManagedDIDTemplateValidator.scala
similarity index 81%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidator.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/ManagedDIDTemplateValidator.scala
index 93c7ffe99a..daa24fd415 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidator.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/ManagedDIDTemplateValidator.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.agent.walletapi.util
+package org.hyperledger.identus.agent.walletapi.util
-import io.iohk.atala.agent.walletapi.model.ManagedDIDTemplate
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.castor.core.model.did.EllipticCurve
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDTemplate
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.castor.core.model.did.EllipticCurve
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
object ManagedDIDTemplateValidator {
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/OperationFactory.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactory.scala
similarity index 95%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/OperationFactory.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactory.scala
index e94cb31582..2973014bf3 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/OperationFactory.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactory.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.agent.walletapi.util
+package org.hyperledger.identus.agent.walletapi.util
-import io.iohk.atala.agent.walletapi.model.*
-import io.iohk.atala.agent.walletapi.model.error.{CreateManagedDIDError, UpdateManagedDIDError}
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.shared.crypto.{
+import org.hyperledger.identus.agent.walletapi.model.*
+import org.hyperledger.identus.agent.walletapi.model.error.{CreateManagedDIDError, UpdateManagedDIDError}
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.shared.crypto.{
Apollo,
Ed25519KeyPair,
Ed25519PublicKey,
@@ -12,7 +12,7 @@ import io.iohk.atala.shared.crypto.{
X25519KeyPair,
X25519PublicKey
}
-import io.iohk.atala.shared.models.Base64UrlString
+import org.hyperledger.identus.shared.models.Base64UrlString
import zio.*
import scala.collection.immutable.ArraySeq
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/UpdateManagedDIDActionValidator.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/UpdateManagedDIDActionValidator.scala
similarity index 82%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/UpdateManagedDIDActionValidator.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/UpdateManagedDIDActionValidator.scala
index 4428238293..28027f0cdf 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/UpdateManagedDIDActionValidator.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/UpdateManagedDIDActionValidator.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.agent.walletapi.util
+package org.hyperledger.identus.agent.walletapi.util
-import io.iohk.atala.agent.walletapi.model.UpdateManagedDIDAction
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.agent.walletapi.model.UpdateManagedDIDAction
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
object UpdateManagedDIDActionValidator {
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultClient.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultClient.scala
similarity index 99%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultClient.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultClient.scala
index 74d1011534..5f2d8a9948 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultClient.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultClient.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.agent.walletapi.vault
+package org.hyperledger.identus.agent.walletapi.vault
import io.github.jopenlibs.vault.Vault
import io.github.jopenlibs.vault.VaultConfig
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultDIDSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultDIDSecretStorage.scala
similarity index 87%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultDIDSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultDIDSecretStorage.scala
index 27ce96f99d..a334f0ac34 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultDIDSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultDIDSecretStorage.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.agent.walletapi.vault
+package org.hyperledger.identus.agent.walletapi.vault
import com.nimbusds.jose.jwk.OctetKeyPair
-import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.mercury.model.DidId
+import org.hyperledger.identus.agent.walletapi.storage.DIDSecretStorage
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.castor.core.model.did.PrismDID
import io.iohk.atala.prism.crypto.Sha256
-import io.iohk.atala.shared.crypto.jwk.FromJWK
-import io.iohk.atala.shared.crypto.jwk.JWK
-import io.iohk.atala.shared.models.HexString
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.crypto.jwk.FromJWK
+import org.hyperledger.identus.shared.crypto.jwk.JWK
+import org.hyperledger.identus.shared.models.HexString
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import java.nio.charset.StandardCharsets
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultGenericSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultGenericSecretStorage.scala
similarity index 86%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultGenericSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultGenericSecretStorage.scala
index fec9d1870c..268c0eb4e9 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultGenericSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultGenericSecretStorage.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.agent.walletapi.vault
+package org.hyperledger.identus.agent.walletapi.vault
-import io.iohk.atala.agent.walletapi.storage.GenericSecret
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecret
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
import io.iohk.atala.prism.crypto.Sha256
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import zio.json.ast.Json
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultWalletSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultWalletSecretStorage.scala
similarity index 77%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultWalletSecretStorage.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultWalletSecretStorage.scala
index b7b53b58ec..561080afaa 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultWalletSecretStorage.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultWalletSecretStorage.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.agent.walletapi.vault
+package org.hyperledger.identus.agent.walletapi.vault
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
class VaultWalletSecretStorage(vaultKV: VaultKVClient) extends WalletSecretStorage {
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/package.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/package.scala
similarity index 89%
rename from prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/package.scala
rename to cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/package.scala
index 3b5822a0dd..4f0c861ce4 100644
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/package.scala
+++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/package.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.agent.walletapi
+package org.hyperledger.identus.agent.walletapi
import com.nimbusds.jose.jwk.OctetKeyPair
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.shared.crypto.jwk.JWK
-import io.iohk.atala.shared.models.HexString
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.shared.crypto.jwk.JWK
+import org.hyperledger.identus.shared.models.HexString
+import org.hyperledger.identus.shared.models.WalletId
import zio.json.*
import zio.json.ast.Json
import zio.json.ast.Json.*
diff --git a/prism-agent/service/wallet-api/src/test/resources/logback.xml b/cloud-agent/service/wallet-api/src/test/resources/logback.xml
similarity index 100%
rename from prism-agent/service/wallet-api/src/test/resources/logback.xml
rename to cloud-agent/service/wallet-api/src/test/resources/logback.xml
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/benchmark/KeyDerivation.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/benchmark/KeyDerivation.scala
similarity index 89%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/benchmark/KeyDerivation.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/benchmark/KeyDerivation.scala
index 981b934fad..7ab8e40e02 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/benchmark/KeyDerivation.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/benchmark/KeyDerivation.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.agent.walletapi.benchmark
+package org.hyperledger.identus.agent.walletapi.benchmark
-import io.iohk.atala.agent.walletapi.vault.KVCodec
-import io.iohk.atala.agent.walletapi.vault.VaultKVClient
-import io.iohk.atala.shared.crypto.Apollo
-import io.iohk.atala.shared.crypto.DerivationPath
-import io.iohk.atala.shared.crypto.Secp256k1PrivateKey
-import io.iohk.atala.shared.models.Base64UrlString
-import io.iohk.atala.shared.models.HexString
-import io.iohk.atala.test.container.VaultTestContainerSupport
+import org.hyperledger.identus.agent.walletapi.vault.KVCodec
+import org.hyperledger.identus.agent.walletapi.vault.VaultKVClient
+import org.hyperledger.identus.shared.crypto.Apollo
+import org.hyperledger.identus.shared.crypto.DerivationPath
+import org.hyperledger.identus.shared.crypto.Secp256k1PrivateKey
+import org.hyperledger.identus.shared.models.Base64UrlString
+import org.hyperledger.identus.shared.models.HexString
+import org.hyperledger.identus.test.container.VaultTestContainerSupport
import scala.util.Try
import zio.*
import zio.test.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceSpec.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceSpec.scala
similarity index 96%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceSpec.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceSpec.scala
index 5ffc724abf..c819cc0f2e 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/ManagedDIDServiceSpec.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceSpec.scala
@@ -1,24 +1,24 @@
-package io.iohk.atala.agent.walletapi.service
+package org.hyperledger.identus.agent.walletapi.service
-import io.iohk.atala.agent.walletapi.model.*
-import io.iohk.atala.agent.walletapi.model.error.{
+import org.hyperledger.identus.agent.walletapi.model.*
+import org.hyperledger.identus.agent.walletapi.model.error.{
CreateManagedDIDError,
DIDSecretStorageError,
PublishManagedDIDError,
UpdateManagedDIDError
}
-import io.iohk.atala.agent.walletapi.sql.*
-import io.iohk.atala.agent.walletapi.storage.*
-import io.iohk.atala.agent.walletapi.vault.{VaultDIDSecretStorage, VaultWalletSecretStorage}
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.castor.core.model.error
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.castor.core.util.DIDOperationValidator
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.{DBTestUtils, VaultTestContainerSupport}
+import org.hyperledger.identus.agent.walletapi.sql.*
+import org.hyperledger.identus.agent.walletapi.storage.*
+import org.hyperledger.identus.agent.walletapi.vault.{VaultDIDSecretStorage, VaultWalletSecretStorage}
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.castor.core.model.error
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.castor.core.util.DIDOperationValidator
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.{DBTestUtils, VaultTestContainerSupport}
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/WalletManagementServiceSpec.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/service/WalletManagementServiceSpec.scala
similarity index 87%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/WalletManagementServiceSpec.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/service/WalletManagementServiceSpec.scala
index 60d18eed1c..86e03e86ff 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/service/WalletManagementServiceSpec.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/service/WalletManagementServiceSpec.scala
@@ -1,20 +1,20 @@
-package io.iohk.atala.agent.walletapi.service
+package org.hyperledger.identus.agent.walletapi.service
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceError.DuplicatedWalletSeed
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceError.TooManyPermittedWallet
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletSecretStorage
-import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage
-import io.iohk.atala.agent.walletapi.vault.VaultWalletSecretStorage
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.shared.models.WalletId
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.DBTestUtils
-import io.iohk.atala.test.container.VaultTestContainerSupport
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementServiceError.DuplicatedWalletSeed
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementServiceError.TooManyPermittedWallet
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.WalletSecretStorage
+import org.hyperledger.identus.agent.walletapi.vault.VaultWalletSecretStorage
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.shared.models.WalletId
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.DBTestUtils
+import org.hyperledger.identus.test.container.VaultTestContainerSupport
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorageSpec.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/DIDSecretStorageSpec.scala
similarity index 89%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorageSpec.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/DIDSecretStorageSpec.scala
index 974c885f12..b72d982e99 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorageSpec.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/DIDSecretStorageSpec.scala
@@ -1,20 +1,20 @@
-package io.iohk.atala.agent.walletapi.storage
+package org.hyperledger.identus.agent.walletapi.storage
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.service.{WalletManagementService, WalletManagementServiceImpl}
-import io.iohk.atala.agent.walletapi.sql.{
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.service.{WalletManagementService, WalletManagementServiceImpl}
+import org.hyperledger.identus.agent.walletapi.sql.{
JdbcDIDNonSecretStorage,
JdbcDIDSecretStorage,
JdbcWalletNonSecretStorage,
JdbcWalletSecretStorage
}
-import io.iohk.atala.agent.walletapi.vault.{VaultDIDSecretStorage, VaultWalletSecretStorage}
-import io.iohk.atala.mercury.PeerDID
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.{DBTestUtils, VaultTestContainerSupport}
+import org.hyperledger.identus.agent.walletapi.vault.{VaultDIDSecretStorage, VaultWalletSecretStorage}
+import org.hyperledger.identus.mercury.PeerDID
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.{DBTestUtils, VaultTestContainerSupport}
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/GenericSecretStorageSpec.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/GenericSecretStorageSpec.scala
similarity index 87%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/GenericSecretStorageSpec.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/GenericSecretStorageSpec.scala
index 51a564d3e2..2b7e95a142 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/GenericSecretStorageSpec.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/GenericSecretStorageSpec.scala
@@ -1,15 +1,19 @@
-package io.iohk.atala.agent.walletapi.storage
-
-import io.iohk.atala.agent.walletapi.memory.GenericSecretStorageInMemory
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.service.{WalletManagementService, WalletManagementServiceImpl}
-import io.iohk.atala.agent.walletapi.sql.{JdbcGenericSecretStorage, JdbcWalletNonSecretStorage, JdbcWalletSecretStorage}
-import io.iohk.atala.agent.walletapi.vault.{VaultGenericSecretStorage, VaultWalletSecretStorage}
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.{DBTestUtils, VaultTestContainerSupport}
+package org.hyperledger.identus.agent.walletapi.storage
+
+import org.hyperledger.identus.agent.walletapi.memory.GenericSecretStorageInMemory
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.service.{WalletManagementService, WalletManagementServiceImpl}
+import org.hyperledger.identus.agent.walletapi.sql.{
+ JdbcGenericSecretStorage,
+ JdbcWalletNonSecretStorage,
+ JdbcWalletSecretStorage
+}
+import org.hyperledger.identus.agent.walletapi.vault.{VaultGenericSecretStorage, VaultWalletSecretStorage}
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.{DBTestUtils, VaultTestContainerSupport}
import zio.*
import zio.json.ast.Json
import zio.test.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcEntityRepositorySpec.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/JdbcEntityRepositorySpec.scala
similarity index 93%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcEntityRepositorySpec.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/JdbcEntityRepositorySpec.scala
index a1da66a1fa..8ab2904559 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcEntityRepositorySpec.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/JdbcEntityRepositorySpec.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.agent.walletapi.storage
+package org.hyperledger.identus.agent.walletapi.storage
-import io.iohk.atala.agent.walletapi.model.error.EntityServiceError.{
+import org.hyperledger.identus.agent.walletapi.model.error.EntityServiceError.{
EntityAlreadyExists,
EntityNotFound,
EntityWalletNotFound
}
-import io.iohk.atala.agent.walletapi.model.{Entity, Wallet}
-import io.iohk.atala.agent.walletapi.sql.{EntityRepository, JdbcEntityRepository, JdbcWalletNonSecretStorage}
-import io.iohk.atala.shared.models.WalletId
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.DBTestUtils
+import org.hyperledger.identus.agent.walletapi.model.{Entity, Wallet}
+import org.hyperledger.identus.agent.walletapi.sql.{EntityRepository, JdbcEntityRepository, JdbcWalletNonSecretStorage}
+import org.hyperledger.identus.shared.models.WalletId
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.DBTestUtils
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcWalletNonSecretStorageSpec.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/JdbcWalletNonSecretStorageSpec.scala
similarity index 90%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcWalletNonSecretStorageSpec.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/JdbcWalletNonSecretStorageSpec.scala
index b23ad0a2c6..e112843b3d 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcWalletNonSecretStorageSpec.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/JdbcWalletNonSecretStorageSpec.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.agent.walletapi.storage
+package org.hyperledger.identus.agent.walletapi.storage
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.storage.WalletNonSecretStorageError.TooManyWebhook
-import io.iohk.atala.agent.walletapi.storage.WalletNonSecretStorageError.DuplicatedWalletId
-import io.iohk.atala.agent.walletapi.storage.WalletNonSecretStorageError.DuplicatedWalletSeed
-import io.iohk.atala.event.notification.EventNotificationConfig
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.DBTestUtils
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.storage.WalletNonSecretStorageError.TooManyWebhook
+import org.hyperledger.identus.agent.walletapi.storage.WalletNonSecretStorageError.DuplicatedWalletId
+import org.hyperledger.identus.agent.walletapi.storage.WalletNonSecretStorageError.DuplicatedWalletSeed
+import org.hyperledger.identus.event.notification.EventNotificationConfig
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.DBTestUtils
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/StorageSpecHelper.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/StorageSpecHelper.scala
similarity index 65%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/StorageSpecHelper.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/StorageSpecHelper.scala
index 1670b6b1e1..8e4b5fde56 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/StorageSpecHelper.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/StorageSpecHelper.scala
@@ -1,21 +1,21 @@
-package io.iohk.atala.agent.walletapi.storage
+package org.hyperledger.identus.agent.walletapi.storage
-import io.iohk.atala.agent.walletapi.model.DIDPublicKeyTemplate
-import io.iohk.atala.agent.walletapi.model.DIDUpdateLineage
-import io.iohk.atala.agent.walletapi.model.ManagedDIDState
-import io.iohk.atala.agent.walletapi.model.ManagedDIDTemplate
-import io.iohk.atala.agent.walletapi.model.PublicationState
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.agent.walletapi.util.OperationFactory
-import io.iohk.atala.castor.core.model.did.EllipticCurve
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.castor.core.model.did.PrismDIDOperation
-import io.iohk.atala.castor.core.model.did.ScheduledDIDOperationStatus
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletAdministrationContext
+import org.hyperledger.identus.agent.walletapi.model.DIDPublicKeyTemplate
+import org.hyperledger.identus.agent.walletapi.model.DIDUpdateLineage
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDState
+import org.hyperledger.identus.agent.walletapi.model.ManagedDIDTemplate
+import org.hyperledger.identus.agent.walletapi.model.PublicationState
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.service.WalletManagementService
+import org.hyperledger.identus.agent.walletapi.util.OperationFactory
+import org.hyperledger.identus.castor.core.model.did.EllipticCurve
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+import org.hyperledger.identus.castor.core.model.did.PrismDIDOperation
+import org.hyperledger.identus.castor.core.model.did.ScheduledDIDOperationStatus
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAdministrationContext
import zio.*
import zio.test.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/WalletSecretStorageSpec.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/WalletSecretStorageSpec.scala
similarity index 79%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/WalletSecretStorageSpec.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/WalletSecretStorageSpec.scala
index d913d1dea9..de3c005a71 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/WalletSecretStorageSpec.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/storage/WalletSecretStorageSpec.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.agent.walletapi.storage
+package org.hyperledger.identus.agent.walletapi.storage
-import io.iohk.atala.agent.walletapi.model.Wallet
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletSecretStorage
-import io.iohk.atala.agent.walletapi.vault.VaultWalletSecretStorage
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.DBTestUtils
-import io.iohk.atala.test.container.VaultTestContainerSupport
+import org.hyperledger.identus.agent.walletapi.model.Wallet
+import org.hyperledger.identus.agent.walletapi.model.WalletSeed
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletNonSecretStorage
+import org.hyperledger.identus.agent.walletapi.sql.JdbcWalletSecretStorage
+import org.hyperledger.identus.agent.walletapi.vault.VaultWalletSecretStorage
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.DBTestUtils
+import org.hyperledger.identus.test.container.VaultTestContainerSupport
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala
similarity index 72%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala
index f8bfb61541..37e0d343be 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/util/ManagedDIDTemplateValidatorSpec.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.agent.walletapi.util
+package org.hyperledger.identus.agent.walletapi.util
-import io.iohk.atala.agent.walletapi.model.{DIDPublicKeyTemplate, ManagedDIDTemplate}
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.castor.core.model.did.EllipticCurve
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
-import io.iohk.atala.castor.core.model.did.ServiceEndpoint.UriValue
-import io.iohk.atala.castor.core.model.did.{Service, ServiceType, VerificationRelationship}
+import org.hyperledger.identus.agent.walletapi.model.{DIDPublicKeyTemplate, ManagedDIDTemplate}
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.castor.core.model.did.EllipticCurve
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint.UriOrJsonEndpoint
+import org.hyperledger.identus.castor.core.model.did.ServiceEndpoint.UriValue
+import org.hyperledger.identus.castor.core.model.did.{Service, ServiceType, VerificationRelationship}
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/OperationFactorySpec.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactorySpec.scala
similarity index 95%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/OperationFactorySpec.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactorySpec.scala
index 4e9f684160..6e28f86376 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/util/OperationFactorySpec.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactorySpec.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.agent.walletapi.util
+package org.hyperledger.identus.agent.walletapi.util
-import io.iohk.atala.agent.walletapi.model.*
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.HexString
+import org.hyperledger.identus.agent.walletapi.model.*
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.shared.crypto.ApolloSpecHelper
+import org.hyperledger.identus.shared.models.HexString
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/test/container/DBTestUtils.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/test/container/DBTestUtils.scala
similarity index 95%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/test/container/DBTestUtils.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/test/container/DBTestUtils.scala
index c50b700eba..6a6d4da18b 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/test/container/DBTestUtils.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/test/container/DBTestUtils.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.test.container
+package org.hyperledger.identus.test.container
import com.dimafeng.testcontainers.PostgreSQLContainer
import org.flywaydb.core.Flyway
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/test/container/VaultLayer.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/test/container/VaultLayer.scala
similarity index 76%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/test/container/VaultLayer.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/test/container/VaultLayer.scala
index bbbbc4d508..7c539c463b 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/test/container/VaultLayer.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/test/container/VaultLayer.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.test.container
+package org.hyperledger.identus.test.container
import zio.*
-import io.iohk.atala.sharedtest.containers.VaultTestContainer
-import io.iohk.atala.sharedtest.containers.VaultContainerCustom
+import org.hyperledger.identus.sharedtest.containers.VaultTestContainer
+import org.hyperledger.identus.sharedtest.containers.VaultContainerCustom
object VaultLayer {
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/test/container/VaultTestContainerSupport.scala b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/test/container/VaultTestContainerSupport.scala
similarity index 71%
rename from prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/test/container/VaultTestContainerSupport.scala
rename to cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/test/container/VaultTestContainerSupport.scala
index 03447a1dbd..b4e9111c5f 100644
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/test/container/VaultTestContainerSupport.scala
+++ b/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/test/container/VaultTestContainerSupport.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.test.container
+package org.hyperledger.identus.test.container
-import io.iohk.atala.agent.walletapi.vault.VaultKVClient
-import io.iohk.atala.agent.walletapi.vault.VaultKVClientImpl
-import io.iohk.atala.sharedtest.containers.VaultContainerCustom
+import org.hyperledger.identus.agent.walletapi.vault.VaultKVClient
+import org.hyperledger.identus.agent.walletapi.vault.VaultKVClientImpl
+import org.hyperledger.identus.sharedtest.containers.VaultContainerCustom
import zio.*
import zio.http.Client
diff --git a/connect/lib/CHANGELOG.md b/connect/CHANGELOG.md
similarity index 100%
rename from connect/lib/CHANGELOG.md
rename to connect/CHANGELOG.md
diff --git a/connect/lib/README.md b/connect/README.md
similarity index 100%
rename from connect/lib/README.md
rename to connect/README.md
diff --git a/connect/lib/connect-protocol-state.md b/connect/connect-protocol-state.md
similarity index 100%
rename from connect/lib/connect-protocol-state.md
rename to connect/connect-protocol-state.md
diff --git a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/model/ConnectionRecord.scala b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/model/ConnectionRecord.scala
similarity index 91%
rename from connect/lib/core/src/main/scala/io/iohk/atala/connect/core/model/ConnectionRecord.scala
rename to connect/core/src/main/scala/org/hyperledger/identus/connect/core/model/ConnectionRecord.scala
index 3a91d8ef26..d1e33be574 100644
--- a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/model/ConnectionRecord.scala
+++ b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/model/ConnectionRecord.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.connect.core.model
+package org.hyperledger.identus.connect.core.model
-import io.iohk.atala.connect.core.model.ConnectionRecord.{ProtocolState, Role}
-import io.iohk.atala.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.{ProtocolState, Role}
+import org.hyperledger.identus.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
import java.time.Instant
import java.time.temporal.ChronoUnit
diff --git a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/model/error/ConnectionServiceError.scala b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/model/error/ConnectionServiceError.scala
similarity index 90%
rename from connect/lib/core/src/main/scala/io/iohk/atala/connect/core/model/error/ConnectionServiceError.scala
rename to connect/core/src/main/scala/org/hyperledger/identus/connect/core/model/error/ConnectionServiceError.scala
index fb9bc514e7..f4a23b745b 100644
--- a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/model/error/ConnectionServiceError.scala
+++ b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/model/error/ConnectionServiceError.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.connect.core.model.error
+package org.hyperledger.identus.connect.core.model.error
-import io.iohk.atala.connect.core.model.ConnectionRecord.ProtocolState
-import io.iohk.atala.shared.models.{Failure, StatusCode}
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.ProtocolState
+import org.hyperledger.identus.shared.models.{Failure, StatusCode}
import zio.NonEmptyChunk
import java.util.UUID
diff --git a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/repository/ConnectionRepository.scala b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepository.scala
similarity index 82%
rename from connect/lib/core/src/main/scala/io/iohk/atala/connect/core/repository/ConnectionRepository.scala
rename to connect/core/src/main/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepository.scala
index 3ba6843bc8..121371700c 100644
--- a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/repository/ConnectionRepository.scala
+++ b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepository.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.connect.core.repository
+package org.hyperledger.identus.connect.core.repository
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.ConnectionRecord.ProtocolState
-import io.iohk.atala.mercury.protocol.connection.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.ProtocolState
+import org.hyperledger.identus.mercury.protocol.connection.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.UIO
import zio.URIO
diff --git a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/repository/ConnectionRepositoryInMemory.scala b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepositoryInMemory.scala
similarity index 93%
rename from connect/lib/core/src/main/scala/io/iohk/atala/connect/core/repository/ConnectionRepositoryInMemory.scala
rename to connect/core/src/main/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepositoryInMemory.scala
index f4f2f57142..b9415bc354 100644
--- a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/repository/ConnectionRepositoryInMemory.scala
+++ b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepositoryInMemory.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.connect.core.repository
-
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.ConnectionRecord.ProtocolState
-import io.iohk.atala.mercury.protocol.connection.ConnectionRequest
-import io.iohk.atala.mercury.protocol.connection.ConnectionResponse
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+package org.hyperledger.identus.connect.core.repository
+
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.ProtocolState
+import org.hyperledger.identus.mercury.protocol.connection.ConnectionRequest
+import org.hyperledger.identus.mercury.protocol.connection.ConnectionResponse
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import java.time.Instant
diff --git a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/ConnectionService.scala b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/ConnectionService.scala
similarity index 83%
rename from connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/ConnectionService.scala
rename to connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/ConnectionService.scala
index c68f751f8d..27d5c0eb1b 100644
--- a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/ConnectionService.scala
+++ b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/ConnectionService.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.connect.core.service
-
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError.*
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
-import io.iohk.atala.shared.models.WalletAccessContext
+package org.hyperledger.identus.connect.core.service
+
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError.*
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.time.Duration
diff --git a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/ConnectionServiceImpl.scala b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceImpl.scala
similarity index 92%
rename from connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/ConnectionServiceImpl.scala
rename to connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceImpl.scala
index d4132d7d65..175f16ec6a 100644
--- a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/ConnectionServiceImpl.scala
+++ b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceImpl.scala
@@ -1,23 +1,24 @@
-package io.iohk.atala.connect.core.service
+package org.hyperledger.identus.connect.core.service
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.ConnectionRecord.*
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError.*
-import io.iohk.atala.connect.core.repository.ConnectionRepository
-import io.iohk.atala.mercury.*
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.connection.*
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.utils.Base64Utils
-import io.iohk.atala.shared.utils.aspects.CustomMetricsAspect
-import io.iohk.atala.shared.validation.ValidationUtils
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.*
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError.*
+import org.hyperledger.identus.connect.core.repository.ConnectionRepository
+import org.hyperledger.identus.*
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.connection.*
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.utils.Base64Utils
+import org.hyperledger.identus.shared.utils.aspects.CustomMetricsAspect
+import org.hyperledger.identus.shared.validation.ValidationUtils
import zio.*
import zio.prelude.*
import java.time.{Duration, Instant}
import java.util.UUID
+
private class ConnectionServiceImpl(
connectionRepository: ConnectionRepository,
maxRetries: Int = 5, // TODO move to config
diff --git a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/ConnectionServiceNotifier.scala b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceNotifier.scala
similarity index 88%
rename from connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/ConnectionServiceNotifier.scala
rename to connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceNotifier.scala
index e6294cf85f..05ebead7b0 100644
--- a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/ConnectionServiceNotifier.scala
+++ b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceNotifier.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.connect.core.service
-
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError.*
-import io.iohk.atala.event.notification.{Event, EventNotificationService}
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
-import io.iohk.atala.shared.models.WalletAccessContext
+package org.hyperledger.identus.connect.core.service
+
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError.*
+import org.hyperledger.identus.event.notification.{Event, EventNotificationService}
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{UIO, URIO, URLayer, ZIO, ZLayer}
import java.time.Duration
diff --git a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/MockConnectionService.scala b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/MockConnectionService.scala
similarity index 91%
rename from connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/MockConnectionService.scala
rename to connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/MockConnectionService.scala
index b1eb81e1df..597460e992 100644
--- a/connect/lib/core/src/main/scala/io/iohk/atala/connect/core/service/MockConnectionService.scala
+++ b/connect/core/src/main/scala/org/hyperledger/identus/connect/core/service/MockConnectionService.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.connect.core.service
-
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError.*
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
-import io.iohk.atala.shared.models.WalletAccessContext
+package org.hyperledger.identus.connect.core.service
+
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError.*
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.mock.{Mock, Proxy}
import zio.{UIO, URIO, URLayer, ZIO, ZLayer, mock}
diff --git a/connect/lib/core/src/test/scala/io/iohk/atala/connect/core/repository/ConnectionRepositoryInMemorySpec.scala b/connect/core/src/test/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepositoryInMemorySpec.scala
similarity index 88%
rename from connect/lib/core/src/test/scala/io/iohk/atala/connect/core/repository/ConnectionRepositoryInMemorySpec.scala
rename to connect/core/src/test/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepositoryInMemorySpec.scala
index aeddbf6190..38751293bc 100644
--- a/connect/lib/core/src/test/scala/io/iohk/atala/connect/core/repository/ConnectionRepositoryInMemorySpec.scala
+++ b/connect/core/src/test/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepositoryInMemorySpec.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.connect.core.repository
+package org.hyperledger.identus.connect.core.repository
import zio.*
import zio.test.*
diff --git a/connect/lib/core/src/test/scala/io/iohk/atala/connect/core/repository/ConnectionRepositorySpecSuite.scala b/connect/core/src/test/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepositorySpecSuite.scala
similarity index 96%
rename from connect/lib/core/src/test/scala/io/iohk/atala/connect/core/repository/ConnectionRepositorySpecSuite.scala
rename to connect/core/src/test/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepositorySpecSuite.scala
index 12e4d9876f..4aa03b95ab 100644
--- a/connect/lib/core/src/test/scala/io/iohk/atala/connect/core/repository/ConnectionRepositorySpecSuite.scala
+++ b/connect/core/src/test/scala/org/hyperledger/identus/connect/core/repository/ConnectionRepositorySpecSuite.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.connect.core.repository
+package org.hyperledger.identus.connect.core.repository
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.ConnectionRecord.*
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.*
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.Exit.Failure
import zio.test.*
import zio.{Cause, Exit, ZIO, ZLayer}
@@ -33,7 +33,7 @@ object ConnectionRepositorySpecSuite {
from = DidId("did:prism:aaa"),
body = Invitation
.Body(
- goal_code = Some("io.atalaprism.connect"),
+ goal_code = Some("org.hyperledger.identus.connect"),
goal = Some("Establish a trust connection between two peers"),
Nil
)
@@ -50,7 +50,7 @@ object ConnectionRepositorySpecSuite {
to = DidId("did:prism:bbb"),
thid = None,
pthid = Some(UUID.randomUUID().toString),
- body = ConnectionRequest.Body(goal_code = Some("io.atalaprism.connect"))
+ body = ConnectionRequest.Body(goal_code = Some("org.hyperledger.identus.connect"))
)
val testSuite = suite("CRUD operations")(
diff --git a/connect/lib/core/src/test/scala/io/iohk/atala/connect/core/service/ConnectionServiceImplSpec.scala b/connect/core/src/test/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceImplSpec.scala
similarity index 95%
rename from connect/lib/core/src/test/scala/io/iohk/atala/connect/core/service/ConnectionServiceImplSpec.scala
rename to connect/core/src/test/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceImplSpec.scala
index af75f4f570..fca81c7a9a 100644
--- a/connect/lib/core/src/test/scala/io/iohk/atala/connect/core/service/ConnectionServiceImplSpec.scala
+++ b/connect/core/src/test/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceImplSpec.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.connect.core.service
+package org.hyperledger.identus.connect.core.service
import io.circe.syntax.*
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.ConnectionRecord.*
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError
-import io.iohk.atala.connect.core.model.error.ConnectionServiceError.InvalidStateForOperation
-import io.iohk.atala.connect.core.repository.ConnectionRepositoryInMemory
-import io.iohk.atala.mercury.model.{DidId, Message}
-import io.iohk.atala.mercury.protocol.connection.ConnectionResponse
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.*
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError
+import org.hyperledger.identus.connect.core.model.error.ConnectionServiceError.InvalidStateForOperation
+import org.hyperledger.identus.connect.core.repository.ConnectionRepositoryInMemory
+import org.hyperledger.identus.mercury.model.{DidId, Message}
+import org.hyperledger.identus.mercury.protocol.connection.ConnectionResponse
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/connect/lib/core/src/test/scala/io/iohk/atala/connect/core/service/ConnectionServiceNotifierSpec.scala b/connect/core/src/test/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceNotifierSpec.scala
similarity index 90%
rename from connect/lib/core/src/test/scala/io/iohk/atala/connect/core/service/ConnectionServiceNotifierSpec.scala
rename to connect/core/src/test/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceNotifierSpec.scala
index 957a8beb69..2f156b0114 100644
--- a/connect/lib/core/src/test/scala/io/iohk/atala/connect/core/service/ConnectionServiceNotifierSpec.scala
+++ b/connect/core/src/test/scala/org/hyperledger/identus/connect/core/service/ConnectionServiceNotifierSpec.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.connect.core.service
+package org.hyperledger.identus.connect.core.service
-import io.iohk.atala.connect.core.model.ConnectionRecord
-import io.iohk.atala.connect.core.model.ConnectionRecord.ProtocolState
-import io.iohk.atala.connect.core.repository.ConnectionRepositoryInMemory
-import io.iohk.atala.event.notification.*
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.connect.core.model.ConnectionRecord
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.ProtocolState
+import org.hyperledger.identus.connect.core.repository.ConnectionRepositoryInMemory
+import org.hyperledger.identus.event.notification.*
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.connection.{ConnectionRequest, ConnectionResponse}
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import zio.ZIO.*
import zio.mock.Expectation
diff --git a/connect/lib/sql-doobie/src/main/resources/sql/connect/V1__init_tables.sql b/connect/sql-doobie/src/main/resources/sql/connect/V1__init_tables.sql
similarity index 100%
rename from connect/lib/sql-doobie/src/main/resources/sql/connect/V1__init_tables.sql
rename to connect/sql-doobie/src/main/resources/sql/connect/V1__init_tables.sql
diff --git a/connect/lib/sql-doobie/src/main/resources/sql/connect/V2__add_thid_unique_constraint.sql b/connect/sql-doobie/src/main/resources/sql/connect/V2__add_thid_unique_constraint.sql
similarity index 100%
rename from connect/lib/sql-doobie/src/main/resources/sql/connect/V2__add_thid_unique_constraint.sql
rename to connect/sql-doobie/src/main/resources/sql/connect/V2__add_thid_unique_constraint.sql
diff --git a/connect/lib/sql-doobie/src/main/resources/sql/connect/V3__add_meta_retries_and_meta_last_failure.sql b/connect/sql-doobie/src/main/resources/sql/connect/V3__add_meta_retries_and_meta_last_failure.sql
similarity index 100%
rename from connect/lib/sql-doobie/src/main/resources/sql/connect/V3__add_meta_retries_and_meta_last_failure.sql
rename to connect/sql-doobie/src/main/resources/sql/connect/V3__add_meta_retries_and_meta_last_failure.sql
diff --git a/connect/lib/sql-doobie/src/main/resources/sql/connect/V4__create_protocol_state_index.sql b/connect/sql-doobie/src/main/resources/sql/connect/V4__create_protocol_state_index.sql
similarity index 100%
rename from connect/lib/sql-doobie/src/main/resources/sql/connect/V4__create_protocol_state_index.sql
rename to connect/sql-doobie/src/main/resources/sql/connect/V4__create_protocol_state_index.sql
diff --git a/connect/lib/sql-doobie/src/main/resources/sql/connect/V5__add_meta_next_retry.sql b/connect/sql-doobie/src/main/resources/sql/connect/V5__add_meta_next_retry.sql
similarity index 100%
rename from connect/lib/sql-doobie/src/main/resources/sql/connect/V5__add_meta_next_retry.sql
rename to connect/sql-doobie/src/main/resources/sql/connect/V5__add_meta_next_retry.sql
diff --git a/connect/lib/sql-doobie/src/main/resources/sql/connect/V6__add_rls_policy.sql b/connect/sql-doobie/src/main/resources/sql/connect/V6__add_rls_policy.sql
similarity index 100%
rename from connect/lib/sql-doobie/src/main/resources/sql/connect/V6__add_rls_policy.sql
rename to connect/sql-doobie/src/main/resources/sql/connect/V6__add_rls_policy.sql
diff --git a/connect/lib/sql-doobie/src/main/resources/sql/connect/V7__add_goal_and_goal_code.sql b/connect/sql-doobie/src/main/resources/sql/connect/V7__add_goal_and_goal_code.sql
similarity index 100%
rename from connect/lib/sql-doobie/src/main/resources/sql/connect/V7__add_goal_and_goal_code.sql
rename to connect/sql-doobie/src/main/resources/sql/connect/V7__add_goal_and_goal_code.sql
diff --git a/connect/lib/sql-doobie/src/main/scala/io/iohk/atala/connect/sql/repository/JdbcConnectionRepository.scala b/connect/sql-doobie/src/main/scala/org/hyperledger/identus/connect/sql/repository/JdbcConnectionRepository.scala
similarity index 94%
rename from connect/lib/sql-doobie/src/main/scala/io/iohk/atala/connect/sql/repository/JdbcConnectionRepository.scala
rename to connect/sql-doobie/src/main/scala/org/hyperledger/identus/connect/sql/repository/JdbcConnectionRepository.scala
index 0f76908f37..439df93062 100644
--- a/connect/lib/sql-doobie/src/main/scala/io/iohk/atala/connect/sql/repository/JdbcConnectionRepository.scala
+++ b/connect/sql-doobie/src/main/scala/org/hyperledger/identus/connect/sql/repository/JdbcConnectionRepository.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.connect.sql.repository
+package org.hyperledger.identus.connect.sql.repository
import cats.data.NonEmptyList
import doobie.*
@@ -8,14 +8,14 @@ import doobie.postgres.implicits.*
import io.circe.*
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.connect.core.model.*
-import io.iohk.atala.connect.core.model.ConnectionRecord.{ProtocolState, Role}
-import io.iohk.atala.connect.core.repository.ConnectionRepository
-import io.iohk.atala.mercury.protocol.connection.*
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.connect.core.model.*
+import org.hyperledger.identus.connect.core.model.ConnectionRecord.{ProtocolState, Role}
+import org.hyperledger.identus.connect.core.repository.ConnectionRepository
+import org.hyperledger.identus.mercury.protocol.connection.*
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.interop.catz.*
diff --git a/connect/lib/sql-doobie/src/main/scala/io/iohk/atala/connect/sql/repository/Migrations.scala b/connect/sql-doobie/src/main/scala/org/hyperledger/identus/connect/sql/repository/Migrations.scala
similarity index 89%
rename from connect/lib/sql-doobie/src/main/scala/io/iohk/atala/connect/sql/repository/Migrations.scala
rename to connect/sql-doobie/src/main/scala/org/hyperledger/identus/connect/sql/repository/Migrations.scala
index eeaf4dd70f..68f3051e15 100644
--- a/connect/lib/sql-doobie/src/main/scala/io/iohk/atala/connect/sql/repository/Migrations.scala
+++ b/connect/sql-doobie/src/main/scala/org/hyperledger/identus/connect/sql/repository/Migrations.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.connect.sql.repository
+package org.hyperledger.identus.connect.sql.repository
import doobie.*
import doobie.implicits.*
import doobie.util.transactor.Transactor
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.DbConfig
-import io.iohk.atala.shared.db.Implicits.*
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.DbConfig
+import org.hyperledger.identus.shared.db.Implicits.*
import org.flywaydb.core.Flyway
import zio.*
import zio.interop.catz.*
diff --git a/connect/lib/sql-doobie/src/test/resources/logback.xml b/connect/sql-doobie/src/test/resources/logback.xml
similarity index 100%
rename from connect/lib/sql-doobie/src/test/resources/logback.xml
rename to connect/sql-doobie/src/test/resources/logback.xml
diff --git a/connect/lib/sql-doobie/src/test/scala/io/iohk/atala/connect/sql/repository/JdbcConnectionRepositorySpec.scala b/connect/sql-doobie/src/test/scala/org/hyperledger/identus/connect/sql/repository/JdbcConnectionRepositorySpec.scala
similarity index 77%
rename from connect/lib/sql-doobie/src/test/scala/io/iohk/atala/connect/sql/repository/JdbcConnectionRepositorySpec.scala
rename to connect/sql-doobie/src/test/scala/org/hyperledger/identus/connect/sql/repository/JdbcConnectionRepositorySpec.scala
index 32e4d8d6f0..13d10d6663 100644
--- a/connect/lib/sql-doobie/src/test/scala/io/iohk/atala/connect/sql/repository/JdbcConnectionRepositorySpec.scala
+++ b/connect/sql-doobie/src/test/scala/org/hyperledger/identus/connect/sql/repository/JdbcConnectionRepositorySpec.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.connect.sql.repository
+package org.hyperledger.identus.connect.sql.repository
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.connect.core.repository.{ConnectionRepository, ConnectionRepositorySpecSuite}
-import io.iohk.atala.shared.db.DbConfig
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.connect.core.repository.{ConnectionRepository, ConnectionRepositorySpecSuite}
+import org.hyperledger.identus.shared.db.DbConfig
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
import zio.*
import zio.test.*
diff --git a/connect/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container/PostgresTestContainer.scala b/connect/sql-doobie/src/test/scala/org/hyperledger/identus/test/container/PostgresTestContainer.scala
similarity index 78%
rename from connect/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container/PostgresTestContainer.scala
rename to connect/sql-doobie/src/test/scala/org/hyperledger/identus/test/container/PostgresTestContainer.scala
index a3f74c949a..35f4fabac8 100644
--- a/connect/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container/PostgresTestContainer.scala
+++ b/connect/sql-doobie/src/test/scala/org/hyperledger/identus/test/container/PostgresTestContainer.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.test.container
+package org.hyperledger.identus.test.container
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.sharedtest.containers.PostgresTestContainer.postgresContainer
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainer.postgresContainer
import zio.*
import zio.ZIO.*
diff --git a/docs/decisions/20240116-use-zio-failures-and-defects-effectively.md b/docs/decisions/20240116-use-zio-failures-and-defects-effectively.md
index 15480799e9..20ef42cccf 100644
--- a/docs/decisions/20240116-use-zio-failures-and-defects-effectively.md
+++ b/docs/decisions/20240116-use-zio-failures-and-defects-effectively.md
@@ -392,7 +392,7 @@ prohibited ([example](https://github.com/hyperledger/identus-cloud-agent/blob/b5
#### Extend the common `Failure` trait
Make sure all service errors extend the shared
-trait [`io.iohk.atala.shared.models.Failure`](https://github.com/hyperledger/identus-cloud-agent/blob/main/shared/src/main/scala/io/iohk/atala/shared/models/Failure.scala).
+trait [`org.hyperledger.identus.shared.models.Failure`](https://github.com/hyperledger/identus-cloud-agent/blob/main/shared/src/main/scala/io/iohk/atala/shared/models/Failure.scala).
This allows handling "at the end of the world“ to be done in a consistent and in generic way.
Create an exhaustive and meaningful list of service errors and make sure the value of the `userFacingMessage` attribute
@@ -490,7 +490,7 @@ The upper layer will automatically do so appropriately and consistently using Ta
#### Reporting RFC-9457 Error Response
All declared Tapir endpoints must
-use [`io.iohk.atala.api.http.ErrorResponse`](https://github.com/hyperledger/identus-cloud-agent/blob/main/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/ErrorResponse.scala)
+use [`org.hyperledger.identus.api.http.ErrorResponse`](https://github.com/hyperledger/identus-cloud-agent/blob/main/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/ErrorResponse.scala)
as their output error
type ([example](https://github.com/hyperledger/identus-cloud-agent/blob/eb898e068f768507d6979a5d9bab35ef7ad4a045/prism-agent/service/server/src/main/scala/io/iohk/atala/connect/controller/ConnectionEndpoints.scala#L45))
This type ensures that the response returned to the user complies with
@@ -514,7 +514,7 @@ object ConnectionEndpoints {
If all the underlying services used by a controller comply with the above rules, then the only error type that could
propagate through the effect’s error channel is the
-parent [`io.iohk.atala.shared.models.Failure`](https://github.com/hyperledger/identus-cloud-agent/blob/main/shared/src/main/scala/io/iohk/atala/shared/models/Failure.scala)
+parent [`org.hyperledger.identus.shared.models.Failure`](https://github.com/hyperledger/identus-cloud-agent/blob/main/shared/src/main/scala/io/iohk/atala/shared/models/Failure.scala)
type and its conversion
to the ErrorResponse type is done automatically
via [Scala implicit conversion](https://github.com/hyperledger/identus-cloud-agent/blob/eb898e068f768507d6979a5d9bab35ef7ad4a045/prism-agent/service/server/src/main/scala/io/iohk/atala/api/http/ErrorResponse.scala#L44).
diff --git a/docs/general/key-derivation-benchmark.md b/docs/general/key-derivation-benchmark.md
index 64d331a970..b7cdc677b7 100644
--- a/docs/general/key-derivation-benchmark.md
+++ b/docs/general/key-derivation-benchmark.md
@@ -18,7 +18,7 @@ __System information__
__JVM options__
- Xmx:4G
-The tests can be run by running the `io.iohk.atala.agent.walletapi.benchmark.KeyDerivation`.
+The tests can be run by running the `org.hyperledger.identus.agent.walletapi.benchmark.KeyDerivation`.
The tests are being ignored to avoid running them on CI. When running locally,
the ignore aspect should be removed and the test can be run by
diff --git a/docs/guides/linting.md b/docs/guides/linting.md
index 4c347d530d..dc26ac5f23 100644
--- a/docs/guides/linting.md
+++ b/docs/guides/linting.md
@@ -128,19 +128,9 @@ Linter - Suggested Change: Customise
In /github/workspace/infrastructure/dev/get-versions.sh line 8:
- export PRISM_AGENT_VERSION=$(cd ../../prism-agent/service && sbt "project server" -Dsbt.supershell=false -error "print version")
+ export AGENT_VERSION=$(cd ../../prism-agent/service && sbt "project server" -Dsbt.supershell=false -error "print version")
^-----------------^ SC2155 (warning): Declare and assign separately to avoid masking return values.
-
- In /github/workspace/infrastructure/dev/get-versions.sh line 11:
- export MERCURY_MEDIATOR_VERSION=$(cd ../../mercury/mercury-mediator && sbt "project mediator" -Dsbt.supershell=false -error "print version")
- ^----------------------^ SC2155 (warning): Declare and assign separately to avoid masking return values.
-
-
- In /github/workspace/infrastructure/dev/get-versions.sh line 14:
- export IRIS_SERVICE_VERSION=$(cd ../../iris/service && sbt "project server" -Dsbt.supershell=false -error "print version")
- ^------------------^ SC2155 (warning): Declare and assign separately to avoid masking return values.
-
For more information:
https://www.shellcheck.net/wiki/SC2155 -- Declare and assign separately to ...
https://www.shellcheck.net/wiki/SC2164 -- Use 'cd ... || exit' or 'cd ... |...
diff --git a/event-notification/src/main/scala/io/iohk/atala/event/notification/Event.scala b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/Event.scala
similarity index 73%
rename from event-notification/src/main/scala/io/iohk/atala/event/notification/Event.scala
rename to event-notification/src/main/scala/org/hyperledger/identus/event/notification/Event.scala
index 1b2a255ad7..edeef57c6f 100644
--- a/event-notification/src/main/scala/io/iohk/atala/event/notification/Event.scala
+++ b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/Event.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.event.notification
+package org.hyperledger.identus.event.notification
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletId
import java.time.Instant
import java.util.UUID
diff --git a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventConsumer.scala b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventConsumer.scala
similarity index 68%
rename from event-notification/src/main/scala/io/iohk/atala/event/notification/EventConsumer.scala
rename to event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventConsumer.scala
index 3b65858bd5..77c3512b68 100644
--- a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventConsumer.scala
+++ b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventConsumer.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.event.notification
+package org.hyperledger.identus.event.notification
import zio.IO
diff --git a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationConfig.scala b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationConfig.scala
similarity index 87%
rename from event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationConfig.scala
rename to event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationConfig.scala
index 39ce4108c9..5837ec87d9 100644
--- a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationConfig.scala
+++ b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationConfig.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.event.notification
+package org.hyperledger.identus.event.notification
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import java.net.URL
diff --git a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationService.scala b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationService.scala
similarity index 81%
rename from event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationService.scala
rename to event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationService.scala
index e3f590faf5..72792f94c9 100644
--- a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationService.scala
+++ b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationService.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.event.notification
+package org.hyperledger.identus.event.notification
import zio.IO
diff --git a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationServiceError.scala b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationServiceError.scala
similarity index 76%
rename from event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationServiceError.scala
rename to event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationServiceError.scala
index abee167f41..23c8506ad4 100644
--- a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationServiceError.scala
+++ b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationServiceError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.event.notification
+package org.hyperledger.identus.event.notification
sealed trait EventNotificationServiceError
diff --git a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationServiceImpl.scala b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationServiceImpl.scala
similarity index 92%
rename from event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationServiceImpl.scala
rename to event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationServiceImpl.scala
index 55a138c8df..39450a2931 100644
--- a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventNotificationServiceImpl.scala
+++ b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventNotificationServiceImpl.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.event.notification
+package org.hyperledger.identus.event.notification
-import io.iohk.atala.event.notification.EventNotificationServiceError.EventSendingFailed
+import org.hyperledger.identus.event.notification.EventNotificationServiceError.EventSendingFailed
import zio.concurrent.ConcurrentMap
import zio.{IO, Queue, URLayer, ZIO, ZLayer}
diff --git a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventProducer.scala b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventProducer.scala
similarity index 68%
rename from event-notification/src/main/scala/io/iohk/atala/event/notification/EventProducer.scala
rename to event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventProducer.scala
index 9fec9c2f8d..4bb52e4154 100644
--- a/event-notification/src/main/scala/io/iohk/atala/event/notification/EventProducer.scala
+++ b/event-notification/src/main/scala/org/hyperledger/identus/event/notification/EventProducer.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.event.notification
+package org.hyperledger.identus.event.notification
import zio.IO
diff --git a/event-notification/src/test/scala/io/iohk/atala/event/notification/EventNotificationServiceImplSpec.scala b/event-notification/src/test/scala/org/hyperledger/identus/event/notification/EventNotificationServiceImplSpec.scala
similarity index 97%
rename from event-notification/src/test/scala/io/iohk/atala/event/notification/EventNotificationServiceImplSpec.scala
rename to event-notification/src/test/scala/org/hyperledger/identus/event/notification/EventNotificationServiceImplSpec.scala
index 8b7a215911..80bf5bf7db 100644
--- a/event-notification/src/test/scala/io/iohk/atala/event/notification/EventNotificationServiceImplSpec.scala
+++ b/event-notification/src/test/scala/org/hyperledger/identus/event/notification/EventNotificationServiceImplSpec.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.event.notification
+package org.hyperledger.identus.event.notification
import zio.*
import zio.test.*
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletId
object EventNotificationServiceImplSpec extends ZIOSpecDefault {
diff --git a/examples/readme.md b/examples/readme.md
index 302f6756ef..2344b5197c 100644
--- a/examples/readme.md
+++ b/examples/readme.md
@@ -1,5 +1,5 @@
# Examples of OpenAPI specifications
-This directory contains OpenAPI/Swagger specifications of Atala competitors.
+This directory contains OpenAPI/Swagger specifications of Identus competitors.
Not all the companies are real competitors, but number of them are experts in particular area, so we have a good opportunity to get inspiration and build a better solution.
### godiddy-api.yaml
diff --git a/infrastructure/ci/docker-compose-multiple-actors.yml b/infrastructure/ci/docker-compose-multiple-actors.yml
new file mode 100644
index 0000000000..a13c64e2d1
--- /dev/null
+++ b/infrastructure/ci/docker-compose-multiple-actors.yml
@@ -0,0 +1,154 @@
+version: "3.8"
+
+services:
+ ##########################
+ # Pollux Databases
+ ##########################
+
+ db_pollux_issuer:
+ image: postgres:13
+ restart: always
+ environment:
+ POSTGRES_DB: pollux_issuer
+ POSTGRES_USER: postgres
+ POSTGRES_PASSWORD: postgres
+ ports:
+ - 5435:5432
+ volumes:
+ - pg_data_pollux_db_issuer:/var/lib/postgresql/data
+ healthcheck:
+ test: ["CMD", "pg_isready", "-U", "postgres", "-d", "pollux_issuer"]
+ interval: 10s
+ timeout: 5s
+ retries: 5
+
+ db_pollux_holder:
+ image: postgres:13
+ restart: always
+ environment:
+ POSTGRES_DB: pollux_holder
+ POSTGRES_USER: postgres
+ POSTGRES_PASSWORD: postgres
+ ports:
+ - 5436:5432
+ volumes:
+ - pg_data_pollux_db_holder:/var/lib/postgresql/data
+ healthcheck:
+ test: ["CMD", "pg_isready", "-U", "postgres", "-d", "pollux_holder"]
+ interval: 10s
+ timeout: 5s
+ retries: 5
+
+ ##########################
+ # Connect Databases
+ ##########################
+
+ db_connect_issuer:
+ image: postgres:13
+ restart: always
+ environment:
+ POSTGRES_DB: connect_issuer
+ POSTGRES_USER: postgres
+ POSTGRES_PASSWORD: postgres
+ ports:
+ - 5437:5432
+ volumes:
+ - pg_data_connect_db_issuer:/var/lib/postgresql/data
+ healthcheck:
+ test: ["CMD", "pg_isready", "-U", "postgres", "-d", "connect_issuer"]
+ interval: 10s
+ timeout: 5s
+ retries: 5
+
+ db_connect_holder:
+ image: postgres:13
+ restart: always
+ environment:
+ POSTGRES_DB: connect_holder
+ POSTGRES_USER: postgres
+ POSTGRES_PASSWORD: postgres
+ ports:
+ - 5438:5432
+ volumes:
+ - pg_data_connect_db_holder:/var/lib/postgresql/data
+ healthcheck:
+ test: ["CMD", "pg_isready", "-U", "postgres", "-d", "connect_holder"]
+ interval: 10s
+ timeout: 5s
+ retries: 5
+
+ ##########################
+ # Services
+ ##########################c
+
+ prism-agent-issuer:
+ image: ghcr.io/hyperledger/prism-agent:0.5.0
+ environment:
+ REST_SERVICE_PORT: 8080
+ DIDCOMM_SERVICE_PORT: 8081
+ CASTOR_DB_HOST: db_castor_issuer
+ CASTOR_DB_PORT: 5432
+ CASTOR_DB_NAME: castor_issuer
+ CASTOR_DB_USER: postgres
+ CASTOR_DB_PASSWORD: postgres
+ POLLUX_DB_HOST: db_pollux_issuer
+ POLLUX_DB_PORT: 5432
+ POLLUX_DB_NAME: pollux_issuer
+ POLLUX_DB_USER: postgres
+ POLLUX_DB_PASSWORD: postgres
+ CONNECT_DB_HOST: db_connect_issuer
+ CONNECT_DB_PORT: 5432
+ CONNECT_DB_NAME: connect_issuer
+ CONNECT_DB_USER: postgres
+ CONNECT_DB_PASSWORD: postgres
+ DIDCOMM_SERVICE_URL: "http://prism-agent-issuer"
+ ports:
+ - "8080:8080"
+ - "8081:8081"
+ depends_on:
+ - db_castor_issuer
+ - db_pollux_issuer
+ healthcheck:
+ test: ["CMD", "curl", "-f", "http://prism-agent-issuer:8080/dids/xyz"]
+ interval: 30s
+ timeout: 10s
+ retries: 5
+
+ prism-agent-holder:
+ image: ghcr.io/hyperledger/prism-agent:0.5.0
+ environment:
+ REST_SERVICE_PORT: 8090
+ DIDCOMM_SERVICE_PORT: 8091
+ CASTOR_DB_HOST: db_castor_holder
+ CASTOR_DB_PORT: 5432
+ CASTOR_DB_NAME: castor_holder
+ CASTOR_DB_USER: postgres
+ CASTOR_DB_PASSWORD: postgres
+ POLLUX_DB_HOST: db_pollux_holder
+ POLLUX_DB_PORT: 5432
+ POLLUX_DB_NAME: pollux_holder
+ POLLUX_DB_USER: postgres
+ POLLUX_DB_PASSWORD: postgres
+ CONNECT_DB_HOST: db_connect_holder
+ CONNECT_DB_PORT: 5432
+ CONNECT_DB_NAME: connect_holder
+ CONNECT_DB_USER: postgres
+ CONNECT_DB_PASSWORD: postgres
+ DIDCOMM_SERVICE_URL: "http://prism-agent-holder"
+ ports:
+ - "8090:8090"
+ - "8091:8091"
+ depends_on:
+ - db_castor_holder
+ - db_pollux_holder
+ healthcheck:
+ test: ["CMD", "curl", "-f", "http://prism-agent-holder:8090/dids/xyz"]
+ interval: 30s
+ timeout: 10s
+ retries: 5
+
+volumes:
+ pg_data_pollux_db_issuer:
+ pg_data_pollux_db_holder:
+ pg_data_connect_db_issuer:
+ pg_data_connect_db_holder:
diff --git a/infrastructure/dev/get-versions.sh b/infrastructure/dev/get-versions.sh
index ccc91631eb..b301a00281 100755
--- a/infrastructure/dev/get-versions.sh
+++ b/infrastructure/dev/get-versions.sh
@@ -5,8 +5,8 @@ SCRIPT_DIR=$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" &>/dev/null && pwd)
# Set working directory
cd ${SCRIPT_DIR}
-export PRISM_AGENT_VERSION=$(cd ../../ && sbt "project agent" -Dsbt.supershell=false -error "print version")
-echo "prism-agent server version: ${PRISM_AGENT_VERSION}"
+export AGENT_VERSION=$(cd ../../ && sbt "project agent" -Dsbt.supershell=false -error "print version")
+echo "prism-agent server version: ${AGENT_VERSION}"
export PRISM_NODE_VERSION=v2.1.1
echo "prism node version: ${PRISM_NODE_VERSION}"
diff --git a/infrastructure/local/.env b/infrastructure/local/.env
index f85485b1c5..1b3d510520 100644
--- a/infrastructure/local/.env
+++ b/infrastructure/local/.env
@@ -1,3 +1,3 @@
-PRISM_AGENT_VERSION=1.31.0
+AGENT_VERSION=1.31.0
PRISM_NODE_VERSION=2.2.1
VAULT_DEV_ROOT_TOKEN_ID=root
diff --git a/infrastructure/local/update_env.sh b/infrastructure/local/update_env.sh
index a8831c9e51..5ab8eedffb 100755
--- a/infrastructure/local/update_env.sh
+++ b/infrastructure/local/update_env.sh
@@ -5,6 +5,6 @@ ENV_FILE="${SCRIPT_DIR}/.env"
pip install ${SCRIPT_DIR}/../utils/python/github-helpers > /dev/null 2>&1
-PRISM_AGENT_VERSION=$(github get-latest-package-version --package prism-agent --package-type container)
+AGENT_VERSION=$(github get-latest-package-version --package prism-agent --package-type container)
-sed -i.bak "s/PRISM_AGENT_VERSION=.*/PRISM_AGENT_VERSION=${PRISM_AGENT_VERSION}/" ${ENV_FILE} && rm -f ${ENV_FILE}.bak
+sed -i.bak "s/AGENT_VERSION=.*/AGENT_VERSION=${AGENT_VERSION}/" ${ENV_FILE} && rm -f ${ENV_FILE}.bak
diff --git a/infrastructure/multi/.env b/infrastructure/multi/.env
index a6c57a3d91..ec1313acb7 100644
--- a/infrastructure/multi/.env
+++ b/infrastructure/multi/.env
@@ -1,2 +1,2 @@
MERCURY_MEDIATOR_VERSION=0.2.0
-PRISM_AGENT_VERSION=0.6.0
+AGENT_VERSION=0.6.0
diff --git a/infrastructure/shared/docker-compose-demo.yml b/infrastructure/shared/docker-compose-demo.yml
index a448aa3e05..eecb80ac05 100644
--- a/infrastructure/shared/docker-compose-demo.yml
+++ b/infrastructure/shared/docker-compose-demo.yml
@@ -29,7 +29,7 @@ services:
condition: service_healthy
prism-agent:
- image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${AGENT_VERSION}
environment:
DIDCOMM_SERVICE_URL: http://${DOCKERHOST}:${PORT}/didcomm
REST_SERVICE_URL: http://${DOCKERHOST}:${PORT}/prism-agent
diff --git a/infrastructure/shared/docker-compose-mt-keycloak.yml b/infrastructure/shared/docker-compose-mt-keycloak.yml
index 5b0e6c5d7f..ea7f76d8b5 100644
--- a/infrastructure/shared/docker-compose-mt-keycloak.yml
+++ b/infrastructure/shared/docker-compose-mt-keycloak.yml
@@ -70,7 +70,7 @@ services:
retries: 5
prism-agent:
- image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${AGENT_VERSION}
environment:
POLLUX_DB_HOST: db
POLLUX_DB_PORT: 5432
diff --git a/infrastructure/shared/docker-compose.yml b/infrastructure/shared/docker-compose.yml
index 70384c1b62..7b9ecb0a82 100644
--- a/infrastructure/shared/docker-compose.yml
+++ b/infrastructure/shared/docker-compose.yml
@@ -71,7 +71,7 @@ services:
retries: 5
prism-agent:
- image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${AGENT_VERSION}
environment:
POLLUX_DB_HOST: db
POLLUX_DB_PORT: 5432
diff --git a/infrastructure/single-tenant-testing-stack/.env b/infrastructure/single-tenant-testing-stack/.env
index 3d851d1c25..4dafa03681 100644
--- a/infrastructure/single-tenant-testing-stack/.env
+++ b/infrastructure/single-tenant-testing-stack/.env
@@ -1,3 +1,3 @@
-PRISM_AGENT_VERSION=1.25.0
+AGENT_VERSION=1.25.0
PRISM_NODE_VERSION=2.2.1
VAULT_DEV_ROOT_TOKEN_ID=root
diff --git a/infrastructure/single-tenant-testing-stack/docker-compose.yml b/infrastructure/single-tenant-testing-stack/docker-compose.yml
index ea959fcfd5..bc4c641c53 100644
--- a/infrastructure/single-tenant-testing-stack/docker-compose.yml
+++ b/infrastructure/single-tenant-testing-stack/docker-compose.yml
@@ -85,7 +85,7 @@ services:
condition: service_healthy
issuer-oea:
- image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${AGENT_VERSION}
environment:
POLLUX_DB_HOST: issuer-db
POLLUX_DB_PORT: 5432
@@ -155,7 +155,7 @@ services:
- 9095:9095
verifier-oea:
- image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${AGENT_VERSION}
environment:
POLLUX_DB_HOST: verifier-db
POLLUX_DB_PORT: 5432
@@ -227,7 +227,7 @@ services:
- DATA_SOURCE_NAME=postgresql://postgres:postgres@issuer-db:5432/postgres?sslmode=disable
holder-oea:
- image: ghcr.io/hyperledger/identus-cloud-agent:${PRISM_AGENT_VERSION}
+ image: ghcr.io/hyperledger/identus-cloud-agent:${AGENT_VERSION}
environment:
POLLUX_DB_HOST: holder-db
POLLUX_DB_PORT: 5432
diff --git a/infrastructure/single-tenant-testing-stack/run-performance-tests-local.sh b/infrastructure/single-tenant-testing-stack/run-performance-tests-local.sh
index 38e5a6d051..f45e698acf 100755
--- a/infrastructure/single-tenant-testing-stack/run-performance-tests-local.sh
+++ b/infrastructure/single-tenant-testing-stack/run-performance-tests-local.sh
@@ -30,7 +30,7 @@ echo "--------------------------------------"
(
export K6_PROMETHEUS_RW_SERVER_URL=http://localhost:9090/api/v1/write
export K6_PROMETHEUS_RW_TREND_AS_NATIVE_HISTOGRAM=true
- cd ${SCRIPT_DIR}/../../tests/performance-tests/atala-performance-tests-k6
+ cd ${SCRIPT_DIR}/../../tests/performance-tests/agent-performance-tests-k6
yarn install
yarn webpack
k6 run -e SCENARIO_LABEL=st-create-prism-did-smoke dist/create-prism-did-test.js -o experimental-prometheus-rw
diff --git a/mercury/mercury-library/CHANGELOG.md b/mercury/CHANGELOG.md
similarity index 100%
rename from mercury/mercury-library/CHANGELOG.md
rename to mercury/CHANGELOG.md
diff --git a/mercury/mercury-library/QuickStart.md b/mercury/QuickStart.md
similarity index 100%
rename from mercury/mercury-library/QuickStart.md
rename to mercury/QuickStart.md
diff --git a/mercury/README.md b/mercury/README.md
index db1fb3f277..f3c891098d 100644
--- a/mercury/README.md
+++ b/mercury/README.md
@@ -1,15 +1,97 @@
-# Mercury folder
+# Mercury
-We are following the directory structure defined in [RFC 0013 - Service-Oriented BB API Dependency Management](https://input-output.atlassian.net/wiki/spaces/ATB/pages/3534848001/RFC+0013+-+Service-Oriented+BB+API+Dependency+Management).
+## Index
-**NOTE** - The `Mediator` development is part of the Mercury BB and is being implemented in a separate repository [atala-prism-mediator](https://github.com/input-output-hk/atala-prism-mediator).
+- [Mediator (Mailbox)](./Mercury-Mailbox-Mediator.md)
+- Protocols:
+ - [Invitation-Protocol](./protocol-invitation/Invitation-Protocol.md)
+ - [Mercury-Mailbox-Protocol](./protocol-mercury-mailbox/Mercury-Mailbox-Protocol.md)
+ - [Report-Problem-Protocol](protocol-report-problem/Report-Problem-Protocol.md)
+ - [Routing-Protocol](./protocol-routing/Routing-Protocol.md)
+- [Quick start](./QuickStart.md)
+- [UseCases](./UseCases.md)
-**Folders:**
+## Project structure
-- `mercury-library`:
- Is our project implementation of the DID Comm and DID Comm protocols.
+Dependencies:
-- `roots-id-mediator`:
- Contains a configuration setup and utilities script to test interoperability against ROOTS-ID's mediator.
+```mermaid
+flowchart BT
+ models
+ %%[mercury-data-models]
+ resolver
+ %%[mercury-resolver]
+ invitation[protocol-invitation]
+ mailbox[protocol-mercury-mailbox]
+ routing[mercury-protocol-routing-2_0]
+ agent
+ agent-didcommx
+ agent-didscala
- See [ROOTS-ID-mediator](./roots-id-mediator/REAMDE-ROOTS-ID-mediator.md)
+ alice((Alice))
+ bob((Bob))
+
+ subgraph Libs
+ didcommx
+ did-scala
+ http[shttp or zhttp]
+ end
+
+
+
+ subgraph Mercury
+ subgraph Protocols
+ invitation
+ mailbox
+ routing
+ end
+
+ subgraph DID agents
+ alice
+ bob
+ agent-cli-didcommx
+ end
+
+ resolver --> models
+ agent --> resolver
+
+ invitation --> models
+ mailbox --> models
+ routing --> models
+ mailbox --> invitation
+ mailbox --> routing
+
+ alice -.->|client| mailbox
+ alice --> agent-didcommx
+ bob --> agent-didcommx
+
+
+ agent ---> models
+ agent -..-> routing
+ %% invitation
+
+
+ agent-didcommx --> agent
+ agent-didcommx -.-> didcommx
+
+ agent-cli-didcommx -.-> http
+ agent-cli-didcommx --> agent-didcommx
+
+ agent-didscala --> agent
+ agent-didscala -.-> did-scala
+ end
+
+
+
+
+```
+
+## Quick Reference Guide
+
+```shell
+# Alice Agent (send messagem to Bob's Mediator)
+sbt "agentDidcommx/runMain org.hyperledger.identus.AgentClientAlice"
+
+# Bob Agent (fetch his message from Mediator)
+sbt "agentDidcommx/runMain org.hyperledger.identus.AgentClientBob"
+```
diff --git a/mercury/mercury-library/UseCases.md b/mercury/UseCases.md
similarity index 100%
rename from mercury/mercury-library/UseCases.md
rename to mercury/UseCases.md
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/AgentPeerService.scala b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/AgentPeerService.scala
similarity index 96%
rename from mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/AgentPeerService.scala
rename to mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/AgentPeerService.scala
index fd4870d2dd..1b71af6e86 100644
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/AgentPeerService.scala
+++ b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/AgentPeerService.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import zio._
-import io.iohk.atala.mercury.model.*
+import org.hyperledger.identus.mercury.model.*
import com.nimbusds.jose.jwk.OctetKeyPair
import org.didcommx.peerdid.core.PeerDIDUtils
import org.didcommx.didcomm.common._
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/DidCommX.scala b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/DidCommX.scala
similarity index 93%
rename from mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/DidCommX.scala
rename to mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/DidCommX.scala
index 84d3028d48..dc23a01a86 100644
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/DidCommX.scala
+++ b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/DidCommX.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import org.didcommx.didcomm.DIDComm
import zio._
import org.didcommx.didcomm.model._
-import io.iohk.atala.resolvers._
-import io.iohk.atala.mercury.model.{given, _}
+import org.hyperledger.identus.resolvers.UniversalDidResolver
+import org.hyperledger.identus.mercury.model.{given, _}
import scala.language.implicitConversions
object DidCommX {
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/MessagingService.scala b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/MessagingService.scala
similarity index 94%
rename from mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/MessagingService.scala
rename to mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/MessagingService.scala
index e0dba38d3e..0db166cb47 100644
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/MessagingService.scala
+++ b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/MessagingService.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import scala.jdk.CollectionConverters.*
import zio._
import io.circe._
import io.circe.JsonObject
-import io.iohk.atala.mercury.model._
-import io.iohk.atala.mercury.model.error._
-import io.iohk.atala.mercury.protocol.routing._
-import io.iohk.atala.resolvers.DIDResolver
+import org.hyperledger.identus.mercury.model._
+import org.hyperledger.identus.mercury.error._
+import org.hyperledger.identus.mercury.protocol.routing._
+import org.hyperledger.identus.resolvers.DIDResolver
type HttpOrDID = String //TODO
case class ServiceEndpoint(uri: HttpOrDID, accept: Option[Seq[String]], routingKeys: Option[Seq[String]])
@@ -124,7 +124,7 @@ object MessagingService {
didCommService.packEncrypted(msg = finalMessage, to = finalMessage.to.head) // TODO Head
_ <- ZIO.log(s"Sending a Message to '$serviceEndpoint'")
- resp <- HttpClient
+ resp <- org.hyperledger.identus.mercury.HttpClient
.postDIDComm(url = serviceEndpoint, data = encryptedMessage.string)
.catchAll { case ex => ZIO.fail(SendMessageError(ex, Some(encryptedMessage.string))) }
_ <- ZIO.when(resp.status >= 300)(
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/PeerDID.scala b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/PeerDID.scala
similarity index 97%
rename from mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/PeerDID.scala
rename to mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/PeerDID.scala
index a4a9f052ed..3e29ff6b5c 100644
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/PeerDID.scala
+++ b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/PeerDID.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import org.didcommx.peerdid.*
@@ -9,7 +9,7 @@ import io.circe.syntax._
import io.circe.generic.semiauto._
import scala.jdk.CollectionConverters.*
-import io.iohk.atala.mercury.model.DidId
+import org.hyperledger.identus.mercury.model.DidId
final case class PeerDID(
did: DidId,
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/model/Conversions.scala b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/model/Conversions.scala
similarity index 98%
rename from mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/model/Conversions.scala
rename to mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/model/Conversions.scala
index 7caa3b62b1..b91ced49e3 100644
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/model/Conversions.scala
+++ b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/model/Conversions.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
import io.circe.*
-import io.iohk.atala.mercury.model.*
+import org.hyperledger.identus.mercury.model.*
import org.didcommx.didcomm.message.Attachment.Data
import org.didcommx.didcomm.message.{MessageBuilder, Attachment as XAttachment}
import org.didcommx.didcomm.model.*
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/model/JsonUtilsForDidCommx.scala b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/model/JsonUtilsForDidCommx.scala
similarity index 98%
rename from mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/model/JsonUtilsForDidCommx.scala
rename to mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/model/JsonUtilsForDidCommx.scala
index 16d603ae62..b25e43f88c 100644
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/model/JsonUtilsForDidCommx.scala
+++ b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/model/JsonUtilsForDidCommx.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
import scala.jdk.CollectionConverters._
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/model/package.scala b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/model/package.scala
similarity index 97%
rename from mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/model/package.scala
rename to mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/model/package.scala
index 19a0637cad..b4a0a5888d 100644
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/mercury/model/package.scala
+++ b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/model/package.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
import scala.jdk.CollectionConverters.*
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/AliceSecretResolver.scala b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/resolvers/AliceSecretResolver.scala
similarity index 96%
rename from mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/AliceSecretResolver.scala
rename to mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/resolvers/AliceSecretResolver.scala
index 246955ba95..fff62a7b22 100644
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/AliceSecretResolver.scala
+++ b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/resolvers/AliceSecretResolver.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.mercury.resolvers
import org.didcommx.didcomm.common.{VerificationMaterial, VerificationMaterialFormat, VerificationMethodType}
import org.didcommx.didcomm.secret.{Secret, SecretResolverInMemory}
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/BobSecretResolver.scala b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/resolvers/BobSecretResolver.scala
similarity index 96%
rename from mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/BobSecretResolver.scala
rename to mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/resolvers/BobSecretResolver.scala
index cf14e8375d..4a57e4cce7 100644
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/BobSecretResolver.scala
+++ b/mercury/agent-didcommx/src/main/scala/org/hyperledger/identus/mercury/resolvers/BobSecretResolver.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.mercury.resolvers
import org.didcommx.didcomm.common.{VerificationMaterial, VerificationMaterialFormat, VerificationMethodType}
import org.didcommx.didcomm.secret.{Secret, SecretResolverInMemory}
diff --git a/mercury/mercury-library/agent-didcommx/src/test/scala/io/iohk/atala/mercury/PeerDIDSpec.scala b/mercury/agent-didcommx/src/test/scala/org/hyperledger/identus/mercury/PeerDIDSpec.scala
similarity index 78%
rename from mercury/mercury-library/agent-didcommx/src/test/scala/io/iohk/atala/mercury/PeerDIDSpec.scala
rename to mercury/agent-didcommx/src/test/scala/org/hyperledger/identus/mercury/PeerDIDSpec.scala
index 0628ecb986..e1b3c21326 100644
--- a/mercury/mercury-library/agent-didcommx/src/test/scala/io/iohk/atala/mercury/PeerDIDSpec.scala
+++ b/mercury/agent-didcommx/src/test/scala/org/hyperledger/identus/mercury/PeerDIDSpec.scala
@@ -1,13 +1,14 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import munit.*
-import io.iohk.atala.mercury.model.DidId
+import org.hyperledger.identus.mercury.model.DidId
import com.nimbusds.jose.jwk.OctetKeyPair
class PeerDIDSpec extends ZSuite {
test("Make and parse PeerDID") {
- val peer = PeerDID.makePeerDid(serviceEndpoint = Some("http://localhost:8654/myendpoint"))
+ val peer =
+ org.hyperledger.identus.mercury.PeerDID.makePeerDid(serviceEndpoint = Some("http://localhost:8654/myendpoint"))
val did = peer.did.value
// Exemple {"kty":"OKP","d":"XwaryH2em2iRwqPjxInIHrhvKJqLZ_iejheA5cVM2ZY","crv":"X25519","x":"w1tZHpAuQ6TD6q5cMGWu6q2K1eL3gvEbE1gwkMzLnQI"}
diff --git a/mercury/mercury-library/agent-didcommx/src/test/scala/io/iohk/atala/mercury/model/UnpackMessageImpSpec.scala b/mercury/agent-didcommx/src/test/scala/org/hyperledger/identus/mercury/model/UnpackMessageImpSpec.scala
similarity index 94%
rename from mercury/mercury-library/agent-didcommx/src/test/scala/io/iohk/atala/mercury/model/UnpackMessageImpSpec.scala
rename to mercury/agent-didcommx/src/test/scala/org/hyperledger/identus/mercury/model/UnpackMessageImpSpec.scala
index cb4031d350..1426255b6f 100644
--- a/mercury/mercury-library/agent-didcommx/src/test/scala/io/iohk/atala/mercury/model/UnpackMessageImpSpec.scala
+++ b/mercury/agent-didcommx/src/test/scala/org/hyperledger/identus/mercury/model/UnpackMessageImpSpec.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
import munit.*
import io.circe.JsonObject
import scala.language.implicitConversions
-/** agentDidcommx/testOnly io.iohk.atala.mercury.model.UnpackMessageImpSpec */
+/** agentDidcommx/testOnly org.hyperledger.identus.mercury.UnpackMessageImpSpec */
class UnpackMessageImpSpec extends ZSuite {
test("Message conversions - check pleaseAck None") {
val m1 = Message(
diff --git a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/Agent.scala b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/Agent.scala
similarity index 96%
rename from mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/Agent.scala
rename to mercury/agent/src/main/scala/org/hyperledger/identus/mercury/Agent.scala
index a20c198ac2..6e9c19b085 100644
--- a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/Agent.scala
+++ b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/Agent.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
-import io.iohk.atala.mercury.model.DidId
+import org.hyperledger.identus.mercury.model.DidId
enum Agent(val id: DidId):
case Alice extends Agent(DidId("did:example:alice"))
diff --git a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/CoordinateMediationPrograms.scala b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/CoordinateMediationPrograms.scala
similarity index 89%
rename from mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/CoordinateMediationPrograms.scala
rename to mercury/agent/src/main/scala/org/hyperledger/identus/mercury/CoordinateMediationPrograms.scala
index 446d9b76cc..7e5501a1cf 100644
--- a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/CoordinateMediationPrograms.scala
+++ b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/CoordinateMediationPrograms.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import scala.util.chaining._
import zio._
import io.circe.parser._
import io.circe.JsonObject
-import io.iohk.atala.mercury._
-import io.iohk.atala.mercury.model._
-import io.iohk.atala.mercury.protocol.coordinatemediation._
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus._
+import org.hyperledger.identus.mercury.model._
+import org.hyperledger.identus.mercury.protocol.coordinatemediation._
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
object CoordinateMediationPrograms {
diff --git a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/HttpClient.scala b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/HttpClient.scala
similarity index 94%
rename from mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/HttpClient.scala
rename to mercury/agent/src/main/scala/org/hyperledger/identus/mercury/HttpClient.scala
index 6f5ee118b8..b17a1d86bf 100644
--- a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/HttpClient.scala
+++ b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/HttpClient.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import zio._
diff --git a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/InvitationPrograms.scala b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/InvitationPrograms.scala
similarity index 80%
rename from mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/InvitationPrograms.scala
rename to mercury/agent/src/main/scala/org/hyperledger/identus/mercury/InvitationPrograms.scala
index c8950a8a31..7e74ea9098 100644
--- a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/InvitationPrograms.scala
+++ b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/InvitationPrograms.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import zio.*
-import io.iohk.atala.mercury.protocol.invitation.*
-import io.iohk.atala.mercury.protocol.invitation.v2.*
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation.Body
+import org.hyperledger.identus.mercury.protocol.invitation.*
+import org.hyperledger.identus.mercury.protocol.invitation.v2.*
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation.Body
import io.circe.syntax.*
object InvitationPrograms {
diff --git a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/OutOfBandLoginPrograms.scala b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/OutOfBandLoginPrograms.scala
similarity index 79%
rename from mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/OutOfBandLoginPrograms.scala
rename to mercury/agent/src/main/scala/org/hyperledger/identus/mercury/OutOfBandLoginPrograms.scala
index 03a137f6ef..e124a58e32 100644
--- a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/mercury/OutOfBandLoginPrograms.scala
+++ b/mercury/agent/src/main/scala/org/hyperledger/identus/mercury/OutOfBandLoginPrograms.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
-import io.iohk.atala.mercury.model._
-import io.iohk.atala.mercury.protocol.outofbandlogin._
+import org.hyperledger.identus.mercury.model._
+import org.hyperledger.identus.mercury.protocol.outofbandlogin._
object OutOfBandLoginPrograms {
diff --git a/mercury/mercury-library/README.md b/mercury/mercury-library/README.md
deleted file mode 100644
index dcf6bf508e..0000000000
--- a/mercury/mercury-library/README.md
+++ /dev/null
@@ -1,97 +0,0 @@
-# Mercury
-
-## Index
-
-- [Mediator (Mailbox)](./Mercury-Mailbox-Mediator.md)
-- Protocols:
- - [Invitation-Protocol](./protocol-invitation/Invitation-Protocol.md)
- - [Mercury-Mailbox-Protocol](./protocol-mercury-mailbox/Mercury-Mailbox-Protocol.md)
- - [Report-Problem-Protocol](protocol-report-problem/Report-Problem-Protocol.md)
- - [Routing-Protocol](./protocol-routing/Routing-Protocol.md)
-- [Quick start](./QuickStart.md)
-- [UseCases](./UseCases.md)
-
-## Project structure
-
-Dependencies:
-
-```mermaid
-flowchart BT
- models
- %%[mercury-data-models]
- resolver
- %%[mercury-resolver]
- invitation[protocol-invitation]
- mailbox[protocol-mercury-mailbox]
- routing[mercury-protocol-routing-2_0]
- agent
- agent-didcommx
- agent-didscala
-
- alice((Alice))
- bob((Bob))
-
- subgraph Libs
- didcommx
- did-scala
- http[shttp or zhttp]
- end
-
-
-
- subgraph Mercury
- subgraph Protocols
- invitation
- mailbox
- routing
- end
-
- subgraph DID agents
- alice
- bob
- agent-cli-didcommx
- end
-
- resolver --> models
- agent --> resolver
-
- invitation --> models
- mailbox --> models
- routing --> models
- mailbox --> invitation
- mailbox --> routing
-
- alice -.->|client| mailbox
- alice --> agent-didcommx
- bob --> agent-didcommx
-
-
- agent ---> models
- agent -..-> routing
- %% invitation
-
-
- agent-didcommx --> agent
- agent-didcommx -.-> didcommx
-
- agent-cli-didcommx -.-> http
- agent-cli-didcommx --> agent-didcommx
-
- agent-didscala --> agent
- agent-didscala -.-> did-scala
- end
-
-
-
-
-```
-
-## Quick Reference Guide
-
-```shell
-# Alice Agent (send messagem to Bob's Mediator)
-sbt "agentDidcommx/runMain io.iohk.atala.AgentClientAlice"
-
-# Bob Agent (fetch his message from Mediator)
-sbt "agentDidcommx/runMain io.iohk.atala.AgentClientBob"
-```
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/Main.scala b/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/Main.scala
deleted file mode 100644
index c13b8d973d..0000000000
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/Main.scala
+++ /dev/null
@@ -1,129 +0,0 @@
-/*
-package io.iohk.atala
-
-import java.time.{LocalDateTime, ZoneOffset}
-import scala.jdk.CollectionConverters._
-
-import java.util
-import java.util.Base64
-
-import zio._
-
-import io.iohk.atala.resolvers.{AliceSecretResolver, BobSecretResolver, MediatorSecretResolver, UniversalDidResolver}
-import io.iohk.atala.mercury.model.Message
-import io.iohk.atala.mercury.Agent
-import io.iohk.atala.mercury.AgentService
-import io.iohk.atala.mercury.protocol.routing._
-import io.iohk.atala.mercury.model.Attachment
-import io.iohk.atala.mercury.model.EncryptedMessage
-
-val program1 = for {
- messageCreated <- ZIO.succeed(makeMsg(Agent.Alice, Agent.Bob))
- alice <- ZIO.service[AgentService[Agent.Alice.type]]
- bob <- ZIO.service[AgentService[Agent.Bob.type]]
- // ##########################################
- signedMsg <- alice.packSigned(messageCreated)
- _ <- Console.printLine("SignedMesagem: " + signedMsg.string)
- aux <- bob.unpackBase64(signedMsg.base64)
- _ <- Console.printLine("Bob Check SignedMesagem: " + aux.getMessage)
-} yield ()
-
-val program2 = for {
- messageCreated <- ZIO.succeed(makeMsg(Agent.Alice, Agent.Bob))
- alice <- ZIO.service[AgentService[Agent.Alice.type]]
- bob <- ZIO.service[AgentService[Agent.Bob.type]]
- // ##########################################
- _ <- Console.printLine("*" * 120)
- encryptedMsg <- alice.packEncrypted(messageCreated, to = Agent.Bob.id)
- _ <- Console.printLine("EncryptedMsg: " + encryptedMsg.string)
- base64EncodedString = encryptedMsg.base64
- _ <- Console.printLine("Sending bytes ...")
- // base64DecodedString = new String(Base64.getUrlDecoder.decode(base64EncodedString))
- mediator <- ZIO.service[AgentService[Agent.Mediator.type]]
- msgInMediator <- mediator.unpackBase64(base64EncodedString)
- _ <- Console.printLine("msgInMediator: " + msgInMediator.getMessage)
- _ <- Console.printLine("Sending bytes to BOB ...")
- msgToBob = msgInMediator.getMessage.getAttachments().get(0).getData().toJSONObject().get("json").toString()
- _ <- Console.printLine("msgToBob: " + msgToBob)
- _ <- Console.printLine("Bob read Message ...")
- msgInBob <- bob.unpack(msgToBob)
- _ <- Console.printLine("msgInBob: " + msgInBob.getMessage)
-} yield ()
-
-val program3 = for {
- _ <- Console.printLine("\n#### Program 3 ####")
- messageCreated <- ZIO.succeed(makeMsg(Agent.Alice, Agent.Bob))
- alice <- ZIO.service[AgentService[Agent.Alice.type]]
- bob <- ZIO.service[AgentService[Agent.Bob.type]]
- // ##########################################
- encryptedMsg <- alice.packEncrypted(messageCreated, to = Agent.Bob.id)
- _ <- Console.printLine("EncryptedMsg: " + encryptedMsg.string)
- msgInBob <- bob.unpack(encryptedMsg.string)
- _ <- Console.printLine("msgInBob: " + msgInBob.getMessage)
-} yield ()
-
-val program4 = for {
- _ <- Console.printLine("\n#### Program 4 ####")
- messageCreated <- ZIO.succeed(makeMsg(Agent.Alice, Agent.Bob))
- alice <- ZIO.service[AgentService[Agent.Alice.type]]
-
- // ##########################################
- encryptedMsg <- alice.packEncrypted(messageCreated, to = Agent.Bob.id)
- _ <- Console.printLine("EncryptedMsg: " + encryptedMsg.string)
-
- forwardMessage = makeForwardMessage(Agent.Alice, Agent.Mediator, Agent.Bob, encryptedMsg).asMessage
-
- encryptedForwardMessage <- alice.packEncrypted(forwardMessage, to = Agent.Mediator.id)
- _ <- Console.printLine("Sending bytes ...")
- base64EncodedString = encryptedForwardMessage.base64
- _ <- Console.printLine(base64EncodedString)
-
- // _ <- Console.printLine("Sending bytes ...")
- base64DecodedString = new String(Base64.getUrlDecoder.decode(base64EncodedString))
- mediator <- ZIO.service[AgentService[Agent.Mediator.type]]
- msgInMediator <- mediator.unpackBase64(base64EncodedString)
- _ <- Console.printLine("msgInMediator: ")
- _ <- Console.printLine(msgInMediator.getMessage)
- _ <- Console.printLine("Sending bytes to BOB ...")
- msgToBob = msgInMediator.getMessage.getAttachments().get(0).getData().toJSONObject().get("json").toString()
- _ <- Console.printLine("msgToBob:")
- _ <- Console.printLine(msgToBob)
- _ <- Console.printLine("Bob read Message ...")
-
- bob <- ZIO.service[AgentService[Agent.Bob.type]]
- msgInBob <- bob.unpack(msgToBob)
- _ <- Console.printLine("msgInBob: " + msgInBob.getMessage)
-} yield ()
-
-// TODO Make tests and remove this main
-@main def didCommPlay() = {
-
- val app1 = program1.provide(
- AgentService.alice,
- AgentService.bob
- )
-
- val app2 = program2.provide(
- AgentService.alice,
- AgentService.bob,
- AgentService.mediator
- )
-
- val app3 = program3.provide(
- AgentService.alice,
- AgentService.bob
- )
-
- val app4 = program4.provide(
- AgentService.alice,
- AgentService.bob,
- AgentService.mediator
- )
-
- // Unsafe.unsafe { Runtime.default.unsafe.run(app1).getOrThrowFiberFailure() }
- // Unsafe.unsafe { Runtime.default.unsafe.run(app2).getOrThrowFiberFailure() }
- // Unsafe.unsafe { Runtime.default.unsafe.run(app3).getOrThrowFiberFailure() }
- Unsafe.unsafe { Runtime.default.unsafe.run(app4).getOrThrowFiberFailure() }
-
-}
- */
diff --git a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/CharlieSecretResolver.scala b/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/CharlieSecretResolver.scala
deleted file mode 100644
index a93c0b4939..0000000000
--- a/mercury/mercury-library/agent-didcommx/src/main/scala/io/iohk/atala/resolvers/CharlieSecretResolver.scala
+++ /dev/null
@@ -1,62 +0,0 @@
-/*
-package io.iohk.atala.resolvers
-
-import org.didcommx.didcomm.common.{VerificationMaterial, VerificationMaterialFormat, VerificationMethodType}
-import org.didcommx.didcomm.secret.{Secret, SecretResolverInMemory}
-import scala.jdk.CollectionConverters._
-import org.didcommx.peerdid._
-
-object CharlieSecretResolver {
-
- private val jwkKey1 =
- // "kid":"${io.iohk.atala.mercury.charlie}#6LSiseNCbbtmG6ascxpPvoyT8ewrWdtJZxwmPNxYAPWxzM8",
- s"""{"kty":"OKP","d":"r-jK2cO3taR8LQnJB1_ikLBTAnOtShJOsHXRUWT-aZA","crv":"X25519","x":"avH0O2Y4tqLAq8y9zpianr8ajii5m4F_mICrzNlatXs"}"""
-
- private val jwkKey2 = // example from did:example:alice#key-1
- // "kid":"${io.iohk.atala.mercury.charlie}#6MkgLBGee6xL5KH8SZmqmKmQKS2o1qd4RG4dSmjtRGTfsxX",
- s"""{"kty":"OKP","d":"pFRUKkyzx4kHdJtFSnlPA9WzqkDT1HWV0xZ5OYZd2SY","crv":"Ed25519","x":"G-boxFB6vOZBu-wXkm-9Lh79I8nf9Z50cILaOgKKGww"}"""
-
- private val secretKey1 = new Secret(
- io.iohk.atala.mercury.charlie + "#6LSiseNCbbtmG6ascxpPvoyT8ewrWdtJZxwmPNxYAPWxzM8",
- VerificationMethodType.JSON_WEB_KEY_2020,
- new VerificationMaterial(VerificationMaterialFormat.JWK, jwkKey1)
- )
- private val secretKeyAgreement1 = new Secret(
- io.iohk.atala.mercury.charlie + "#6MkgLBGee6xL5KH8SZmqmKmQKS2o1qd4RG4dSmjtRGTfsxX",
- VerificationMethodType.JSON_WEB_KEY_2020,
- new VerificationMaterial(VerificationMaterialFormat.JWK, jwkKey2)
- )
-
- val secretResolver = new SecretResolverInMemory(
- Map(
- (io.iohk.atala.mercury.charlie + "#6LSiseNCbbtmG6ascxpPvoyT8ewrWdtJZxwmPNxYAPWxzM8") -> secretKey1,
- (io.iohk.atala.mercury.charlie + "#6MkgLBGee6xL5KH8SZmqmKmQKS2o1qd4RG4dSmjtRGTfsxX") -> secretKeyAgreement1,
- (io.iohk.atala.mercury.charlie) -> secretKeyAgreement1
- ).asJava
- )
-
- // val service =
- // """[{
- // | "type": "DIDCommMessaging",
- // | "serviceEndpoint": "http://localhost:8000/",
- // | "routingKeys": ["did:example:somemediator#somekey"]
- // |},
- // |{
- // | "type": "example",
- // | "serviceEndpoint": "http://localhost:8000/",
- // | "routingKeys": ["did:example:somemediator#somekey2"],
- // | "accept": ["didcomm/v2", "didcomm/aip2;env=rfc587"]
- // |}]""".stripMargin
-
- @main def testPeerDidDoc() = {
- println(
- org.didcommx.peerdid.PeerDIDResolver
- .resolvePeerDID(
- io.iohk.atala.mercury.charlie,
- VerificationMaterialFormatPeerDID.JWK
- )
- )
- }
-
-}
- */
diff --git a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/AgentPrograms.scala b/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/AgentPrograms.scala
deleted file mode 100644
index 015ab28118..0000000000
--- a/mercury/mercury-library/agent/src/main/scala/io/iohk/atala/AgentPrograms.scala
+++ /dev/null
@@ -1,106 +0,0 @@
-package io.iohk.atala
-
-import zio._
-
-import io.circe._
-import io.circe.Json._
-import io.circe.parser._
-import io.circe.JsonObject
-import io.iohk.atala.mercury.*
-import io.iohk.atala.mercury.model._
-import io.iohk.atala.mercury.protocol.mailbox.Mailbox.ReadMessage
-import io.iohk.atala.mercury.protocol.routing._
-
-def makeMsg(from: Agent, to: Agent) = Message(
- `type` = "http://atalaprism.io/lets_connect/proposal",
- from = Some(from.id),
- to = Seq(to.id),
- body = JsonObject.fromIterable(
- Seq(
- "connectionId" -> Json.fromString("8fb9ea21-d094-4506-86b6-c7c1627d753a"),
- "msg" -> Json.fromString("Hello Bob")
- )
- )
-)
-
-def makeForwardMessage(mediator: Agent, to: Agent, msg: EncryptedMessage) =
- ForwardMessage(
- to = mediator.id,
- expires_time = None,
- body = ForwardBody(next = to.id), // TODO check msg header
- attachments = Seq(AttachmentDescriptor.buildJsonAttachment(payload = msg.asJson)),
- )
-
-object AgentPrograms {
-
- def toPrettyJson(parseToJson: String) = {
- parse(parseToJson).getOrElse(???).spaces2
- }
-
- def makeReadMessage(from: Agent, mediator: Agent) =
- ReadMessage(from = from.id, to = mediator.id, expires_time = None)
-
- val senderProgram = for {
- _ <- Console.printLine("\n#### Bob Sending type Readmessages ####")
- messageCreated <- ZIO.succeed(makeReadMessage(Agent.Bob, Agent.Mediator))
- bob <- ZIO.service[DidOps] // AgentService[Agent.Bob.type]]
-
- // ##########################################
- encryptedMsg <- bob.packEncrypted(messageCreated.asMessage, to = Agent.Mediator.id)
- _ <- Console.printLine("EncryptedMsg: \n" + fromJsonObject(encryptedMsg.asJson).spaces2 + "\n")
- _ <- Console.printLine("Sending bytes ...")
- jsonString = encryptedMsg.string
- // HTTP
- httpClient <- ZIO.service[HttpClient]
- res <- httpClient.postDIDComm(
- url = "http://localhost:8080",
- data = jsonString
- )
- _ <- Console.printLine("Receiving the message ..." + res.bodyAsString)
- messageReceived <- bob.unpack(res.bodyAsString)
- _ <- Console.printLine("Unpacking and decrypting the received message ...")
- _ <- Console.printLine(
- "\n*********************************************************************************************************************************\n"
- + toPrettyJson(messageReceived.message.toString)
- + "\n********************************************************************************************************************************\n"
- )
-
- } yield ()
-
- val pickupMessageProgram = for {
- _ <- Console.printLine("\n#### Program 4 ####")
- messageCreated <- ZIO.succeed(makeMsg(Agent.Alice, Agent.Bob))
- alice <- ZIO.service[DidOps] // AgentService[Agent.Alice.type]]
- _ <- Console.printLine("Send Message")
- _ <- Console.printLine(
- "\n*********************************************************************************************************************************\n"
- + messageCreated // toPrettyJson(msg.toString)
- + "\n********************************************************************************************************************************\n"
- )
- // ##########################################
- encryptedMsg <- alice.packEncrypted(messageCreated, to = Agent.Bob.id)
- _ <- Console.printLine("EncryptedMsg: " + encryptedMsg.asJson)
- _ <- Console.printLine(
- "\n*********************************************************************************************************************************\n"
- + fromJsonObject(encryptedMsg.asJson).spaces2
- + "\n********************************************************************************************************************************\n"
- )
- forwardMessage = makeForwardMessage(Agent.Mediator, Agent.Bob, encryptedMsg).asMessage
-
- encryptedForwardMessage <- alice.packEncrypted(forwardMessage, to = Agent.Mediator.id)
- _ <- Console.printLine("Sending bytes ...")
- jsonString = encryptedForwardMessage.string
- _ <- Console.printLine(jsonString)
-
- // HTTP
-
- alice <- ZIO.service[DidOps]
- httpClient <- ZIO.service[HttpClient]
- res <- httpClient.postDIDComm(
- url = "http://localhost:8080",
- data = jsonString
- )
- _ <- Console.printLine(res.bodyAsString)
- } yield ()
-
-}
diff --git a/mercury/mercury-library/protocol-did-exchange/src/main/scala/io/iohk/atala/mercury/protocol/didexchange/v1/DIDExchange.scala b/mercury/mercury-library/protocol-did-exchange/src/main/scala/io/iohk/atala/mercury/protocol/didexchange/v1/DIDExchange.scala
deleted file mode 100644
index 620632adba..0000000000
--- a/mercury/mercury-library/protocol-did-exchange/src/main/scala/io/iohk/atala/mercury/protocol/didexchange/v1/DIDExchange.scala
+++ /dev/null
@@ -1,3 +0,0 @@
-package io.iohk.atala.mercury.protocol.didexchange.v1
-
-object DIDExchange {}
diff --git a/mercury/mercury-library/protocol-mercury-mailbox/Mercury-Mailbox-Protocol.md b/mercury/mercury-library/protocol-mercury-mailbox/Mercury-Mailbox-Protocol.md
deleted file mode 100644
index c18109d352..0000000000
--- a/mercury/mercury-library/protocol-mercury-mailbox/Mercury-Mailbox-Protocol.md
+++ /dev/null
@@ -1,87 +0,0 @@
-# [WIP] Mercury Mailbox Protocol
-
-## PIURI
-
-TODO maybe ??? `https://atalaprism.io/mercury/mailbox/1.0`
-
-## Diagrams (Mailbox Operations)
-
-### Flow Diagram
-
-```mermaid
-sequenceDiagram
- participant Alice
- participant Mediator
- participant DID Resolver
-
- note over Alice: Mediation client or Mediated Agent
-
- rect rgb(0, 120, 255)
- note right of Alice: Alice accepts the invitation and register for a mailbox.
- Alice->>+Mediator: Register (HTTP)
- Mediator->>+DID Resolver: Ask for Alice DID document
- DID Resolver-->>-Mediator: DID document
- note over Mediator: Confirm the identity
- Mediator-->>-Alice: Registration done
- note over Alice: Alice updates his DID document (adding serviceEndpoint)
- end
-```
-
-### Service State Machine - Mediator POV
-
-```mermaid
-stateDiagram-v2
- state "Idle" as idle
- [*] --> idle
- idle --> [*]
- idle --> recieved_forward_message :New msg type forward
- recieved_forward_message --> idle :Invalid Request
- recieved_forward_message --> *process_forward_message :Valid Request
- *process_forward_message --> idle
- idle --> recieved_mailbox_operation :New msg type mailbox operation
- recieved_mailbox_operation --> idle :Invalid Request
- recieved_mailbox_operation --> *process_mailbox_operation :Valid Request
- *process_mailbox_operation --> idle
-```
-
-```mermaid
-stateDiagram-v2
- [*] --> process_forward_message
- process_forward_message --> storeMessage
- storeMessage --> notify_recipient :Message stored
- notify_recipient --> notify_recipient :retry
- notify_recipient --> [*] :acknowledge (or get \n a pickup operation)
- notify_recipient --> [*] :timeout \n (like after 1 year)
-```
-
-```mermaid
-stateDiagram-v2
- [*] --> process_mailbox_operation
- process_mailbox_operation --> send_challenge
- send_challenge --> [*] :timeout (like \n 10min session)
- send_challenge --> *operation :challenge response
- *operation --> [*]
-```
-
-NOTE: message_sent is just a operation type!!
-
-FIXME replace "pickup" with "operation"
-
-TODO: the last diagram is maybe its on protocol.
-(Does a challenge protocol already exists) ???
-
----
-
-### Service State Machine - Alice Agent POV
-
-**Pickup Operation:**
-
-```mermaid
-stateDiagram-v2
-[*] --> messages_requested :Requested pending messages pickup
-messages_requested --> message_replyed :Recived message solve the Challenge
-message_replyed --> recieve_messages :recived the messages
-message_replyed --> messages_requested :Retry with new challenge
-recieve_messages --> messages_requested :Request more messages
-recieve_messages --> [*]
-```
diff --git a/mercury/mercury-library/protocol-mercury-mailbox/src/main/scala/io/iohk/atala/mercury/protocol/mailbox/Mailbox.scala b/mercury/mercury-library/protocol-mercury-mailbox/src/main/scala/io/iohk/atala/mercury/protocol/mailbox/Mailbox.scala
deleted file mode 100644
index bbbfb13dc6..0000000000
--- a/mercury/mercury-library/protocol-mercury-mailbox/src/main/scala/io/iohk/atala/mercury/protocol/mailbox/Mailbox.scala
+++ /dev/null
@@ -1,26 +0,0 @@
-package io.iohk.atala.mercury.protocol.mailbox
-
-import io.iohk.atala.mercury.model.{DidId, Message, PIURI}
-import io.circe.JsonObject
-
-object Mailbox {
- def `type`: PIURI = "https://atalaprism.io/mercury/mailbox/1.0/ReadMessages"
-
- final case class ReadMessage(
- id: String = java.util.UUID.randomUUID.toString(),
- from: DidId,
- to: DidId,
- expires_time: Option[Long],
- ) {
-
- def asMessage = {
- Message(
- from = Some(from),
- to = Seq(to),
- body = JsonObject.empty,
- id = id,
- `type` = `type`
- )
- }
- }
-}
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/DidAgent.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/DidAgent.scala
similarity index 71%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/DidAgent.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/DidAgent.scala
index 5edd5c8cd6..c8dbfdd621 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/DidAgent.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/DidAgent.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import com.nimbusds.jose.jwk.*
-import io.iohk.atala.mercury.model.DidId
+import org.hyperledger.identus.mercury.model.DidId
/** Represente a Decentralized Identifier with secrets keys */
trait DidAgent {
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/DidOps.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/DidOps.scala
similarity index 95%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/DidOps.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/DidOps.scala
index 184a880f8e..fb9309ff45 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/DidOps.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/DidOps.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
import zio._
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model._
import java.util.Base64
import scala.util.Try
import scala.util.Failure
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/MediaTypes.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/MediaTypes.scala
similarity index 83%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/MediaTypes.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/MediaTypes.scala
index 583796fe72..db9f6bfacd 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/MediaTypes.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/MediaTypes.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury
+package org.hyperledger.identus.mercury
object MediaTypes {
val contentTypePlain = "application/didcomm-plain+json"
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/AttachmentDescriptor.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/AttachmentDescriptor.scala
similarity index 99%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/AttachmentDescriptor.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/AttachmentDescriptor.scala
index 8da40854fc..da4357d3df 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/AttachmentDescriptor.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/AttachmentDescriptor.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
import java.util.Base64 as JBase64
import io.circe.{Decoder, Encoder, HCursor, Json, JsonObject}
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/DidId.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/DidId.scala
similarity index 86%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/DidId.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/DidId.scala
index e608396e4f..696c40637d 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/DidId.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/DidId.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
import io.circe._
import io.circe.generic.semiauto._
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/EncryptedMessage.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/EncryptedMessage.scala
similarity index 91%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/EncryptedMessage.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/EncryptedMessage.scala
index 1fa43807c5..83464d5e17 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/EncryptedMessage.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/EncryptedMessage.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
// import org.didcommx.didcomm.model.PackEncryptedResult //FIXME REMOVE
import java.util.Base64
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/Message.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/Message.scala
similarity index 95%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/Message.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/Message.scala
index af6571aba4..190cb802a0 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/Message.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/Message.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
import java.time.LocalDateTime
import java.time.ZoneOffset
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/SignedMesage.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/SignedMesage.scala
similarity index 76%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/SignedMesage.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/SignedMesage.scala
index e161a62140..743c8b3490 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/SignedMesage.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/SignedMesage.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
import java.util.Base64
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/UnpackResult.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/UnpackResult.scala
similarity index 51%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/UnpackResult.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/UnpackResult.scala
index 51ebee26b8..04b7208d18 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/UnpackResult.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/UnpackResult.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury.model
trait UnpackMessage {
def message: Message
diff --git a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/error/package.scala b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/error/package.scala
similarity index 96%
rename from mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/error/package.scala
rename to mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/error/package.scala
index 62feec8cb3..e354be20a7 100644
--- a/mercury/mercury-library/models/src/main/scala/io/iohk/atala/mercury/model/error/package.scala
+++ b/mercury/models/src/main/scala/org/hyperledger/identus/mercury/model/error/package.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.model
+package org.hyperledger.identus.mercury
import java.io.IOException
diff --git a/mercury/mercury-library/protocol-connection/Connection-Protocol.md b/mercury/protocol-connection/Connection-Protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-connection/Connection-Protocol.md
rename to mercury/protocol-connection/Connection-Protocol.md
diff --git a/mercury/mercury-library/protocol-connection/src/main/scala/io/iohk/atala/mercury/protocol/connection/ConnectionInvitation.scala b/mercury/protocol-connection/src/main/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionInvitation.scala
similarity index 65%
rename from mercury/mercury-library/protocol-connection/src/main/scala/io/iohk/atala/mercury/protocol/connection/ConnectionInvitation.scala
rename to mercury/protocol-connection/src/main/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionInvitation.scala
index 691f5805bd..928759d16b 100644
--- a/mercury/mercury-library/protocol-connection/src/main/scala/io/iohk/atala/mercury/protocol/connection/ConnectionInvitation.scala
+++ b/mercury/protocol-connection/src/main/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionInvitation.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.mercury.protocol.connection
+package org.hyperledger.identus.mercury.protocol.connection
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation.Body
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation.Body
object ConnectionInvitation {
@@ -10,7 +10,7 @@ object ConnectionInvitation {
def makeConnectionInvitation(from: DidId): Invitation = {
makeConnectionInvitation(
from = from,
- goalCode = Some("io.atalaprism.connect"),
+ goalCode = Some("org.hyperledger.identus.connect"),
goal = Some(s"Establish a trust connection between two peers using the protocol '${ConnectionRequest.`type`}'")
)
}
diff --git a/mercury/mercury-library/protocol-connection/src/main/scala/io/iohk/atala/mercury/protocol/connection/ConnectionRequest.scala b/mercury/protocol-connection/src/main/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionRequest.scala
similarity index 91%
rename from mercury/mercury-library/protocol-connection/src/main/scala/io/iohk/atala/mercury/protocol/connection/ConnectionRequest.scala
rename to mercury/protocol-connection/src/main/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionRequest.scala
index 4915354659..cbb7c942f9 100644
--- a/mercury/mercury-library/protocol-connection/src/main/scala/io/iohk/atala/mercury/protocol/connection/ConnectionRequest.scala
+++ b/mercury/protocol-connection/src/main/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionRequest.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.mercury.protocol.connection
+package org.hyperledger.identus.mercury.protocol.connection
+
import io.circe.generic.semiauto.{deriveDecoder, deriveEncoder}
import io.circe.{Decoder, Encoder}
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, DidId, Message, PIURI}
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, DidId, Message, PIURI}
import io.circe.syntax.*
-import io.iohk.atala.mercury.protocol.connection.ConnectionRequest.Body
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation
object ConnectionRequest {
def `type`: PIURI = "https://atalaprism.io/mercury/connections/1.0/request"
@@ -80,7 +80,7 @@ final case class ConnectionRequest(
to: DidId,
thid: Option[String],
pthid: Option[String],
- body: Body,
+ body: ConnectionRequest.Body,
) {
assert(`type` == "https://atalaprism.io/mercury/connections/1.0/request")
diff --git a/mercury/mercury-library/protocol-connection/src/main/scala/io/iohk/atala/mercury/protocol/connection/ConnectionResponse.scala b/mercury/protocol-connection/src/main/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionResponse.scala
similarity index 95%
rename from mercury/mercury-library/protocol-connection/src/main/scala/io/iohk/atala/mercury/protocol/connection/ConnectionResponse.scala
rename to mercury/protocol-connection/src/main/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionResponse.scala
index 4a2aa8cd3b..86815d124e 100644
--- a/mercury/mercury-library/protocol-connection/src/main/scala/io/iohk/atala/mercury/protocol/connection/ConnectionResponse.scala
+++ b/mercury/protocol-connection/src/main/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionResponse.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.mercury.protocol.connection
+package org.hyperledger.identus.mercury.protocol.connection
import io.circe.{Decoder, Encoder}
import io.circe.generic.semiauto.{deriveDecoder, deriveEncoder}
-import io.iohk.atala.mercury.model.{DidId, Message, PIURI}
+import org.hyperledger.identus.mercury.model.{DidId, Message, PIURI}
import io.circe.syntax.*
object ConnectionResponse {
diff --git a/mercury/mercury-library/protocol-connection/src/test/scala/io/iohk/atala/mercury/protocol/connection/ConnectionSpec.scala b/mercury/protocol-connection/src/test/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionSpec.scala
similarity index 94%
rename from mercury/mercury-library/protocol-connection/src/test/scala/io/iohk/atala/mercury/protocol/connection/ConnectionSpec.scala
rename to mercury/protocol-connection/src/test/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionSpec.scala
index 2af194eacf..73f3d34d05 100644
--- a/mercury/mercury-library/protocol-connection/src/test/scala/io/iohk/atala/mercury/protocol/connection/ConnectionSpec.scala
+++ b/mercury/protocol-connection/src/test/scala/org/hyperledger/identus/mercury/protocol/connection/ConnectionSpec.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.mercury.protocol.connection
+package org.hyperledger.identus.mercury.protocol.connection
import io.circe._
import io.circe.parser._
import munit.*
-import io.iohk.atala.mercury.model.*
+import org.hyperledger.identus.mercury.model.{Message, DidId}
-/** protocolConnection/testOnly io.iohk.atala.mercury.protocol.connection.CoordinateMediationSpec */
+/** protocolConnection/testOnly org.hyperledger.identus.mercury.protocol.connection.CoordinateMediationSpec */
class CoordinateMediationSpec extends ZSuite {
test("parse ConnectionRequest") {
diff --git a/mercury/mercury-library/protocol-coordinate-mediation/Coordinate-Mediation-Protocol.md b/mercury/protocol-coordinate-mediation/Coordinate-Mediation-Protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-coordinate-mediation/Coordinate-Mediation-Protocol.md
rename to mercury/protocol-coordinate-mediation/Coordinate-Mediation-Protocol.md
diff --git a/mercury/mercury-library/protocol-coordinate-mediation/src/main/scala/io/iohk/atala/mercury/protocol/coordinatemediation/CoordinateMediation.scala b/mercury/protocol-coordinate-mediation/src/main/scala/org/hyperledger/identus/mercury/protocol/coordinatemediation/CoordinateMediation.scala
similarity index 97%
rename from mercury/mercury-library/protocol-coordinate-mediation/src/main/scala/io/iohk/atala/mercury/protocol/coordinatemediation/CoordinateMediation.scala
rename to mercury/protocol-coordinate-mediation/src/main/scala/org/hyperledger/identus/mercury/protocol/coordinatemediation/CoordinateMediation.scala
index cc6c9f7f65..640cd9ebb2 100644
--- a/mercury/mercury-library/protocol-coordinate-mediation/src/main/scala/io/iohk/atala/mercury/protocol/coordinatemediation/CoordinateMediation.scala
+++ b/mercury/protocol-coordinate-mediation/src/main/scala/org/hyperledger/identus/mercury/protocol/coordinatemediation/CoordinateMediation.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.mercury.protocol.coordinatemediation
+package org.hyperledger.identus.mercury.protocol.coordinatemediation
-import io.iohk.atala.mercury.model.PIURI
+import org.hyperledger.identus.mercury.model.PIURI
import io.circe._
import io.circe.generic.semiauto._
diff --git a/mercury/mercury-library/protocol-coordinate-mediation/src/test/scala/io/iohk/atala/mercury/protocol/coordinatemediation/CoordinateMediationSpec.scala b/mercury/protocol-coordinate-mediation/src/test/scala/org/hyperledger/identus/mercury/protocol/coordinatemediation/CoordinateMediationSpec.scala
similarity index 94%
rename from mercury/mercury-library/protocol-coordinate-mediation/src/test/scala/io/iohk/atala/mercury/protocol/coordinatemediation/CoordinateMediationSpec.scala
rename to mercury/protocol-coordinate-mediation/src/test/scala/org/hyperledger/identus/mercury/protocol/coordinatemediation/CoordinateMediationSpec.scala
index 066917aca1..76e5464f17 100644
--- a/mercury/mercury-library/protocol-coordinate-mediation/src/test/scala/io/iohk/atala/mercury/protocol/coordinatemediation/CoordinateMediationSpec.scala
+++ b/mercury/protocol-coordinate-mediation/src/test/scala/org/hyperledger/identus/mercury/protocol/coordinatemediation/CoordinateMediationSpec.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.protocol.coordinatemediation
+package org.hyperledger.identus.mercury.protocol.coordinatemediation
import io.circe._
import io.circe.parser._
diff --git a/mercury/mercury-library/protocol-did-exchange/DidExchange-Protocol.md b/mercury/protocol-did-exchange/DidExchange-Protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-did-exchange/DidExchange-Protocol.md
rename to mercury/protocol-did-exchange/DidExchange-Protocol.md
diff --git a/mercury/mercury-library/protocol-did-exchange/src/main/scala/io/iohk/atala/mercury/protocol/didexchange/v1/DidExchangeRequest.scala b/mercury/protocol-did-exchange/src/main/scala/org/hyperledger/identus/mercury/protocol/didexchange/v1/DidExchangeRequest.scala
similarity index 65%
rename from mercury/mercury-library/protocol-did-exchange/src/main/scala/io/iohk/atala/mercury/protocol/didexchange/v1/DidExchangeRequest.scala
rename to mercury/protocol-did-exchange/src/main/scala/org/hyperledger/identus/mercury/protocol/didexchange/v1/DidExchangeRequest.scala
index 038611036b..877a50ba0c 100644
--- a/mercury/mercury-library/protocol-did-exchange/src/main/scala/io/iohk/atala/mercury/protocol/didexchange/v1/DidExchangeRequest.scala
+++ b/mercury/protocol-did-exchange/src/main/scala/org/hyperledger/identus/mercury/protocol/didexchange/v1/DidExchangeRequest.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.mercury.protocol.didexchange.v1
+package org.hyperledger.identus.mercury.protocol.didexchange.v1
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, PIURI}
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, PIURI}
final case class Thread(thid: String, pthid: String)
diff --git a/mercury/mercury-library/protocol-invitation/Invitation-Protocol.md b/mercury/protocol-invitation/Invitation-Protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-invitation/Invitation-Protocol.md
rename to mercury/protocol-invitation/Invitation-Protocol.md
diff --git a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/OutOfBand.scala b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/OutOfBand.scala
similarity index 84%
rename from mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/OutOfBand.scala
rename to mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/OutOfBand.scala
index 8a8976cb0e..7cd2a59be5 100644
--- a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/OutOfBand.scala
+++ b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/OutOfBand.scala
@@ -1,11 +1,10 @@
-package io.iohk.atala.mercury.protocol.invitation
+package org.hyperledger.identus.mercury.protocol.invitation
import java.net.URL
import java.{util => ju}
-import io.iohk.atala.mercury.protocol.invitation.v2._
+import org.hyperledger.identus.mercury.protocol.invitation.v2._
import io.circe._
import io.circe.parser._
-import io.iohk.atala.mercury
object OutOfBand {
diff --git a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/ServiceType.scala b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/ServiceType.scala
similarity index 95%
rename from mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/ServiceType.scala
rename to mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/ServiceType.scala
index 8581355844..7f3ea642ec 100644
--- a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/ServiceType.scala
+++ b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/ServiceType.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.protocol.invitation
+package org.hyperledger.identus.mercury.protocol.invitation
import cats.implicits._
import io.circe.syntax._
import io.circe.generic.semiauto.{deriveDecoder, deriveEncoder}
diff --git a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/package.scala b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/package.scala
similarity index 74%
rename from mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/package.scala
rename to mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/package.scala
index d6e04a4d5c..cd6e3156fa 100644
--- a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/package.scala
+++ b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/package.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.protocol
+package org.hyperledger.identus.mercury.protocol
package object invitation {
diff --git a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/v1/Invitation.scala b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/v1/Invitation.scala
similarity index 75%
rename from mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/v1/Invitation.scala
rename to mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/v1/Invitation.scala
index f38625ea98..05245b0d57 100644
--- a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/v1/Invitation.scala
+++ b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/v1/Invitation.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.mercury.protocol.invitation.v1
+package org.hyperledger.identus.mercury.protocol.invitation.v1
import io.circe.syntax.*
import io.circe.generic.semiauto.*
import io.circe.{Decoder, Encoder, Json}
-import io.iohk.atala.mercury.model.PIURI
+import org.hyperledger.identus.mercury.model.PIURI
-import io.iohk.atala.mercury.model.AttachmentDescriptor
-import io.iohk.atala.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV1
-import io.iohk.atala.mercury.protocol.invitation.ServiceType
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV1
+import org.hyperledger.identus.mercury.protocol.invitation.ServiceType
/** Out-Of-Band invitation Example
* @see
@@ -21,7 +21,7 @@ import io.iohk.atala.mercury.protocol.invitation.ServiceType
* @param services
*/
final case class Invitation(
- `@id`: String = io.iohk.atala.mercury.protocol.invitation.getNewMsgId,
+ `@id`: String = org.hyperledger.identus.mercury.protocol.invitation.getNewMsgId,
label: String,
goal: String,
goal_code: String,
diff --git a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/v2/Invitation.scala b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/v2/Invitation.scala
similarity index 81%
rename from mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/v2/Invitation.scala
rename to mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/v2/Invitation.scala
index 9cfb4711c4..e4105deb8b 100644
--- a/mercury/mercury-library/protocol-invitation/src/main/scala/io/iohk/atala/mercury/protocol/invitation/v2/Invitation.scala
+++ b/mercury/protocol-invitation/src/main/scala/org/hyperledger/identus/mercury/protocol/invitation/v2/Invitation.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.mercury.protocol.invitation.v2
+package org.hyperledger.identus.mercury.protocol.invitation.v2
import io.circe.syntax.*
import io.circe.{Decoder, Encoder}
-import io.iohk.atala.mercury.model.*
-import AttachmentDescriptor.attachmentDescriptorEncoderV2
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
import io.circe.generic.semiauto._
+import org.hyperledger.identus.mercury.model.{PIURI, AttachmentDescriptor, DidId}
/** Out-Of-Band invitation
* @see
diff --git a/mercury/mercury-library/protocol-invitation/src/test/scala/io/iohk/atala/mercury/protocol/invitation/v1/InvitationV1Spec.scala b/mercury/protocol-invitation/src/test/scala/org/hyperledger/identus/mercury/protocol/invitation/v1/InvitationV1Spec.scala
similarity index 92%
rename from mercury/mercury-library/protocol-invitation/src/test/scala/io/iohk/atala/mercury/protocol/invitation/v1/InvitationV1Spec.scala
rename to mercury/protocol-invitation/src/test/scala/org/hyperledger/identus/mercury/protocol/invitation/v1/InvitationV1Spec.scala
index 470c230557..520d66b5a5 100644
--- a/mercury/mercury-library/protocol-invitation/src/test/scala/io/iohk/atala/mercury/protocol/invitation/v1/InvitationV1Spec.scala
+++ b/mercury/protocol-invitation/src/test/scala/org/hyperledger/identus/mercury/protocol/invitation/v1/InvitationV1Spec.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.mercury.protocol.invitation.v1
+package org.hyperledger.identus.mercury.protocol.invitation.v1
import munit.*
import io.circe.syntax._
import io.circe.Json
import io.circe.parser._
-import io.iohk.atala.mercury.protocol.invitation._
-import io.iohk.atala.mercury.model.AttachmentDescriptor
+import org.hyperledger.identus.mercury.protocol.invitation._
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor
class InvitationV1Spec extends ZSuite {
diff --git a/mercury/mercury-library/protocol-invitation/src/test/scala/io/iohk/atala/mercury/protocol/invitation/v2/OutOfBandSpec.scala b/mercury/protocol-invitation/src/test/scala/org/hyperledger/identus/mercury/protocol/invitation/v2/OutOfBandSpec.scala
similarity index 80%
rename from mercury/mercury-library/protocol-invitation/src/test/scala/io/iohk/atala/mercury/protocol/invitation/v2/OutOfBandSpec.scala
rename to mercury/protocol-invitation/src/test/scala/org/hyperledger/identus/mercury/protocol/invitation/v2/OutOfBandSpec.scala
index 87eb8f60e0..0ab35ce3ff 100644
--- a/mercury/mercury-library/protocol-invitation/src/test/scala/io/iohk/atala/mercury/protocol/invitation/v2/OutOfBandSpec.scala
+++ b/mercury/protocol-invitation/src/test/scala/org/hyperledger/identus/mercury/protocol/invitation/v2/OutOfBandSpec.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.mercury.protocol.invitation.v2
+package org.hyperledger.identus.mercury.protocol.invitation.v2
import munit.*
-import io.iohk.atala.mercury.protocol.invitation.v2._
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.invitation.v2.Invitation.Body
-import io.iohk.atala.mercury.protocol.invitation.OutOfBand
+import org.hyperledger.identus.mercury.protocol.invitation.v2._
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.invitation.v2.Invitation.Body
+import org.hyperledger.identus.mercury.protocol.invitation.OutOfBand
class OutOfBandSpec extends FunSuite {
test("out-of-band (_oob URL) messagem parsing into Invitation") {
diff --git a/mercury/mercury-library/protocol-issue-credential/Issue-Credential-Protocol.md b/mercury/protocol-issue-credential/Issue-Credential-Protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-issue-credential/Issue-Credential-Protocol.md
rename to mercury/protocol-issue-credential/Issue-Credential-Protocol.md
diff --git a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/Credential.scala b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/Credential.scala
similarity index 92%
rename from mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/Credential.scala
rename to mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/Credential.scala
index 405c2a8065..d49bfc4403 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/Credential.scala
+++ b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/Credential.scala
@@ -1,5 +1,5 @@
/*
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe.generic.semiauto.*
import io.circe.{Decoder, Encoder}
final case class Attribute(
diff --git a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/CredentialPreview.scala b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/CredentialPreview.scala
similarity index 97%
rename from mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/CredentialPreview.scala
rename to mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/CredentialPreview.scala
index f354cc0136..5ea3ef8308 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/CredentialPreview.scala
+++ b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/CredentialPreview.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe.generic.semiauto.*
import io.circe.{Decoder, Encoder}
diff --git a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/IssueCredential.scala b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/IssueCredential.scala
similarity index 95%
rename from mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/IssueCredential.scala
rename to mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/IssueCredential.scala
index 1d5fa0ca14..bb14f716fe 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/IssueCredential.scala
+++ b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/IssueCredential.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe._
import io.circe.generic.semiauto._
import io.circe.syntax._
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.{PIURI, AttachmentDescriptor, Message, DidId}
/** ALL parameterS are DIDCOMMV2 format and naming conventions and follows the protocol
* @see
diff --git a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/IssueFormats.scala b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/IssueFormats.scala
similarity index 99%
rename from mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/IssueFormats.scala
rename to mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/IssueFormats.scala
index f731449e0b..0ac5ab79dd 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/IssueFormats.scala
+++ b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/IssueFormats.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe.generic.semiauto.*
import io.circe.{Decoder, Encoder}
diff --git a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/OfferCredential.scala b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/OfferCredential.scala
similarity index 94%
rename from mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/OfferCredential.scala
rename to mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/OfferCredential.scala
index ef66589de5..6a8cb76d26 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/OfferCredential.scala
+++ b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/OfferCredential.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe._
import io.circe.generic.semiauto._
import io.circe.syntax._
-import io.iohk.atala.mercury.model.PIURI
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.PIURI
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, Message, DidId}
/** ALL parameterS are DIDCOMMV2 format and naming conventions and follows the protocol
* @see
diff --git a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/ProposeCredential.scala b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/ProposeCredential.scala
similarity index 93%
rename from mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/ProposeCredential.scala
rename to mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/ProposeCredential.scala
index b8e24f204b..445a9e5d57 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/ProposeCredential.scala
+++ b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/ProposeCredential.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe._
import io.circe.generic.semiauto._
import io.circe.syntax._
-import io.iohk.atala.mercury.model.PIURI
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.PIURI
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, Message, DidId}
/** ALL parameterS are DIDCOMMV2 format and naming conventions and follows the protocol
* @see
diff --git a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/RequestCredential.scala b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/RequestCredential.scala
similarity index 93%
rename from mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/RequestCredential.scala
rename to mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/RequestCredential.scala
index 294b564a2b..4d40f4da5e 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/RequestCredential.scala
+++ b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/RequestCredential.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe._
import io.circe.generic.semiauto._
import io.circe.syntax._
-import io.iohk.atala.mercury.model.PIURI
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.PIURI
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, Message, DidId}
final case class RequestCredential(
id: String = java.util.UUID.randomUUID.toString(),
diff --git a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/Utils.scala b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/Utils.scala
similarity index 88%
rename from mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/Utils.scala
rename to mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/Utils.scala
index 61f5ed5000..d87c49a7e5 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/main/scala/io/iohk/atala/mercury/protocol/issuecredential/Utils.scala
+++ b/mercury/protocol-issue-credential/src/main/scala/org/hyperledger/identus/mercury/protocol/issuecredential/Utils.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe.syntax._
import io.circe.parser._
-import io.iohk.atala.mercury.model._
import io.circe.Decoder
+import org.hyperledger.identus.mercury.model.{LinkData, JsonData, AttachmentDescriptor, Base64, JwsData}
private[this] trait ReadAttachmentsUtils {
diff --git a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/anotherclasspath/UtilsCredentialSpec.scala b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/anotherclasspath/UtilsCredentialSpec.scala
similarity index 88%
rename from mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/anotherclasspath/UtilsCredentialSpec.scala
rename to mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/anotherclasspath/UtilsCredentialSpec.scala
index a9875c4fdd..8ad4467c9c 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/anotherclasspath/UtilsCredentialSpec.scala
+++ b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/anotherclasspath/UtilsCredentialSpec.scala
@@ -1,12 +1,22 @@
-package io.iohk.atala.mercury.protocol.anotherclasspath
+package org.hyperledger.identus.mercury.protocol.anotherclasspath
import io.circe.*
import io.circe.syntax.*
import io.circe.generic.semiauto.*
import munit.*
-import io.iohk.atala.mercury.model._
-import io.iohk.atala.mercury.protocol.issuecredential._
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, DidId}
+import org.hyperledger.identus.mercury.protocol.issuecredential.{
+ IssueCredential,
+ IssueCredentialProposeFormat,
+ OfferCredential,
+ ProposeCredential,
+ CredentialPreview,
+ RequestCredential,
+ IssueCredentialIssuedFormat,
+ IssueCredentialOfferFormat,
+ IssueCredentialRequestFormat
+}
private[this] case class TestCredentialType(a: String, b: Int, x: Long, name: String, dob: String)
private[this] object TestCredentialType {
@@ -14,7 +24,7 @@ private[this] object TestCredentialType {
given Decoder[TestCredentialType] = deriveDecoder[TestCredentialType]
}
-/** testOnly io.iohk.atala.mercury.protocol.anotherclasspath.UtilsCredentialSpec
+/** testOnly org.hyperledger.identus.mercury.protocol.anotherclasspath.UtilsCredentialSpec
*/
class UtilsCredentialSpec extends ZSuite {
val nameCredentialType = "prism/TestCredentialType"
diff --git a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/IssueCredentialSpec.scala b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/IssueCredentialSpec.scala
similarity index 89%
rename from mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/IssueCredentialSpec.scala
rename to mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/IssueCredentialSpec.scala
index c6bdc7d749..d79b9195e8 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/IssueCredentialSpec.scala
+++ b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/IssueCredentialSpec.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe.Json
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.mercury.model.AttachmentDescriptor
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor
import munit.*
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.DidId
class IssueCredentialSpec extends ZSuite {
diff --git a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/OfferCredentialSpec.scala b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/OfferCredentialSpec.scala
similarity index 89%
rename from mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/OfferCredentialSpec.scala
rename to mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/OfferCredentialSpec.scala
index 68dc9cdb9a..f0c7589a3b 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/OfferCredentialSpec.scala
+++ b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/OfferCredentialSpec.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe.Json
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, DidId}
-import io.iohk.atala.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, DidId}
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
import munit.*
-import io.iohk.atala.mercury.model._
+
class OfferCredentialSpec extends ZSuite {
test("Issuer OfferCredential") {
diff --git a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/ProposeCredentialSpec.scala b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/ProposeCredentialSpec.scala
similarity index 87%
rename from mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/ProposeCredentialSpec.scala
rename to mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/ProposeCredentialSpec.scala
index e186fcf21b..05615f298a 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/ProposeCredentialSpec.scala
+++ b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/ProposeCredentialSpec.scala
@@ -1,12 +1,13 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe.Json
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.mercury.model.AttachmentDescriptor
-import io.iohk.atala.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
import munit.*
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.DidId
+
class ProposeCredentialSpec extends ZSuite {
test("Holder ProposeCredential") {
diff --git a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/RequestCredentialSpec.scala b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/RequestCredentialSpec.scala
similarity index 86%
rename from mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/RequestCredentialSpec.scala
rename to mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/RequestCredentialSpec.scala
index 99e06079e1..7a184edb33 100644
--- a/mercury/mercury-library/protocol-issue-credential/src/test/scala/io/iohk/atala/mercury/protocol/issuecredential/RequestCredentialSpec.scala
+++ b/mercury/protocol-issue-credential/src/test/scala/org/hyperledger/identus/mercury/protocol/issuecredential/RequestCredentialSpec.scala
@@ -1,12 +1,11 @@
-package io.iohk.atala.mercury.protocol.issuecredential
+package org.hyperledger.identus.mercury.protocol.issuecredential
import io.circe.Json
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, DidId}
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, DidId}
import munit.*
-import io.iohk.atala.mercury.model._
class RequestCredentialSpec extends ZSuite {
test("Holder RequestCredential") {
diff --git a/mercury/mercury-library/protocol-outofband-login/OutOfBand-Login-Protocol.md b/mercury/protocol-outofband-login/OutOfBand-Login-Protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-outofband-login/OutOfBand-Login-Protocol.md
rename to mercury/protocol-outofband-login/OutOfBand-Login-Protocol.md
diff --git a/mercury/mercury-library/protocol-outofband-login/src/main/scala/io/iohk/atala/mercury/protocol/outofbandlogin/OutOfBandLogin.scala b/mercury/protocol-outofband-login/src/main/scala/org/hyperledger/identus/mercury/protocol/outofbandlogin/OutOfBandLogin.scala
similarity index 85%
rename from mercury/mercury-library/protocol-outofband-login/src/main/scala/io/iohk/atala/mercury/protocol/outofbandlogin/OutOfBandLogin.scala
rename to mercury/protocol-outofband-login/src/main/scala/org/hyperledger/identus/mercury/protocol/outofbandlogin/OutOfBandLogin.scala
index 2cf2b5e592..49ba39d758 100644
--- a/mercury/mercury-library/protocol-outofband-login/src/main/scala/io/iohk/atala/mercury/protocol/outofbandlogin/OutOfBandLogin.scala
+++ b/mercury/protocol-outofband-login/src/main/scala/org/hyperledger/identus/mercury/protocol/outofbandlogin/OutOfBandLogin.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.mercury.protocol.outofbandlogin
+package org.hyperledger.identus.mercury.protocol.outofbandlogin
-import io.iohk.atala.mercury.model.PIURI
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.model.Message
+import org.hyperledger.identus.mercury.model.PIURI
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.model.Message
/** Out-Of-Band Login Invitation
* @see
diff --git a/mercury/mercury-library/protocol-outofband-login/src/main/scala/io/iohk/atala/mercury/protocol/outofbandlogin/Utils.scala b/mercury/protocol-outofband-login/src/main/scala/org/hyperledger/identus/mercury/protocol/outofbandlogin/Utils.scala
similarity index 86%
rename from mercury/mercury-library/protocol-outofband-login/src/main/scala/io/iohk/atala/mercury/protocol/outofbandlogin/Utils.scala
rename to mercury/protocol-outofband-login/src/main/scala/org/hyperledger/identus/mercury/protocol/outofbandlogin/Utils.scala
index 3046f9054d..675933383e 100644
--- a/mercury/mercury-library/protocol-outofband-login/src/main/scala/io/iohk/atala/mercury/protocol/outofbandlogin/Utils.scala
+++ b/mercury/protocol-outofband-login/src/main/scala/org/hyperledger/identus/mercury/protocol/outofbandlogin/Utils.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.mercury.protocol.outofbandlogin
+package org.hyperledger.identus.mercury.protocol.outofbandlogin
import java.net.URL
-import io.iohk.atala.mercury
+import org.hyperledger.identus.mercury
object Utils {
diff --git a/mercury/mercury-library/protocol-present-proof/Present-Proof-Protocol.md b/mercury/protocol-present-proof/Present-Proof-Protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-present-proof/Present-Proof-Protocol.md
rename to mercury/protocol-present-proof/Present-Proof-Protocol.md
diff --git a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/PresentFormats.scala b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/PresentFormats.scala
similarity index 98%
rename from mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/PresentFormats.scala
rename to mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/PresentFormats.scala
index 010f7f8df3..8eb6340370 100644
--- a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/PresentFormats.scala
+++ b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/PresentFormats.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.protocol.presentproof
+package org.hyperledger.identus.mercury.protocol.presentproof
import io.circe.generic.semiauto.*
import io.circe.{Decoder, Encoder}
diff --git a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/Presentation.scala b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/Presentation.scala
similarity index 95%
rename from mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/Presentation.scala
rename to mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/Presentation.scala
index e7873bb70e..acedadc0aa 100644
--- a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/Presentation.scala
+++ b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/Presentation.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.mercury.protocol.presentproof
+package org.hyperledger.identus.mercury.protocol.presentproof
import io.circe.{Decoder, Encoder}
import io.circe.generic.semiauto.*
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, DidId, Message, PIURI}
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, DidId, Message, PIURI}
import io.circe.syntax._
/** @param attach_id
diff --git a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/ProofType.scala b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/ProofType.scala
similarity index 77%
rename from mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/ProofType.scala
rename to mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/ProofType.scala
index 7a2abba6cc..be90209ff4 100644
--- a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/ProofType.scala
+++ b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/ProofType.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.mercury.protocol.presentproof
+package org.hyperledger.identus.mercury.protocol.presentproof
import io.circe._
import io.circe.generic.semiauto._
-import io.iohk.atala.mercury.model.DidId
+import org.hyperledger.identus.mercury.model.DidId
case class ProofType(
schema: String, // Schema ID EX: https://schema.org/Person
diff --git a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/ProposePresentation.scala b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/ProposePresentation.scala
similarity index 94%
rename from mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/ProposePresentation.scala
rename to mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/ProposePresentation.scala
index 5d83f64cdf..faf310ca3d 100644
--- a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/ProposePresentation.scala
+++ b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/ProposePresentation.scala
@@ -1,11 +1,10 @@
-package io.iohk.atala.mercury.protocol.presentproof
+package org.hyperledger.identus.mercury.protocol.presentproof
import io.circe._
import io.circe.generic.semiauto._
import io.circe.syntax._
-import io.iohk.atala.mercury.model.PIURI
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model._
/** ALL parameterS are DIDCOMMV2 format and naming conventions and follows the protocol
* @see
diff --git a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/RequestPresentation.scala b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/RequestPresentation.scala
similarity index 95%
rename from mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/RequestPresentation.scala
rename to mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/RequestPresentation.scala
index e4ec59ee87..f787cdecbf 100644
--- a/mercury/mercury-library/protocol-present-proof/src/main/scala/io/iohk/atala/mercury/protocol/presentproof/RequestPresentation.scala
+++ b/mercury/protocol-present-proof/src/main/scala/org/hyperledger/identus/mercury/protocol/presentproof/RequestPresentation.scala
@@ -1,11 +1,10 @@
-package io.iohk.atala.mercury.protocol.presentproof
+package org.hyperledger.identus.mercury.protocol.presentproof
import io.circe._
import io.circe.generic.semiauto._
import io.circe.syntax._
-import io.iohk.atala.mercury.model.PIURI
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model._
final case class RequestPresentation(
id: String = java.util.UUID.randomUUID.toString(),
diff --git a/mercury/mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala/mercury/protocol/presentproof/PresentationSpec.scala b/mercury/protocol-present-proof/src/test/scala/org/hyperledger/identus/mercury/protocol/presentproof/PresentationSpec.scala
similarity index 79%
rename from mercury/mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala/mercury/protocol/presentproof/PresentationSpec.scala
rename to mercury/protocol-present-proof/src/test/scala/org/hyperledger/identus/mercury/protocol/presentproof/PresentationSpec.scala
index 612bd83b60..90c7121b31 100644
--- a/mercury/mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala/mercury/protocol/presentproof/PresentationSpec.scala
+++ b/mercury/protocol-present-proof/src/test/scala/org/hyperledger/identus/mercury/protocol/presentproof/PresentationSpec.scala
@@ -1,12 +1,13 @@
-package io.iohk.atala.mercury.protocol.presentproof
+package org.hyperledger.identus.mercury.protocol.presentproof
import io.circe.Json
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.mercury.model.AttachmentDescriptor
-import io.iohk.atala.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
import munit.*
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.{LinkData, DidId}
+import org.hyperledger.identus.mercury.protocol.presentproof.Presentation
class PresentationSpec extends ZSuite {
diff --git a/mercury/mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala/mercury/protocol/presentproof/ProposePresentationProofSpec.scala b/mercury/protocol-present-proof/src/test/scala/org/hyperledger/identus/mercury/protocol/presentproof/ProposePresentationProofSpec.scala
similarity index 82%
rename from mercury/mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala/mercury/protocol/presentproof/ProposePresentationProofSpec.scala
rename to mercury/protocol-present-proof/src/test/scala/org/hyperledger/identus/mercury/protocol/presentproof/ProposePresentationProofSpec.scala
index 73763129a1..c87618d489 100644
--- a/mercury/mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala/mercury/protocol/presentproof/ProposePresentationProofSpec.scala
+++ b/mercury/protocol-present-proof/src/test/scala/org/hyperledger/identus/mercury/protocol/presentproof/ProposePresentationProofSpec.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.mercury.protocol.presentproof
+package org.hyperledger.identus.mercury.protocol.presentproof
import io.circe.Json
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.mercury.model.AttachmentDescriptor
-import io.iohk.atala.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
import munit.*
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.{LinkData, DidId}
class ProposePresentationSpec extends ZSuite {
diff --git a/mercury/mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala/mercury/protocol/presentproof/RequestPresentationSpec.scala b/mercury/protocol-present-proof/src/test/scala/org/hyperledger/identus/mercury/protocol/presentproof/RequestPresentationSpec.scala
similarity index 83%
rename from mercury/mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala/mercury/protocol/presentproof/RequestPresentationSpec.scala
rename to mercury/protocol-present-proof/src/test/scala/org/hyperledger/identus/mercury/protocol/presentproof/RequestPresentationSpec.scala
index 2e13b84118..4e2ba8525a 100644
--- a/mercury/mercury-library/protocol-present-proof/src/test/scala/io/iohk/atala/mercury/protocol/presentproof/RequestPresentationSpec.scala
+++ b/mercury/protocol-present-proof/src/test/scala/org/hyperledger/identus/mercury/protocol/presentproof/RequestPresentationSpec.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.mercury.protocol.presentproof
+package org.hyperledger.identus.mercury.protocol.presentproof
import io.circe.Json
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, DidId}
+import org.hyperledger.identus.mercury.model.AttachmentDescriptor.attachmentDescriptorEncoderV2
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, DidId}
import munit.*
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.LinkData
class RequestCredentialSpec extends ZSuite {
diff --git a/mercury/mercury-library/protocol-report-problem/Report-Problem-Protocol.md b/mercury/protocol-report-problem/Report-Problem-Protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-report-problem/Report-Problem-Protocol.md
rename to mercury/protocol-report-problem/Report-Problem-Protocol.md
diff --git a/mercury/mercury-library/protocol-report-problem/src/main/scala/io/iohk/atala/mercury/protocol/reportproblem/v1/ReportProblem.scala b/mercury/protocol-report-problem/src/main/scala/org/hyperledger/identus/mercury/protocol/reportproblem/v1/ReportProblem.scala
similarity index 94%
rename from mercury/mercury-library/protocol-report-problem/src/main/scala/io/iohk/atala/mercury/protocol/reportproblem/v1/ReportProblem.scala
rename to mercury/protocol-report-problem/src/main/scala/org/hyperledger/identus/mercury/protocol/reportproblem/v1/ReportProblem.scala
index 55f1d9a44e..6a4e9e4e15 100644
--- a/mercury/mercury-library/protocol-report-problem/src/main/scala/io/iohk/atala/mercury/protocol/reportproblem/v1/ReportProblem.scala
+++ b/mercury/protocol-report-problem/src/main/scala/org/hyperledger/identus/mercury/protocol/reportproblem/v1/ReportProblem.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.mercury.protocol.reportproblem.v1
+package org.hyperledger.identus.mercury.protocol.reportproblem.v1
-import io.iohk.atala.mercury.model.Message
-import io.iohk.atala.mercury.model.PIURI
+import org.hyperledger.identus.mercury.model.Message
+import org.hyperledger.identus.mercury.model.PIURI
/** ReportProblem
*
diff --git a/mercury/mercury-library/protocol-report-problem/src/main/scala/io/iohk/atala/mercury/protocol/reportproblem/v2/ReportProblem.scala b/mercury/protocol-report-problem/src/main/scala/org/hyperledger/identus/mercury/protocol/reportproblem/v2/ReportProblem.scala
similarity index 98%
rename from mercury/mercury-library/protocol-report-problem/src/main/scala/io/iohk/atala/mercury/protocol/reportproblem/v2/ReportProblem.scala
rename to mercury/protocol-report-problem/src/main/scala/org/hyperledger/identus/mercury/protocol/reportproblem/v2/ReportProblem.scala
index 6b96ed052d..2c621a4d16 100644
--- a/mercury/mercury-library/protocol-report-problem/src/main/scala/io/iohk/atala/mercury/protocol/reportproblem/v2/ReportProblem.scala
+++ b/mercury/protocol-report-problem/src/main/scala/org/hyperledger/identus/mercury/protocol/reportproblem/v2/ReportProblem.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.mercury.protocol.reportproblem.v2
+package org.hyperledger.identus.mercury.protocol.reportproblem.v2
import io.circe._
-import io.iohk.atala.mercury.model.{DidId, Message, PIURI}
+import org.hyperledger.identus.mercury.model.{DidId, Message, PIURI}
import io.circe.generic.semiauto.{deriveDecoder, deriveEncoder}
import io.circe.{Decoder, Encoder}
import io.circe.syntax.*
diff --git a/mercury/mercury-library/protocol-report-problem/src/test/scala/io/iohk/mercury/protocol/reportproblem/v2/ReportProblemSpec.scala b/mercury/protocol-report-problem/src/test/scala/org/hyperledger/identus/mercury/protocol/reportproblem/v2/ReportProblemSpec.scala
similarity index 93%
rename from mercury/mercury-library/protocol-report-problem/src/test/scala/io/iohk/mercury/protocol/reportproblem/v2/ReportProblemSpec.scala
rename to mercury/protocol-report-problem/src/test/scala/org/hyperledger/identus/mercury/protocol/reportproblem/v2/ReportProblemSpec.scala
index 2d650f0126..d40eb86604 100644
--- a/mercury/mercury-library/protocol-report-problem/src/test/scala/io/iohk/mercury/protocol/reportproblem/v2/ReportProblemSpec.scala
+++ b/mercury/protocol-report-problem/src/test/scala/org/hyperledger/identus/mercury/protocol/reportproblem/v2/ReportProblemSpec.scala
@@ -1,11 +1,12 @@
-package io.iohk.atala.mercury.protocol.reportproblem.v2
+package org.hyperledger.identus.mercury.protocol.reportproblem.v2
import io.circe.Json
import io.circe.syntax.*
import munit.*
-import io.iohk.atala.mercury.model._
import io.circe.*
import io.circe.parser.*
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.reportproblem.v2._
class ReportProblemSpec extends ZSuite {
test("ReportProblem") {
diff --git a/mercury/mercury-library/protocol-revocation-notification/Revocation-notification-protocol.md b/mercury/protocol-revocation-notification/Revocation-notification-protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-revocation-notification/Revocation-notification-protocol.md
rename to mercury/protocol-revocation-notification/Revocation-notification-protocol.md
diff --git a/mercury/mercury-library/protocol-revocation-notification/src/main/scala/io/iohk/atala/mercury/protocol/revocationnotificaiton/RevocationNotification.scala b/mercury/protocol-revocation-notification/src/main/scala/org/hyperledger/identus/mercury/protocol/revocationnotificaiton/RevocationNotification.scala
similarity index 93%
rename from mercury/mercury-library/protocol-revocation-notification/src/main/scala/io/iohk/atala/mercury/protocol/revocationnotificaiton/RevocationNotification.scala
rename to mercury/protocol-revocation-notification/src/main/scala/org/hyperledger/identus/mercury/protocol/revocationnotificaiton/RevocationNotification.scala
index 9deed3edea..5dfc001bc2 100644
--- a/mercury/mercury-library/protocol-revocation-notification/src/main/scala/io/iohk/atala/mercury/protocol/revocationnotificaiton/RevocationNotification.scala
+++ b/mercury/protocol-revocation-notification/src/main/scala/org/hyperledger/identus/mercury/protocol/revocationnotificaiton/RevocationNotification.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.mercury.protocol.revocationnotificaiton
+package org.hyperledger.identus.mercury.protocol.revocationnotificaiton
import io.circe._
import io.circe.generic.semiauto._
import io.circe.syntax._
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.{PIURI, Message, DidId}
final case class RevocationNotification(
id: String = java.util.UUID.randomUUID.toString(),
diff --git a/mercury/mercury-library/protocol-routing/Routing-Protocol.md b/mercury/protocol-routing/Routing-Protocol.md
similarity index 100%
rename from mercury/mercury-library/protocol-routing/Routing-Protocol.md
rename to mercury/protocol-routing/Routing-Protocol.md
diff --git a/mercury/mercury-library/protocol-routing/src/main/scala/io/iohk/atala/mercury/protocol/routing/ForwardMessage.scala b/mercury/protocol-routing/src/main/scala/org/hyperledger/identus/mercury/protocol/routing/ForwardMessage.scala
similarity index 95%
rename from mercury/mercury-library/protocol-routing/src/main/scala/io/iohk/atala/mercury/protocol/routing/ForwardMessage.scala
rename to mercury/protocol-routing/src/main/scala/org/hyperledger/identus/mercury/protocol/routing/ForwardMessage.scala
index 31cca44f16..1024c7bd0f 100644
--- a/mercury/mercury-library/protocol-routing/src/main/scala/io/iohk/atala/mercury/protocol/routing/ForwardMessage.scala
+++ b/mercury/protocol-routing/src/main/scala/org/hyperledger/identus/mercury/protocol/routing/ForwardMessage.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.mercury.protocol.routing
+package org.hyperledger.identus.mercury.protocol.routing
import io.circe._
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.{PIURI, AttachmentDescriptor, Message, DidId}
type ForwardAttachment = AttachmentDescriptor
diff --git a/mercury/mercury-library/protocol-trust-ping/src/main/scala/io/iohk/atala/mercury/protocol/trustping/TrustPing.scala b/mercury/protocol-trust-ping/src/main/scala/org/hyperledger/identus/mercury/protocol/trustping/TrustPing.scala
similarity index 94%
rename from mercury/mercury-library/protocol-trust-ping/src/main/scala/io/iohk/atala/mercury/protocol/trustping/TrustPing.scala
rename to mercury/protocol-trust-ping/src/main/scala/org/hyperledger/identus/mercury/protocol/trustping/TrustPing.scala
index 8992911ce5..16166c856c 100644
--- a/mercury/mercury-library/protocol-trust-ping/src/main/scala/io/iohk/atala/mercury/protocol/trustping/TrustPing.scala
+++ b/mercury/protocol-trust-ping/src/main/scala/org/hyperledger/identus/mercury/protocol/trustping/TrustPing.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.mercury.protocol.trustping
+package org.hyperledger.identus.mercury.protocol.trustping
import io.circe._
import io.circe.syntax._
import io.circe.generic.semiauto.{deriveDecoder, deriveEncoder}
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.{PIURI, Message, DidId}
/** https://identity.foundation/didcomm-messaging/spec/#trust-ping-protocol-20 */
final case class TrustPing(
diff --git a/mercury/mercury-library/protocol-trust-ping/src/main/scala/io/iohk/atala/mercury/protocol/trustping/TrustPingResponse.scala b/mercury/protocol-trust-ping/src/main/scala/org/hyperledger/identus/mercury/protocol/trustping/TrustPingResponse.scala
similarity index 92%
rename from mercury/mercury-library/protocol-trust-ping/src/main/scala/io/iohk/atala/mercury/protocol/trustping/TrustPingResponse.scala
rename to mercury/protocol-trust-ping/src/main/scala/org/hyperledger/identus/mercury/protocol/trustping/TrustPingResponse.scala
index 8a58baa671..1020d67a95 100644
--- a/mercury/mercury-library/protocol-trust-ping/src/main/scala/io/iohk/atala/mercury/protocol/trustping/TrustPingResponse.scala
+++ b/mercury/protocol-trust-ping/src/main/scala/org/hyperledger/identus/mercury/protocol/trustping/TrustPingResponse.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.mercury.protocol.trustping
+package org.hyperledger.identus.mercury.protocol.trustping
import io.circe._
-import io.iohk.atala.mercury.model._
+import org.hyperledger.identus.mercury.model.{PIURI, Message, DidId}
final case class TrustPingResponse(
`type`: PIURI = TrustPingResponse.`type`,
diff --git a/mercury/mercury-library/resolver/src/main/scala/io/iohk/atala/resolvers/DidValidator.scala b/mercury/resolver/src/main/scala/org/hyperledger/identus/resolvers/DidValidator.scala
similarity index 94%
rename from mercury/mercury-library/resolver/src/main/scala/io/iohk/atala/resolvers/DidValidator.scala
rename to mercury/resolver/src/main/scala/org/hyperledger/identus/resolvers/DidValidator.scala
index 3180e4da50..f2dfde95a8 100644
--- a/mercury/mercury-library/resolver/src/main/scala/io/iohk/atala/resolvers/DidValidator.scala
+++ b/mercury/resolver/src/main/scala/org/hyperledger/identus/resolvers/DidValidator.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.resolvers
-import io.iohk.atala.mercury.model.DidId
+import org.hyperledger.identus.mercury.model.DidId
object DidValidator extends DidValidator
trait DidValidator {
diff --git a/mercury/mercury-library/resolver/src/main/scala/io/iohk/atala/resolvers/PeerDidResolver.scala b/mercury/resolver/src/main/scala/org/hyperledger/identus/resolvers/PeerDidResolver.scala
similarity index 99%
rename from mercury/mercury-library/resolver/src/main/scala/io/iohk/atala/resolvers/PeerDidResolver.scala
rename to mercury/resolver/src/main/scala/org/hyperledger/identus/resolvers/PeerDidResolver.scala
index a6df34ca72..e881bc50da 100644
--- a/mercury/mercury-library/resolver/src/main/scala/io/iohk/atala/resolvers/PeerDidResolver.scala
+++ b/mercury/resolver/src/main/scala/org/hyperledger/identus/resolvers/PeerDidResolver.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.resolvers
import org.didcommx.didcomm.diddoc.{DIDCommService, DIDDoc, VerificationMethod}
import org.didcommx.peerdid.PeerDIDResolver.resolvePeerDID
diff --git a/mercury/mercury-library/resolver/src/main/scala/io/iohk/atala/resolvers/UniversalDidResolver.scala b/mercury/resolver/src/main/scala/org/hyperledger/identus/resolvers/UniversalDidResolver.scala
similarity index 91%
rename from mercury/mercury-library/resolver/src/main/scala/io/iohk/atala/resolvers/UniversalDidResolver.scala
rename to mercury/resolver/src/main/scala/org/hyperledger/identus/resolvers/UniversalDidResolver.scala
index b7424f63b5..3e543f0380 100644
--- a/mercury/mercury-library/resolver/src/main/scala/io/iohk/atala/resolvers/UniversalDidResolver.scala
+++ b/mercury/resolver/src/main/scala/org/hyperledger/identus/resolvers/UniversalDidResolver.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.resolvers
import org.didcommx.didcomm.diddoc._
@@ -7,7 +7,7 @@ import scala.jdk.CollectionConverters._
import scala.jdk.OptionConverters._
import zio._
-import io.iohk.atala.mercury.model.DidId
+import org.hyperledger.identus.mercury.model.DidId
trait DIDResolver {
def resolveDID(did: DidId): Task[DIDDoc] // TODO return Task[DIDDocument]
diff --git a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/AliceDidDoc.scala b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/AliceDidDoc.scala
similarity index 97%
rename from mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/AliceDidDoc.scala
rename to mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/AliceDidDoc.scala
index c1218d488f..ffd47519f9 100644
--- a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/AliceDidDoc.scala
+++ b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/AliceDidDoc.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.resolvers
import org.didcommx.didcomm.common.{VerificationMaterial, VerificationMaterialFormat, VerificationMethodType}
import org.didcommx.didcomm.diddoc.{DIDCommService, DIDDoc, VerificationMethod}
diff --git a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/BobDidDoc.scala b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/BobDidDoc.scala
similarity index 96%
rename from mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/BobDidDoc.scala
rename to mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/BobDidDoc.scala
index aeb003df3f..86eafe4c7b 100644
--- a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/BobDidDoc.scala
+++ b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/BobDidDoc.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.resolvers
import org.didcommx.didcomm.common.{VerificationMaterial, VerificationMaterialFormat, VerificationMethodType}
import org.didcommx.didcomm.diddoc.{DIDCommService, DIDDoc, VerificationMethod}
@@ -53,7 +53,7 @@ object BobDidDoc {
val didCommServices = Seq(
new DIDCommService(
"did:example:mediator#didcomm-1",
- "http://atalaprism.io/path",
+ "http://identus.io/path",
Seq("did:example:mediator#key-agreement-1").asJava,
Seq("didcomm/v2").asJava
)
diff --git a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/DidValidatorSpec.scala b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/DidValidatorSpec.scala
similarity index 90%
rename from mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/DidValidatorSpec.scala
rename to mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/DidValidatorSpec.scala
index 0949b9f9e1..33c2da5bd5 100644
--- a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/DidValidatorSpec.scala
+++ b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/DidValidatorSpec.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.resolvers
import munit.*
-/** resolver/testOnly io.iohk.atala.resolvers.DidValidatorSpec
+/** resolver/testOnly org.hyperledger.identus.resolvers.DidValidatorSpec
*/
class DidValidatorSpec extends ZSuite {
val exPRISM = "did:prism:66940961cc0f6a884ff5876992991b994ca518aa34b3bacfd15f2b51a7b042cf"
diff --git a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/MediatorDidDoc.scala b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/MediatorDidDoc.scala
similarity index 97%
rename from mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/MediatorDidDoc.scala
rename to mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/MediatorDidDoc.scala
index 8f6bc38abc..cd145a962b 100644
--- a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/MediatorDidDoc.scala
+++ b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/MediatorDidDoc.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.resolvers
import org.didcommx.didcomm.common.{VerificationMaterial, VerificationMaterialFormat, VerificationMethodType}
import org.didcommx.didcomm.diddoc.{DIDCommService, DIDDoc, VerificationMethod}
diff --git a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/PeerDidResolverSpec.scala b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/PeerDidResolverSpec.scala
similarity index 99%
rename from mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/PeerDidResolverSpec.scala
rename to mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/PeerDidResolverSpec.scala
index a21c7b204a..56ee214bd8 100644
--- a/mercury/mercury-library/resolver/src/test/scala/io/iohk/atala/resolvers/PeerDidResolverSpec.scala
+++ b/mercury/resolver/src/test/scala/org/hyperledger/identus/resolvers/PeerDidResolverSpec.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.resolvers
+package org.hyperledger.identus.resolvers
import io.circe.Json
import zio.*
import munit.*
diff --git a/mercury/roots-id-mediator/Dockerfile b/mercury/roots-id-mediator/Dockerfile
deleted file mode 100644
index 7bc55bbc59..0000000000
--- a/mercury/roots-id-mediator/Dockerfile
+++ /dev/null
@@ -1,8 +0,0 @@
-FROM jupyter/scipy-notebook
-
-# Install Python 3 packages
-RUN pip install 'qrcode' 'pymongo' 'didcomm' 'peerdid==0.4.0'
-
-# Downgrade packages
-# See authlib==1.0.0b1 https://github.com/sicpa-dlab/didcomm-python/blob/ca962db30ac7c1492ed6e3654575cce2dd3a5e0e/didcomm/core/from_prior.py#L107
-RUN pip install 'authlib==1.2.0'
diff --git a/mercury/roots-id-mediator/REAMDE-ROOTS-ID-mediator.md b/mercury/roots-id-mediator/REAMDE-ROOTS-ID-mediator.md
deleted file mode 100644
index 5c18555bc7..0000000000
--- a/mercury/roots-id-mediator/REAMDE-ROOTS-ID-mediator.md
+++ /dev/null
@@ -1,81 +0,0 @@
-# ROOTS-ID MEDIATOR
-
-See [ATL-1857](https://input-output.atlassian.net/browse/ATL-1857) from more info.
-
-## Note LICENSE
-
-This [ROOTS-ID's Mediator probject is LICENSE](https://raw.githubusercontent.com/roots-id/didcomm-mediator/main/LICENSE) under the [apache-2.0](https://www.apache.org/licenses/LICENSE-2.0)
-
-## Goal
-
-The idea is to test the interoperability of our agents (the client side) against this mediator.
-
-So our client agents should work exactly the same way with this mediator and our mediator.
-
-This will serve as a sanity check that we are compliant with DID Comm v2.
-
-## Starting point
-
-### Git submodules
-
-We added a link to the ROOTS-ID Mediator's repository as a git submodule.
-
-**NOTE:** The submodule is tracking the HEAD of the master branch.
-
-```shell
-git submodule init
-git submodule update
-
-# or use the flag '--recurse-submodules' when cloning our repository
-# git clone --recurse-submodules ...
-```
-
-### BUILD working station
-
-- Build the `docker` image for Jupyter.
-
-```shell
-docker build -f ./Dockerfile . --platform=linux/amd64 -t atala/didcomm-jupyter
-```
-
-```shell
-docker run -p 8888:8888 -v /home/fabio/workspace/iohk/atala-prism-building-blocks/mercury/roots-id-mediator/didcomm-mediator/sample-notebooks:/home/jovyan atala/didcomm-jupyter
-```
-
-### Build the mediator (docker image)
-
-- Build the `docker` image for the ROOTS-ID mediator (`rodopincha/didcomm-mediator`).
-
-```shell
-cd ./didcomm-mediator/
-docker build -f ./Dockerfile . --platform=linux/amd64 -t rodopincha/didcomm-mediator
-```
-
-### Start the mediator and working station
-
-- Start `docker-compose` (mongodb container instance + mediator container instance)
-
-```shell
-docker-compose up # -d
-```
-
-- Find the out-of-band invitation link.
-
- This inforamation is print on the logs of the container instance.
-
- We can get the _oob message in:
-
- - `http://0.0.0.0:8000/oob_qrcode` - QRcode
- - `http://127.0.0.1:8000/oob_url` - URL
-
-In the logs we can also see something like this:
-
-```shell
-> docker logs roots-id-mediator-rootsid-mediator-1
-
-roots-id-mediator-rootsid-mediator-1 | did:peer:2.Ez6LSmLmWmTvwjgLSuUaEQHdHSFWPwyibgzomWjFmnC6FhLnU.Vz6MktNgLh4N1u9KNhDiqe8KZ8bsLzLcqsifoNiUtBoSs9jxf.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vMTI3LjAuMC4xOjgwMDAiLCJhIjpbImRpZGNvbW0vdjIiXX0
-...
-roots-id-mediator-rootsid-mediator-1 | http://127.0.0.1:8000?_oob=eyJ0eXBlIjoiaHR0cHM6Ly9kaWRjb21tLm9yZy9vdXQtb2YtYmFuZC8yLjAvaW52aXRhdGlvbiIsImlkIjoiNDIxZGJiYzgtNTdjYS00MzQxLWFhM2EtZjViNDIxNWM1NjhmIiwiZnJvbSI6ImRpZDpwZWVyOjIuRXo2TFNtTG1XbVR2d2pnTFN1VWFFUUhkSFNGV1B3eWliZ3pvbVdqRm1uQzZGaExuVS5WejZNa3ROZ0xoNE4xdTlLTmhEaXFlOEtaOGJzTHpMY3FzaWZvTmlVdEJvU3M5anhmLlNleUpwWkNJNkltNWxkeTFwWkNJc0luUWlPaUprYlNJc0luTWlPaUpvZEhSd09pOHZNVEkzTGpBdU1DNHhPamd3TURBaUxDSmhJanBiSW1ScFpHTnZiVzB2ZGpJaVhYMCIsImJvZHkiOnsiZ29hbF9jb2RlIjoicmVxdWVzdC1tZWRpYXRlIiwiZ29hbCI6IlJlcXVlc3RNZWRpYXRlIiwiYWNjZXB0IjpbImRpZGNvbW0vdjIiLCJkaWRjb21tL2FpcDI7ZW52PXJmYzU4NyJdfX0
-```
-
-- To stop and remove the container instances use `docker-compose down`
diff --git a/mercury/roots-id-mediator/docker-compose.yaml b/mercury/roots-id-mediator/docker-compose.yaml
deleted file mode 100644
index 26b3421295..0000000000
--- a/mercury/roots-id-mediator/docker-compose.yaml
+++ /dev/null
@@ -1,44 +0,0 @@
-version: '3.9'
-
-services:
- mongo:
- image: mongo:5.0
- ports:
- - 27017:27017
- #volumes:
- # - ./tmp/mongo:/data/db
- environment:
- - MONGO_INITDB_ROOT_USERNAME=admin
- - MONGO_INITDB_ROOT_PASSWORD=admin
-
- rootsid-mediator:
- image: rodopincha/didcomm-mediator
- ports:
- - 8000:8000
- environment:
- - DB_URL=mongodb://admin:admin@mongo:27017
- - MONGODB_USER=admin
- - MONGODB_PASSWORD=admin
- - PUBLIC_URL=http://rootsid-mediator:8000
- - ROTATE_OOB=0
- depends_on:
- - "mongo"
-
- notebooks:
- image: atala/didcomm-jupyter
- ports:
- - 8888:8888
- volumes:
- - ./notebooks:/home/jovyan
- depends_on:
- - "rootsid-mediator"
-
-# GET invitation with
-# docker logs roots-id-mediator-rootsid-mediator-1
-
-# RUN
-# docker-compose up -d
-# docker-compose ps
-# docker-compose exec mongo /bin/sh
-# docker-compose exec rootsid-mediator /bin/sh
-# docker exec -it roots-id-mediator-rootsid-mediator-1 bash
\ No newline at end of file
diff --git a/mercury/roots-id-mediator/notebooks/.gitignore b/mercury/roots-id-mediator/notebooks/.gitignore
deleted file mode 100644
index f85a34ac7e..0000000000
--- a/mercury/roots-id-mediator/notebooks/.gitignore
+++ /dev/null
@@ -1,8 +0,0 @@
-secrets.json
-
-.local
-.jupyter
-.ipython
-.ipynb_checkpoints
-.config
-.cache
diff --git a/mercury/roots-id-mediator/notebooks/Alice.ipynb b/mercury/roots-id-mediator/notebooks/Alice.ipynb
deleted file mode 100644
index da07e03302..0000000000
--- a/mercury/roots-id-mediator/notebooks/Alice.ipynb
+++ /dev/null
@@ -1,757 +0,0 @@
-{
- "cells": [
- {
- "cell_type": "code",
- "execution_count": 1,
- "metadata": {},
- "outputs": [],
- "source": [
- "import json\n",
- "import base64\n",
- "import qrcode\n",
- "import requests\n",
- "import datetime\n",
- "import uuid\n",
- "import matplotlib.pyplot as plt\n",
- "from pymongo import MongoClient\n",
- "from typing import Optional, List\n",
- "from didcomm.common.types import DID, VerificationMethodType, VerificationMaterial, VerificationMaterialFormat\n",
- "from didcomm.did_doc.did_doc import DIDDoc, VerificationMethod, DIDCommService\n",
- "from didcomm.did_doc.did_resolver import DIDResolver\n",
- "from didcomm.message import Message, FromPrior\n",
- "from didcomm.secrets.secrets_resolver_demo import SecretsResolverDemo\n",
- "from didcomm.unpack import unpack, UnpackResult\n",
- "from didcomm.common.resolvers import ResolversConfig\n",
- "from didcomm.pack_encrypted import pack_encrypted, PackEncryptedConfig, PackEncryptedResult\n",
- "from peerdid.core.did_doc_types import DIDCommServicePeerDID\n",
- "from didcomm.secrets.secrets_util import generate_x25519_keys_as_jwk_dict, generate_ed25519_keys_as_jwk_dict, jwk_to_secret\n",
- "from peerdid import peer_did\n",
- "from peerdid.did_doc import DIDDocPeerDID\n",
- "from peerdid.types import VerificationMaterialAuthentication, VerificationMethodTypeAuthentication, VerificationMaterialAgreement, VerificationMethodTypeAgreement, VerificationMaterialFormatPeerDID"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 2,
- "metadata": {},
- "outputs": [],
- "source": [
- "secrets_resolver = SecretsResolverDemo()"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 3,
- "metadata": {},
- "outputs": [],
- "source": [
- "class DIDResolverPeerDID(DIDResolver):\n",
- " async def resolve(self, did: DID) -> DIDDoc:\n",
- " did_doc_json = peer_did.resolve_peer_did(did, format = VerificationMaterialFormatPeerDID.JWK)\n",
- " did_doc = DIDDocPeerDID.from_json(did_doc_json)\n",
- "\n",
- " return DIDDoc(\n",
- " did=did_doc.did,\n",
- " key_agreement_kids = did_doc.agreement_kids,\n",
- " authentication_kids = did_doc.auth_kids,\n",
- " verification_methods = [\n",
- " VerificationMethod(\n",
- " id = m.id,\n",
- " type = VerificationMethodType.JSON_WEB_KEY_2020,\n",
- " controller = m.controller,\n",
- " verification_material = VerificationMaterial(\n",
- " format = VerificationMaterialFormat.JWK,\n",
- " value = json.dumps(m.ver_material.value)\n",
- " )\n",
- " )\n",
- " for m in did_doc.authentication + did_doc.key_agreement\n",
- " ],\n",
- " didcomm_services = [\n",
- " DIDCommService(\n",
- " id = s.id,\n",
- " service_endpoint = s.service_endpoint,\n",
- " routing_keys = s.routing_keys,\n",
- " accept = s.accept\n",
- " )\n",
- " for s in did_doc.service\n",
- " if isinstance(s, DIDCommServicePeerDID)\n",
- " ] if did_doc.service else []\n",
- " )"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 4,
- "metadata": {},
- "outputs": [],
- "source": [
- "async def create_peer_did(self,\n",
- " auth_keys_count: int = 1,\n",
- " agreement_keys_count: int = 1,\n",
- " service_endpoint: Optional[str] = None,\n",
- " service_routing_keys: Optional[List[str]] = None\n",
- " ) -> str:\n",
- " # 1. generate keys in JWK format\n",
- " agreem_keys = [generate_x25519_keys_as_jwk_dict() for _ in range(agreement_keys_count)]\n",
- " auth_keys = [generate_ed25519_keys_as_jwk_dict() for _ in range(auth_keys_count)]\n",
- "\n",
- " # 2. prepare the keys for peer DID lib\n",
- " agreem_keys_peer_did = [\n",
- " VerificationMaterialAgreement(\n",
- " type=VerificationMethodTypeAgreement.JSON_WEB_KEY_2020,\n",
- " format=VerificationMaterialFormatPeerDID.JWK,\n",
- " value=k[1],\n",
- " )\n",
- " for k in agreem_keys\n",
- " ]\n",
- " auth_keys_peer_did = [\n",
- " VerificationMaterialAuthentication(\n",
- " type=VerificationMethodTypeAuthentication.JSON_WEB_KEY_2020,\n",
- " format=VerificationMaterialFormatPeerDID.JWK,\n",
- " value=k[1],\n",
- " )\n",
- " for k in auth_keys\n",
- " ]\n",
- "\n",
- " # 3. generate service\n",
- " service = None\n",
- " if service_endpoint:\n",
- " service = json.dumps(\n",
- " DIDCommServicePeerDID(\n",
- " id=\"new-id\",\n",
- " service_endpoint=service_endpoint, routing_keys=service_routing_keys,\n",
- " accept=[\"didcomm/v2\"]\n",
- " ).to_dict()\n",
- " )\n",
- "\n",
- " # 4. call peer DID lib\n",
- " # if we have just one key (auth), then use numalg0 algorithm\n",
- " # otherwise use numalg2 algorithm\n",
- " if len(auth_keys_peer_did) == 1 and not agreem_keys_peer_did and not service:\n",
- " did = peer_did.create_peer_did_numalgo_0(auth_keys_peer_did[0])\n",
- " else:\n",
- " did = peer_did.create_peer_did_numalgo_2(\n",
- " encryption_keys=agreem_keys_peer_did,\n",
- " signing_keys=auth_keys_peer_did,\n",
- " service=service,\n",
- " )\n",
- "\n",
- " # 5. set KIDs as in DID DOC for secrets and store the secret in the secrets resolver\n",
- " did_doc = DIDDocPeerDID.from_json(peer_did.resolve_peer_did(did))\n",
- " for auth_key, kid in zip(auth_keys, did_doc.auth_kids):\n",
- " private_key = auth_key[0]\n",
- " private_key[\"kid\"] = kid\n",
- " print(private_key)\n",
- " await secrets_resolver.add_key(jwk_to_secret(private_key))\n",
- "\n",
- " for agreem_key, kid in zip(agreem_keys, did_doc.agreement_kids):\n",
- " private_key = agreem_key[0]\n",
- " private_key[\"kid\"] = kid\n",
- " print(private_key)\n",
- " await secrets_resolver.add_key(jwk_to_secret(private_key))\n",
- "\n",
- " return did\n"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Alice get OOB from Mediator"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 5,
- "metadata": {},
- "outputs": [],
- "source": [
- "oob_url = requests.get(\"http://rootsid-mediator:8000/oob_url\").text\n",
- "#oob_url = requests.get(\"http://127.0.0.1:8000/oob_url\").text\n",
- "#oob_url = requests.get(\"https://mediator.rootsid.cloud/oob_url\").text"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 6,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "http://rootsid-mediator:8000?_oob=eyJ0eXBlIjoiaHR0cHM6Ly9kaWRjb21tLm9yZy9vdXQtb2YtYmFuZC8yLjAvaW52aXRhdGlvbiIsImlkIjoiYjFkN2Y0OWYtYzUyMS00NDk0LTg3MzQtYzAwZDhmY2M2NGFlIiwiZnJvbSI6ImRpZDpwZWVyOjIuRXo2TFNmdVlvZUU4QXJvclJuVkVIRzZnMVRVYjlZNjZLZkczNVdYcmdEbnJmWGtkVi5WejZNa3ZaVlp3SzlSVGtuTThEN0JKM0Q3aVphdTNBSFlKV0M2a1VLcWtvZEtobVdYLlNleUpwWkNJNkltNWxkeTFwWkNJc0luUWlPaUprYlNJc0luTWlPaUpvZEhSd09pOHZjbTl2ZEhOcFpDMXRaV1JwWVhSdmNqbzRNREF3SWl3aVlTSTZXeUprYVdSamIyMXRMM1l5SWwxOSIsImJvZHkiOnsiZ29hbF9jb2RlIjoicmVxdWVzdC1tZWRpYXRlIiwiZ29hbCI6IlJlcXVlc3RNZWRpYXRlIiwiYWNjZXB0IjpbImRpZGNvbW0vdjIiLCJkaWRjb21tL2FpcDI7ZW52PXJmYzU4NyJdfX0\n"
- ]
- }
- ],
- "source": [
- "print(oob_url)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 7,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "{'crv': 'Ed25519', 'x': 'ahRGFauYqLNRt713YmCqkTuwIj6o15WJfmwC6wXmGZQ', 'd': 'bQfbuHb9By5CUSToXBh_2n2-4-8v9nVFtWixtib_jaE', 'kty': 'OKP', 'kid': 'did:peer:2.Ez6LSi6SDgieS8H7FC3UREj2H1iYVCL7S9M8iTCPEmoGtiutJ.Vz6MkmbMC51u4xFNabEXoB32LP9aqJt6f39A3mmmqwuQYMhVm#6MkmbMC51u4xFNabEXoB32LP9aqJt6f39A3mmmqwuQYMhVm'}\n",
- "{'crv': 'X25519', 'x': 'X10VSyUGc2y_uGQU1PZPglsQZD4l73-TBCG11eSxSGc', 'd': 'sP7MbcTnExW9NW9ucc_A7GJ41-shNo2zzAW9PTFonlk', 'kty': 'OKP', 'kid': 'did:peer:2.Ez6LSi6SDgieS8H7FC3UREj2H1iYVCL7S9M8iTCPEmoGtiutJ.Vz6MkmbMC51u4xFNabEXoB32LP9aqJt6f39A3mmmqwuQYMhVm#6LSi6SDgieS8H7FC3UREj2H1iYVCL7S9M8iTCPEmoGtiutJ'}\n",
- "Alice's DID: did:peer:2.Ez6LSi6SDgieS8H7FC3UREj2H1iYVCL7S9M8iTCPEmoGtiutJ.Vz6MkmbMC51u4xFNabEXoB32LP9aqJt6f39A3mmmqwuQYMhVm\n"
- ]
- }
- ],
- "source": [
- "received_msg_encoded = oob_url.split(\"=\")[1]\n",
- "received_msg_decoded = json.loads(str(base64.urlsafe_b64decode(received_msg_encoded + \"==\"), \"utf-8\"))\n",
- "alice_did_for_mediator = await create_peer_did(1,1)\n",
- "print(\"Alice's DID:\", alice_did_for_mediator)"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Alice request mediate"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 8,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_mediate_grant = Message(\n",
- " custom_headers = [{\"return_route\": \"all\"}],\n",
- " id = str(uuid.uuid4()),\n",
- " type = \"https://didcomm.org/coordinate-mediation/2.0/mediate-request\",\n",
- " body = {}\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 9,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "PackEncryptedResult(packed_msg='{\"protected\":\"eyJ0eXAiOiJhcHBsaWNhdGlvbi9kaWRjb21tLWVuY3J5cHRlZCtqc29uIiwiYWxnIjoiRUNESC0xUFUrQTI1NktXIiwiZW5jIjoiQTI1NkNCQy1IUzUxMiIsImFwdSI6IlpHbGtPbkJsWlhJNk1pNUZlalpNVTJrMlUwUm5hV1ZUT0VnM1JrTXpWVkpGYWpKSU1XbFpWa05NTjFNNVRUaHBWRU5RUlcxdlIzUnBkWFJLTGxaNk5rMXJiV0pOUXpVeGRUUjRSazVoWWtWWWIwSXpNa3hRT1dGeFNuUTJaak01UVROdGJXMXhkM1ZSV1Uxb1ZtMGpOa3hUYVRaVFJHZHBaVk00U0RkR1F6TlZVa1ZxTWtneGFWbFdRMHczVXpsTk9HbFVRMUJGYlc5SGRHbDFkRW8iLCJhcHYiOiJUVTRLbXh3eDB3RWxBb0pac21FMG1HZ05GWkI5LVFfWDJCdG1RQzdtRllRIiwic2tpZCI6ImRpZDpwZWVyOjIuRXo2TFNpNlNEZ2llUzhIN0ZDM1VSRWoySDFpWVZDTDdTOU04aVRDUEVtb0d0aXV0Si5WejZNa21iTUM1MXU0eEZOYWJFWG9CMzJMUDlhcUp0NmYzOUEzbW1tcXd1UVlNaFZtIzZMU2k2U0RnaWVTOEg3RkMzVVJFajJIMWlZVkNMN1M5TThpVENQRW1vR3RpdXRKIiwiZXBrIjp7ImNydiI6IlgyNTUxOSIsIngiOiJ1QjJfQWRCTWZSSjEzR2R5Z0lFUmFUYVU2SGh5SFBFRF94ZDlEWnlsYkI0Iiwia3R5IjoiT0tQIn19\",\"recipients\":[{\"header\":{\"kid\":\"did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19#6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV\"},\"encrypted_key\":\"aeWrV-8Bcn1eULHu6LsTAtAlJpxqucew1nsY07DhL2-OpUMtaLsNu2Q4l9hDccEOterU0Ofwgvfr0jJDDD4XAvxEoJT8rv5o\"}],\"iv\":\"HlLWUj9lUvYeg0wrF6bn_A\",\"ciphertext\":\"H8J-NB7f2dmws8ilS_A9fYmo3ZL655SSobYLjEBhGKn2JLWoNZyc6E9dug9GtG-0YTUauEE2YU-oxLHRcerN2TJQiGRNgck5z1WEOriMdubTKV_koQEqvdl-bu2VpxWBpVHlGNKlpIX2fQgXkSeSP_piNvr2QPusA6_N6LsKXBdBpWwx46kSGHSWtOUjU3aoQm1fA74jWvXsEQl3NArVNFuAQWsl86sOALfPLr4M2ikGEjacOWMSdCkvw6GjXQGorOLxZSdsPhCYTdzvP4oIXw\",\"tag\":\"nXDYAIeIiSC6-pUWSzP0PaEXmZsG4eOIGLCn2N3BBdo\"}', to_kids=['did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19#6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV'], from_kid='did:peer:2.Ez6LSi6SDgieS8H7FC3UREj2H1iYVCL7S9M8iTCPEmoGtiutJ.Vz6MkmbMC51u4xFNabEXoB32LP9aqJt6f39A3mmmqwuQYMhVm#6LSi6SDgieS8H7FC3UREj2H1iYVCL7S9M8iTCPEmoGtiutJ', sign_from_kid=None, from_prior_issuer_kid=None, service_metadata=ServiceMetadata(id='did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19#didcommmessaging-0', service_endpoint='http://rootsid-mediator:8000'))\n"
- ]
- }
- ],
- "source": [
- "alice_mediate_grant_packed = await pack_encrypted(\n",
- " resolvers_config = ResolversConfig(\n",
- " secrets_resolver = secrets_resolver,\n",
- " did_resolver = DIDResolverPeerDID()\n",
- " ),\n",
- " message = alice_mediate_grant,\n",
- " frm = alice_did_for_mediator,\n",
- " to = received_msg_decoded[\"from\"],\n",
- " sign_frm = None,\n",
- " pack_config = PackEncryptedConfig(protect_sender_id=False)\n",
- ")\n",
- "print(alice_mediate_grant_packed)"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Sending to Mediator"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 10,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "{'id': 'did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19', 'authentication': [{'id': 'did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19#6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX', 'type': 'Ed25519VerificationKey2020', 'controller': 'did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19', 'publicKeyMultibase': 'z6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX'}], 'keyAgreement': [{'id': 'did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19#6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV', 'type': 'X25519KeyAgreementKey2020', 'controller': 'did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19', 'publicKeyMultibase': 'z6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV'}], 'service': [{'id': 'did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19#didcommmessaging-0', 'type': 'DIDCommMessaging', 'serviceEndpoint': 'http://rootsid-mediator:8000', 'accept': ['didcomm/v2']}]}\n",
- "http://rootsid-mediator:8000\n"
- ]
- }
- ],
- "source": [
- "mediator_did_doc = json.loads(peer_did.resolve_peer_did(received_msg_decoded[\"from\"]))\n",
- "mediator_endpoint = mediator_did_doc[\"service\"][0][\"serviceEndpoint\"]\n",
- "print(mediator_did_doc)\n",
- "print(mediator_endpoint)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 11,
- "metadata": {},
- "outputs": [],
- "source": [
- "headers = {\"Content-Type\": \"application/didcomm-encrypted+json\"}\n",
- "resp = requests.post(mediator_endpoint, headers=headers, data = alice_mediate_grant_packed.packed_msg)\n"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 12,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "{\"protected\":\"eyJ0eXAiOiJhcHBsaWNhdGlvbi9kaWRjb21tLWVuY3J5cHRlZCtqc29uIiwiYWxnIjoiRUNESC0xUFUrQTI1NktXIiwiZW5jIjoiQTI1NkNCQy1IUzUxMiIsImFwdSI6IlpHbGtPbkJsWlhJNk1pNUZlalpNVTI4M2JubG1kMWt6YlRkM1UxRjJRekZOTTFVMU5sUm9kbXBaYURVMFlrdEtUVU5ZYVhONlRuZEhNMlp0TGxaNk5rMXJiMDVaYWpGMGQyTlZaSFJJWWs1RFV6WlpjMUprZEZGdVZYWnBXbFkwVVVoRFFXNXJla3BLTW1seFZVTXVVMlY1U25CYVEwazJTVzAxYkdSNU1YQmFRMGx6U1c1UmFVOXBTbXRpVTBselNXNU5hVTlwU205a1NGSjNUMms0ZG1OdE9YWmtTRTV3V2tNeGRGcFhVbkJaV0ZKMlkycHZORTFFUVhkSmFYZHBXVk5KTmxkNVNtdGhWMUpxWWpJeGRFd3pXWGxKYkRFNUl6Wk1VMjgzYm5sbWQxa3piVGQzVTFGMlF6Rk5NMVUxTmxSb2RtcFphRFUwWWt0S1RVTllhWE42VG5kSE0yWnQiLCJhcHYiOiJpWlpVYklVZ25fWVlCeFlxNHdxaXR5N0s0aVZWVFJwUjZvaC1BSEEteFVNIiwic2tpZCI6ImRpZDpwZWVyOjIuRXo2TFNvN255ZndZM203d1NRdkMxTTNVNTZUaHZqWWg1NGJLSk1DWGlzek53RzNmbS5WejZNa29OWWoxdHdjVWR0SGJOQ1M2WXNSZHRRblV2aVpWNFFIQ0Fua3pKSjJpcVVDLlNleUpwWkNJNkltNWxkeTFwWkNJc0luUWlPaUprYlNJc0luTWlPaUpvZEhSd09pOHZjbTl2ZEhOcFpDMXRaV1JwWVhSdmNqbzRNREF3SWl3aVlTSTZXeUprYVdSamIyMXRMM1l5SWwxOSM2TFNvN255ZndZM203d1NRdkMxTTNVNTZUaHZqWWg1NGJLSk1DWGlzek53RzNmbSIsImVwayI6eyJjcnYiOiJYMjU1MTkiLCJ4IjoiYVZjaWtzaEpWR3VjX09rdkFBako4X2dVMllhRnl2TUhNTEYwRVNRallXdyIsImt0eSI6Ik9LUCJ9fQ\",\"recipients\":[{\"header\":{\"kid\":\"did:peer:2.Ez6LSi6SDgieS8H7FC3UREj2H1iYVCL7S9M8iTCPEmoGtiutJ.Vz6MkmbMC51u4xFNabEXoB32LP9aqJt6f39A3mmmqwuQYMhVm#6LSi6SDgieS8H7FC3UREj2H1iYVCL7S9M8iTCPEmoGtiutJ\"},\"encrypted_key\":\"ToAtopK3nJ6qDF4a4toVw10fP3kfTHtCx6jRWH3wqVNayBbIGV5P75Cb6WAMgcjfudwYOjJI_mW_vmLcTIVuKEtRJh4hWUlK\"}],\"iv\":\"a_ZKxTw5CjmCJuwWBuWQ8w\",\"ciphertext\":\"y3JWYjiBC3ApAEa14gn97UZbwEwyf2DpDkA8i1IpCfzRAXatAGkkpPsOGUOM2W-xw0WBnUvctAQhqEn0yrkTFhXQ_-FTgcfLn1Xgf4BFOfLjToJXxAxw1_sziU86nzqnnTic8VqyOr-L2DLILypNaRsb2Nd-HBwJeYSMVvRbwaqFMLyeNq5rMlNOG-OKOPI8WJeWXOEQL3an90SAUlELn9c8X6zJIJEn4FIyiprBvGVAe-jlYfe9XC5-Zk4j5kSbcxbVaMd92_F2XmxDKfDkpf7CZCrcB-q0FWFE7jF4WuJzDr_EKqOXamttaIyW9a4ZaaBZjx68uAG6GDFMAQ8eAn1iVEXWzC13FiBK34oHiLq3r5MaYPWR8BHjt8Nuri2bchSpyvc4aeQxaKNLcuzAVXlfyrUI0Z8DwAlwsg-rfTDNjqxZjGOactAPREo3Yt0tm6nI32wOAEPWZ1D_ICS9l2hMjp7Qf2_iHow60-3bWI0Zw4zPiRQlYwIg108xnbEdw85i1HVZwCViAXze5W16ujKjVLqbP2Bl-lAGsJgn16xZNNC7ssqk5FBDfpRQO_oxKAz_lXm94TaaMHAdW6sTCGxBPjmOkWm2s_RpFCHD4zBQ4qjG6_YroG1IELHCG6uyQJvP1ja4N1uWfE725rDKu64NPmFB1OSBkxGs36TXvXbk-W7S1GfvS_IWy2FxzdTrhIELUhlYGHUiYVxt1_kpH4CHXLHnw7vCbZcCj_s9PhPZjfzuNMmKPis1dKZ2toWfHmPNRbRJgfvm57RTeS2Du69AbWTdrv7-dMyVGyApKdpOB2ze2BwVdwOF_-UQ022QlrhEqOXT5YexKpoHs1XC_uzMSXOnltT3ruDVQDiW-hi_qBSDKcpbmP3cv0Ph2VOd2z9RfIy8cMzDLUtNgTumTW1nUo9wRq7GfssHGp5QCuBoDpr_jHEzeOEcB0AftfO1rFJe8NWs72H1ZNqlxaSYUJUN1n6zqTPGm4TRHOIpG4MbR4pqm8PXp2jB2H81kyfqIvjyblN0lrjrV8_X252cm_Bx8pPbCWf1rm7XnpkdD9QLukl4VhqihNvWsbI23sZP7OaAYkAvgefXW8cSb_nXf0yCY0T9zfzM8fXyGLU8KTA4us_fzfup416GS4s-p7Ag00nadQLowoSW2SfDWBgi1BUKY2cnZqbkRNZjEcw3QttJjpa5CwPm_os47VdphHAgKPGg9z46sHCTSuupYDgmUzXj7JAgtPagO8B3xr80P46GcdliykUoj6a7NdhAeaUpBD7SHY_uPA2vYQ_3DRc5y86TZ_dYARGnOH5ccJZ6ty-Zv4xBD8dhuI-VCwcI73FD4-zp1ac7FcRSKEbPsmSnadz3T2qiRcHuU3KH-R8vILV3z4gIiAW1o5bHnd5xSQV3wOxOFdE7K8FiqKGdTEsHi2mki0mb_y_5x5caFe7sK1-zWQhp_XsnmxKURxAbYss2HEf-lNDqMHwZdtY8ajn6zXy4cBdn8HbI4HjIqSo3bnA0FrIyo-8PwqcLvBZoY1PEer_WIN6RG7xiyNF0zPl23aX3Tk8sJCeZjAygIjWYEW5HLplpQnAKSLGfEXaZk1fW8_BvAEHt-UERt-SSRN8ExhLoZUk_8YfZ8HXXFI-jIg20a6sPWrUVN48sU9wmVURu4zXhFC3iIdhv2LFnYsQ_r_Y49zrnmWoD9TK4imaCGAZljNq6vL1sIbNOksmf9YnwLXkf0_HMvLy3sAYatf7972I0kGrLHw9BDp0Vn7adji5McJu_XAo3eNww0BdIgHc9jHqD5diUaZkPaFGARFCNY6YGGjIAgrbP_HGUYr0gppcoQg2O__rlbXRJVBS29z57NCCYCOurZvgsIfXQJ41j59Jx6Ya0DrsAp9igpSHNVzW7eMYvPTCSxNKX21Wdv6kf62GaOCBohYgGMqE_fi0pgSxoH4x0LKDqQ5zuf2E94cdy_7VmVgpzUSSSZFZfQYrjFE5EPzU8xj7eNgbyHpAoNg\",\"tag\":\"1MQCtvVbytfnNjg5MXAul6TFG1d2pTtsi3D8HxXPTHg\"}\n"
- ]
- }
- ],
- "source": [
- "print(resp.json())"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Get mediator grant response"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 13,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "https://didcomm.org/coordinate-mediation/2.0/mediate-grant\n",
- "Routing Key: did:peer:2.Ez6LSh86cZe85p4LLsNc28nAp9rtLvg2tdS7KA9cYcB9DpnNY.Vz6Mknau6GqSR279G1akj6imwmXGqxLk5sskPZcnnT83ym1Wa.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19\n",
- "Mediator new DID: did:peer:2.Ez6LSo7nyfwY3m7wSQvC1M3U56ThvjYh54bKJMCXiszNwG3fm.Vz6MkoNYj1twcUdtHbNCS6YsRdtQnUviZV4QHCAnkzJJ2iqUC.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19\n"
- ]
- }
- ],
- "source": [
- "mediator_unpack_msg = await unpack(\n",
- " resolvers_config=ResolversConfig(\n",
- " secrets_resolver=secrets_resolver,\n",
- " did_resolver=DIDResolverPeerDID()\n",
- " ),\n",
- " packed_msg= resp.json()\n",
- ")\n",
- "print(mediator_unpack_msg.message.type)\n",
- "print(\"Routing Key: \" + mediator_unpack_msg.message.body[\"routing_did\"])\n",
- "print(\"Mediator new DID: \" + mediator_unpack_msg.message.from_prior.sub)\n",
- "# mediator rotated did\n",
- "mediator_routing_key = mediator_unpack_msg.message.body[\"routing_did\"]\n",
- "mediator_did = mediator_unpack_msg.message.from_prior.sub"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Keylist update"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "Alice create a new DID to share with other peers using mediator routing keys "
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 14,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "{'crv': 'Ed25519', 'x': 'VbWFIhfT1aUvzxVcZJlGm40KZ7iw3swu2BfKUiS32Q0', 'd': 'fjpPxHmNxBCYOj2Mbi8Zdqw4HKCxaNBXcINIfQNrlhs', 'kty': 'OKP', 'kid': 'did:peer:2.Ez6LSqrUDvHgg8WbUH2gRfgGdNNhABreeuCYmBRTjMDe1AmVL.Vz6MkkDqEhfa7BUpaKsHM4Cph7YnjndRZfLJdqMtixA4jUV3r.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOlt7InVyaSI6ImRpZDpwZWVyOjIuRXo2TFNoODZjWmU4NXA0TExzTmMyOG5BcDlydEx2ZzJ0ZFM3S0E5Y1ljQjlEcG5OWS5WejZNa25hdTZHcVNSMjc5RzFha2o2aW13bVhHcXhMazVzc2tQWmNublQ4M3ltMVdhLlNleUpwWkNJNkltNWxkeTFwWkNJc0luUWlPaUprYlNJc0luTWlPaUpvZEhSd09pOHZjbTl2ZEhOcFpDMXRaV1JwWVhSdmNqbzRNREF3SWl3aVlTSTZXeUprYVdSamIyMXRMM1l5SWwxOSJ9XSwiYSI6WyJkaWRjb21tL3YyIl19#6MkkDqEhfa7BUpaKsHM4Cph7YnjndRZfLJdqMtixA4jUV3r'}\n",
- "{'crv': 'X25519', 'x': '0qa2ljtJpd5hOoV-1TP9NUrQJdeT4HyzQq2onFVbjyM', 'd': 'aEoknbH22Fnm9cCdVJRbNpryELRBSX8nGGerzVcYh0o', 'kty': 'OKP', 'kid': 'did:peer:2.Ez6LSqrUDvHgg8WbUH2gRfgGdNNhABreeuCYmBRTjMDe1AmVL.Vz6MkkDqEhfa7BUpaKsHM4Cph7YnjndRZfLJdqMtixA4jUV3r.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOlt7InVyaSI6ImRpZDpwZWVyOjIuRXo2TFNoODZjWmU4NXA0TExzTmMyOG5BcDlydEx2ZzJ0ZFM3S0E5Y1ljQjlEcG5OWS5WejZNa25hdTZHcVNSMjc5RzFha2o2aW13bVhHcXhMazVzc2tQWmNublQ4M3ltMVdhLlNleUpwWkNJNkltNWxkeTFwWkNJc0luUWlPaUprYlNJc0luTWlPaUpvZEhSd09pOHZjbTl2ZEhOcFpDMXRaV1JwWVhSdmNqbzRNREF3SWl3aVlTSTZXeUprYVdSamIyMXRMM1l5SWwxOSJ9XSwiYSI6WyJkaWRjb21tL3YyIl19#6LSqrUDvHgg8WbUH2gRfgGdNNhABreeuCYmBRTjMDe1AmVL'}\n",
- "Alice's DID for Bob: did:peer:2.Ez6LSqrUDvHgg8WbUH2gRfgGdNNhABreeuCYmBRTjMDe1AmVL.Vz6MkkDqEhfa7BUpaKsHM4Cph7YnjndRZfLJdqMtixA4jUV3r.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOlt7InVyaSI6ImRpZDpwZWVyOjIuRXo2TFNoODZjWmU4NXA0TExzTmMyOG5BcDlydEx2ZzJ0ZFM3S0E5Y1ljQjlEcG5OWS5WejZNa25hdTZHcVNSMjc5RzFha2o2aW13bVhHcXhMazVzc2tQWmNublQ4M3ltMVdhLlNleUpwWkNJNkltNWxkeTFwWkNJc0luUWlPaUprYlNJc0luTWlPaUpvZEhSd09pOHZjbTl2ZEhOcFpDMXRaV1JwWVhSdmNqbzRNREF3SWl3aVlTSTZXeUprYVdSamIyMXRMM1l5SWwxOSJ9XSwiYSI6WyJkaWRjb21tL3YyIl19\n"
- ]
- }
- ],
- "source": [
- "#alice_did_new = await create_peer_did(1, 1, service_endpoint=mediator_endpoint, service_routing_keys=[mediator_routing_key])\n",
- "alice_did_for_bob = await create_peer_did(1, 1, service_endpoint=[{\"uri\": mediator_routing_key}])\n",
- "\n",
- "print(\"Alice's DID for Bob:\", alice_did_for_bob)"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "Alice create and send the keylist update message"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 15,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_keylist_update = Message(\n",
- " id = \"unique-id-293e9a922efff\",\n",
- " type = \"https://didcomm.org/coordinate-mediation/2.0/keylist-update\",\n",
- " body = {\n",
- " \"updates\":[\n",
- " {\n",
- " \"recipient_did\": alice_did_for_bob,\n",
- " \"action\": \"add\"\n",
- " }\n",
- " ]\n",
- " }\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 16,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_keylist_update_packed_msg = await pack_encrypted(\n",
- " resolvers_config = ResolversConfig(\n",
- " secrets_resolver = secrets_resolver,\n",
- " did_resolver = DIDResolverPeerDID()\n",
- " ),\n",
- " message = alice_keylist_update,\n",
- " frm = alice_did_for_mediator,\n",
- " to = mediator_did,\n",
- " sign_frm = None,\n",
- " pack_config = PackEncryptedConfig(protect_sender_id=False)\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 17,
- "metadata": {},
- "outputs": [],
- "source": [
- "headers = {\"Content-Type\": \"application/didcomm-encrypted+json\"}\n",
- "resp = requests.post(mediator_endpoint, headers=headers, data = alice_keylist_update_packed_msg.packed_msg)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 18,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "https://didcomm.org/coordinate-mediation/2.0/keylist-update-response\n",
- "{'updated': [{'recipient_did': 'did:peer:2.Ez6LSqrUDvHgg8WbUH2gRfgGdNNhABreeuCYmBRTjMDe1AmVL.Vz6MkkDqEhfa7BUpaKsHM4Cph7YnjndRZfLJdqMtixA4jUV3r.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOlt7InVyaSI6ImRpZDpwZWVyOjIuRXo2TFNoODZjWmU4NXA0TExzTmMyOG5BcDlydEx2ZzJ0ZFM3S0E5Y1ljQjlEcG5OWS5WejZNa25hdTZHcVNSMjc5RzFha2o2aW13bVhHcXhMazVzc2tQWmNublQ4M3ltMVdhLlNleUpwWkNJNkltNWxkeTFwWkNJc0luUWlPaUprYlNJc0luTWlPaUpvZEhSd09pOHZjbTl2ZEhOcFpDMXRaV1JwWVhSdmNqbzRNREF3SWl3aVlTSTZXeUprYVdSamIyMXRMM1l5SWwxOSJ9XSwiYSI6WyJkaWRjb21tL3YyIl19', 'action': 'add', 'result': 'success'}]}\n"
- ]
- }
- ],
- "source": [
- "mediator_unpack_msg2 = await unpack(\n",
- " resolvers_config=ResolversConfig(\n",
- " secrets_resolver=secrets_resolver,\n",
- " did_resolver=DIDResolverPeerDID()\n",
- " ),\n",
- " packed_msg= resp.json()\n",
- ")\n",
- "print(mediator_unpack_msg2.message.type)\n",
- "print(mediator_unpack_msg2.message.body)\n"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Alice can now send her DID to Bob."
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Alice check status of queued messages from the Mediator"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 19,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_status_check = Message(\n",
- " id = \"unique-id-293e9a922efffxxx\",\n",
- " type = \"https://didcomm.org/messagepickup/3.0/status-request\",\n",
- " body = {}\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 20,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_status_check_packed_msg = await pack_encrypted(\n",
- " resolvers_config = ResolversConfig(\n",
- " secrets_resolver = secrets_resolver,\n",
- " did_resolver = DIDResolverPeerDID()\n",
- " ),\n",
- " message = alice_status_check,\n",
- " to = mediator_did,\n",
- " frm = alice_did_for_mediator,\n",
- " sign_frm = None,\n",
- " pack_config = PackEncryptedConfig(protect_sender_id=False)\n",
- ")\n",
- "headers = {\"Content-Type\": \"application/didcomm-encrypted+json\"}\n",
- "resp3 = requests.post(mediator_endpoint, headers=headers, data = alice_status_check_packed_msg.packed_msg)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 21,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "https://didcomm.org/messagepickup/3.0/status\n",
- "Messages in Mediator queue: 0\n"
- ]
- }
- ],
- "source": [
- "mediator_unpack_status = await unpack(\n",
- " resolvers_config=ResolversConfig(\n",
- " secrets_resolver=secrets_resolver,\n",
- " did_resolver=DIDResolverPeerDID()\n",
- " ),\n",
- " packed_msg= resp3.json()\n",
- ")\n",
- "print(mediator_unpack_status.message.type)\n",
- "print(\"Messages in Mediator queue: \" + str(mediator_unpack_status.message.body[\"message_count\"]))"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### If there are messages, Alice can pickup from the mediator (delivery request)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 22,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_delivery_request = Message(\n",
- " id = \"unique-id-293e9a922efffxxxff\",\n",
- " type = \"https://didcomm.org/messagepickup/3.0/delivery-request\",\n",
- " body = {\"limit\": 1}\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 23,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_delivery_request_packed_msg = await pack_encrypted(\n",
- " resolvers_config = ResolversConfig(\n",
- " secrets_resolver = secrets_resolver,\n",
- " did_resolver = DIDResolverPeerDID()\n",
- " ),\n",
- " message = alice_delivery_request,\n",
- " to = mediator_did,\n",
- " frm = alice_did_for_mediator,\n",
- " sign_frm = None,\n",
- " pack_config = PackEncryptedConfig(protect_sender_id=False)\n",
- ")\n",
- "headers = {\"Content-Type\": \"application/didcomm-encrypted+json\"}\n",
- "resp4 = requests.post(mediator_endpoint, headers=headers, data = alice_delivery_request_packed_msg.packed_msg)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 24,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "https://didcomm.org/messagepickup/3.0/status\n",
- "{'recipient_key': None, 'message_count': 0, 'live_delivery': False}\n"
- ]
- }
- ],
- "source": [
- "mediator_delivery = await unpack(\n",
- " resolvers_config=ResolversConfig(\n",
- " secrets_resolver=secrets_resolver,\n",
- " did_resolver=DIDResolverPeerDID()\n",
- " ),\n",
- " packed_msg= resp4.json()\n",
- ")\n",
- "print(mediator_delivery.message.type)\n",
- "print(mediator_delivery.message.body)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 25,
- "metadata": {},
- "outputs": [
- {
- "ename": "TypeError",
- "evalue": "'NoneType' object is not subscriptable",
- "output_type": "error",
- "traceback": [
- "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
- "\u001b[0;31mTypeError\u001b[0m Traceback (most recent call last)",
- "Cell \u001b[0;32mIn [25], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m bob_packed_msg \u001b[38;5;241m=\u001b[39m \u001b[43mmediator_delivery\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmessage\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mattachments\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m]\u001b[49m\u001b[38;5;241m.\u001b[39mdata\u001b[38;5;241m.\u001b[39mjson\n\u001b[1;32m 2\u001b[0m msg_id \u001b[38;5;241m=\u001b[39m mediator_delivery\u001b[38;5;241m.\u001b[39mmessage\u001b[38;5;241m.\u001b[39mattachments[\u001b[38;5;241m0\u001b[39m]\u001b[38;5;241m.\u001b[39mid\n",
- "\u001b[0;31mTypeError\u001b[0m: 'NoneType' object is not subscriptable"
- ]
- }
- ],
- "source": [
- "bob_packed_msg = mediator_delivery.message.attachments[0].data.json\n",
- "msg_id = mediator_delivery.message.attachments[0].id"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": [
- "print(bob_packed_msg)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": [
- "bob_msg = await unpack(\n",
- " resolvers_config=ResolversConfig(\n",
- " secrets_resolver=secrets_resolver,\n",
- " did_resolver=DIDResolverPeerDID()\n",
- " ),\n",
- " packed_msg= bob_packed_msg\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": [
- "print(\"Message ID:\", msg_id)\n",
- "print(bob_msg.message.body[\"content\"])"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Alice acknowledge so the mediator can delete the message"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_ack = Message(\n",
- " id = \"unique-id-293e9a922efffxxxffsss\",\n",
- " type = \"https://didcomm.org/messagepickup/3.0/messages-received\",\n",
- " body = {\"message_id_list\": [msg_id]}\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_ack_packed_msg = await pack_encrypted(\n",
- " resolvers_config = ResolversConfig(\n",
- " secrets_resolver = secrets_resolver,\n",
- " did_resolver = DIDResolverPeerDID()\n",
- " ),\n",
- " message = alice_ack,\n",
- " to = mediator_did,\n",
- " frm = alice_did_for_mediator,\n",
- " sign_frm = None,\n",
- " pack_config = PackEncryptedConfig(protect_sender_id=False)\n",
- ")\n",
- "headers = {\"Content-Type\": \"application/didcomm-encrypted+json\"}\n",
- "resp5 = requests.post(mediator_endpoint, headers=headers, data = alice_ack_packed_msg.packed_msg)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": [
- "mediator_ack_status = await unpack(\n",
- " resolvers_config=ResolversConfig(\n",
- " secrets_resolver=secrets_resolver,\n",
- " did_resolver=DIDResolverPeerDID()\n",
- " ),\n",
- " packed_msg= resp5.json()\n",
- ")\n",
- "print(mediator_ack_status.message.type)\n",
- "print(mediator_ack_status.message.body)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": []
- }
- ],
- "metadata": {
- "kernelspec": {
- "display_name": "Python 3 (ipykernel)",
- "language": "python",
- "name": "python3"
- },
- "language_info": {
- "codemirror_mode": {
- "name": "ipython",
- "version": 3
- },
- "file_extension": ".py",
- "mimetype": "text/x-python",
- "name": "python",
- "nbconvert_exporter": "python",
- "pygments_lexer": "ipython3",
- "version": "3.10.6"
- }
- },
- "nbformat": 4,
- "nbformat_minor": 4
-}
diff --git a/mercury/roots-id-mediator/notebooks/Bob.ipynb b/mercury/roots-id-mediator/notebooks/Bob.ipynb
deleted file mode 100644
index a2bae3c924..0000000000
--- a/mercury/roots-id-mediator/notebooks/Bob.ipynb
+++ /dev/null
@@ -1,393 +0,0 @@
-{
- "cells": [
- {
- "cell_type": "code",
- "execution_count": 1,
- "metadata": {},
- "outputs": [],
- "source": [
- "import json\n",
- "import base64\n",
- "import qrcode\n",
- "import requests\n",
- "import datetime\n",
- "import uuid\n",
- "import matplotlib.pyplot as plt\n",
- "from pymongo import MongoClient\n",
- "from typing import Optional, List\n",
- "from didcomm.common.types import DID, VerificationMethodType, VerificationMaterial, VerificationMaterialFormat\n",
- "from didcomm.did_doc.did_doc import DIDDoc, VerificationMethod, DIDCommService\n",
- "from didcomm.did_doc.did_resolver import DIDResolver\n",
- "from didcomm.message import Message, FromPrior\n",
- "from didcomm.secrets.secrets_resolver_demo import SecretsResolverDemo\n",
- "from didcomm.unpack import unpack, UnpackResult\n",
- "from didcomm.message import Attachment, AttachmentDataJson, AttachmentDataLinks\n",
- "from didcomm.common.resolvers import ResolversConfig\n",
- "from didcomm.pack_encrypted import pack_encrypted, PackEncryptedConfig, PackEncryptedResult\n",
- "from peerdid.core.did_doc_types import DIDCommServicePeerDID\n",
- "from didcomm.secrets.secrets_util import generate_x25519_keys_as_jwk_dict, generate_ed25519_keys_as_jwk_dict, jwk_to_secret\n",
- "from peerdid import peer_did\n",
- "from peerdid.did_doc import DIDDocPeerDID\n",
- "from peerdid.types import VerificationMaterialAuthentication, VerificationMethodTypeAuthentication, VerificationMaterialAgreement, VerificationMethodTypeAgreement, VerificationMaterialFormatPeerDID"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 2,
- "metadata": {},
- "outputs": [],
- "source": [
- "secrets_resolver = SecretsResolverDemo()"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 3,
- "metadata": {},
- "outputs": [],
- "source": [
- "class DIDResolverPeerDID(DIDResolver):\n",
- " async def resolve(self, did: DID) -> DIDDoc:\n",
- " did_doc_json = peer_did.resolve_peer_did(did, format = VerificationMaterialFormatPeerDID.JWK)\n",
- " did_doc = DIDDocPeerDID.from_json(did_doc_json)\n",
- "\n",
- " return DIDDoc(\n",
- " did=did_doc.did,\n",
- " key_agreement_kids = did_doc.agreement_kids,\n",
- " authentication_kids = did_doc.auth_kids,\n",
- " verification_methods = [\n",
- " VerificationMethod(\n",
- " id = m.id,\n",
- " type = VerificationMethodType.JSON_WEB_KEY_2020,\n",
- " controller = m.controller,\n",
- " verification_material = VerificationMaterial(\n",
- " format = VerificationMaterialFormat.JWK,\n",
- " value = json.dumps(m.ver_material.value)\n",
- " )\n",
- " )\n",
- " for m in did_doc.authentication + did_doc.key_agreement\n",
- " ],\n",
- " didcomm_services = [\n",
- " DIDCommService(\n",
- " id = s.id,\n",
- " service_endpoint = s.service_endpoint[0][\"uri\"] if \"uri\" in s.service_endpoint[0] else s.service_endpoint[0],\n",
- " routing_keys = s.routing_keys,\n",
- " accept = s.accept\n",
- " )\n",
- " for s in did_doc.service\n",
- " if isinstance(s, DIDCommServicePeerDID)\n",
- " ] if did_doc.service else []\n",
- " )"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 4,
- "metadata": {},
- "outputs": [],
- "source": [
- "async def create_peer_did(self,\n",
- " auth_keys_count: int = 1,\n",
- " agreement_keys_count: int = 1,\n",
- " service_endpoint: Optional[str] = None,\n",
- " service_routing_keys: Optional[List[str]] = None\n",
- " ) -> str:\n",
- " # 1. generate keys in JWK format\n",
- " agreem_keys = [generate_x25519_keys_as_jwk_dict() for _ in range(agreement_keys_count)]\n",
- " auth_keys = [generate_ed25519_keys_as_jwk_dict() for _ in range(auth_keys_count)]\n",
- "\n",
- " # 2. prepare the keys for peer DID lib\n",
- " agreem_keys_peer_did = [\n",
- " VerificationMaterialAgreement(\n",
- " type=VerificationMethodTypeAgreement.JSON_WEB_KEY_2020,\n",
- " format=VerificationMaterialFormatPeerDID.JWK,\n",
- " value=k[1],\n",
- " )\n",
- " for k in agreem_keys\n",
- " ]\n",
- " auth_keys_peer_did = [\n",
- " VerificationMaterialAuthentication(\n",
- " type=VerificationMethodTypeAuthentication.JSON_WEB_KEY_2020,\n",
- " format=VerificationMaterialFormatPeerDID.JWK,\n",
- " value=k[1],\n",
- " )\n",
- " for k in auth_keys\n",
- " ]\n",
- "\n",
- " # 3. generate service\n",
- " service = None\n",
- " if service_endpoint:\n",
- " service = json.dumps(\n",
- " DIDCommServicePeerDID(\n",
- " id=\"new-id\",\n",
- " service_endpoint=service_endpoint, \n",
- " routing_keys=service_routing_keys,\n",
- " accept=[\"didcomm/v2\"]\n",
- " ).to_dict()\n",
- " )\n",
- "\n",
- " # 4. call peer DID lib\n",
- " # if we have just one key (auth), then use numalg0 algorithm\n",
- " # otherwise use numalg2 algorithm\n",
- " if len(auth_keys_peer_did) == 1 and not agreem_keys_peer_did and not service:\n",
- " did = peer_did.create_peer_did_numalgo_0(auth_keys_peer_did[0])\n",
- " else:\n",
- " did = peer_did.create_peer_did_numalgo_2(\n",
- " encryption_keys=agreem_keys_peer_did,\n",
- " signing_keys=auth_keys_peer_did,\n",
- " service=service,\n",
- " )\n",
- "\n",
- " # 5. set KIDs as in DID DOC for secrets and store the secret in the secrets resolver\n",
- " did_doc = DIDDocPeerDID.from_json(peer_did.resolve_peer_did(did))\n",
- " for auth_key, kid in zip(auth_keys, did_doc.auth_kids):\n",
- " private_key = auth_key[0]\n",
- " private_key[\"kid\"] = kid\n",
- " await secrets_resolver.add_key(jwk_to_secret(private_key))\n",
- "\n",
- " for agreem_key, kid in zip(agreem_keys, did_doc.agreement_kids):\n",
- " private_key = agreem_key[0]\n",
- " private_key[\"kid\"] = kid\n",
- " await secrets_resolver.add_key(jwk_to_secret(private_key))\n",
- "\n",
- " return did\n"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Get OOB get somehow Alice DID (not covered here) --> Copy did from Alice notebook"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 5,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_did = \"did:peer:2.Ez6LSdiyKeupskKv1GvBoYYaSGLfwBzE9AAkm4jc5vrqsVDsF.Vz6Mkf2FzueL7AGjtuDAmiY8QjiXeRLzSJ725UR5RTdBjpZfG.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOlt7InVyaSI6ImRpZDpwZWVyOjIuRXo2TFNpOXoybnFpZU5OejdDUHpvS0JOcWhIbTF5UDlkY05DOVRuenh1UjJrQUtFeC5WejZNa3BTb2ZXS2M0RkxXU0pEeVh1OEd4UHNTMzZHWGVBb0FTcUNQenRTVVhRODJQLlNleUpwWkNJNkltNWxkeTFwWkNJc0luUWlPaUprYlNJc0luTWlPaUpvZEhSd2N6b3ZMMjFsWkdsaGRHOXlMbkp2YjNSemFXUXVZMnh2ZFdRaUxDSmhJanBiSW1ScFpHTnZiVzB2ZGpJaVhYMCJ9XSwiYSI6WyJkaWRjb21tL3YyIl19\""
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Get mediator DID from Alice DID and endpoint from mediator DID"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 6,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "did:peer:2.Ez6LSi9z2nqieNNz7CPzoKBNqhHm1yP9dcNC9TnzxuR2kAKEx.Vz6MkpSofWKc4FLWSJDyXu8GxPsS36GXeAoASqCPztSUXQ82P.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwczovL21lZGlhdG9yLnJvb3RzaWQuY2xvdWQiLCJhIjpbImRpZGNvbW0vdjIiXX0\n"
- ]
- }
- ],
- "source": [
- "alice_did_doc = json.loads(peer_did.resolve_peer_did(alice_did))\n",
- "mediator_did = alice_did_doc[\"service\"][0][\"serviceEndpoint\"][0][\"uri\"]\n",
- "print(mediator_did)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 7,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "https://mediator.rootsid.cloud\n"
- ]
- }
- ],
- "source": [
- "mediator_did_doc = json.loads(peer_did.resolve_peer_did(mediator_did))\n",
- "mediator_endpoint = mediator_did_doc[\"service\"][0][\"serviceEndpoint\"]\n",
- "print(mediator_endpoint)"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### BOB creates DID and a basic msg to Bob"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 8,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "Bob's DID: did:peer:2.Ez6LSmCUMvEKyJVpmQmg83apzBZMh5BNzDhXfMRzKacAWe7k5.Vz6MkrosMqqLEjU8sSMs9NDg6gQyRjXgJ77PFLhq1S3h4A538.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwczovL3d3dy5leGFtcGxlLmNvbS9ib2IiLCJhIjpbImRpZGNvbW0vdjIiXX0\n"
- ]
- }
- ],
- "source": [
- "bob_did_to_alice = await create_peer_did(1,1, service_endpoint=\"https://www.example.com/bob\")\n",
- "print(\"Bob's DID:\", bob_did_to_alice)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 9,
- "metadata": {},
- "outputs": [],
- "source": [
- "\n",
- "bob_basic_message = Message(\n",
- " id = str(uuid.uuid4()),\n",
- " type=\"https://didcomm.org/basicmessage/2.0/message\",\n",
- " body={\"content\": \"Hola Alice\"},\n",
- " created_time= int(datetime.datetime.now().timestamp()) \n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 10,
- "metadata": {},
- "outputs": [],
- "source": [
- "bob_basic_message_packed = await pack_encrypted(\n",
- " resolvers_config = ResolversConfig(\n",
- " secrets_resolver = secrets_resolver,\n",
- " did_resolver = DIDResolverPeerDID()\n",
- " ),\n",
- " message = bob_basic_message,\n",
- " frm = bob_did_to_alice,\n",
- " to = alice_did,\n",
- " sign_frm = None,\n",
- " pack_config = PackEncryptedConfig(protect_sender_id=False)\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 11,
- "metadata": {
- "scrolled": true
- },
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "eyJ0eXAiOiJhcHBsaWNhdGlvbi9kaWRjb21tLWVuY3J5cHRlZCtqc29uIiwiYWxnIjoiRUNESC0xUFUrQTI1NktXIiwiZW5jIjoiQTI1NkNCQy1IUzUxMiIsImFwdSI6IlpHbGtPbkJsWlhJNk1pNUZlalpNVTIxRFZVMTJSVXQ1U2xad2JWRnRaemd6WVhCNlFscE5hRFZDVG5wRWFGaG1UVko2UzJGalFWZGxOMnMxTGxaNk5rMXJjbTl6VFhGeFRFVnFWVGh6VTAxek9VNUVaelpuVVhsU2FsaG5TamMzVUVaTWFIRXhVek5vTkVFMU16Z3VVMlY1U25CYVEwazJTVzAxYkdSNU1YQmFRMGx6U1c1UmFVOXBTbXRpVTBselNXNU5hVTlwU205a1NGSjNZM3B2ZGt3elpETmtlVFZzWlVkR2RHTkhlR3hNYlU1MllsTTVhV0l5U1dsTVEwcG9TV3B3WWtsdFVuQmFSMDUyWWxjd2RtUnFTV2xZV0RBak5reFRiVU5WVFhaRlMzbEtWbkJ0VVcxbk9ETmhjSHBDV2sxb05VSk9la1JvV0daTlVucExZV05CVjJVM2F6VSIsImFwdiI6Imw5NllfX3M5cHYxbG1CaEdxb0h2eF96eHBPamxxMVY2QUdGWWRVcDBBQjQiLCJza2lkIjoiZGlkOnBlZXI6Mi5FejZMU21DVU12RUt5SlZwbVFtZzgzYXB6QlpNaDVCTnpEaFhmTVJ6S2FjQVdlN2s1LlZ6Nk1rcm9zTXFxTEVqVThzU01zOU5EZzZnUXlSalhnSjc3UEZMaHExUzNoNEE1MzguU2V5SnBaQ0k2SW01bGR5MXBaQ0lzSW5RaU9pSmtiU0lzSW5NaU9pSm9kSFJ3Y3pvdkwzZDNkeTVsZUdGdGNHeGxMbU52YlM5aWIySWlMQ0poSWpwYkltUnBaR052YlcwdmRqSWlYWDAjNkxTbUNVTXZFS3lKVnBtUW1nODNhcHpCWk1oNUJOekRoWGZNUnpLYWNBV2U3azUiLCJlcGsiOnsiY3J2IjoiWDI1NTE5IiwieCI6IkF5Zm9vekhmb0J4OHM0TE00ZnRVdW5LVllydkhvSTJxY0l3X0V3bmlEQ1kiLCJrdHkiOiJPS1AifX0\n"
- ]
- }
- ],
- "source": [
- "print(json.loads(bob_basic_message_packed.packed_msg)[\"protected\"])"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Bobs cread DID and msg routed via Mediator"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 12,
- "metadata": {},
- "outputs": [],
- "source": [
- "bob_did_to_mediator = await create_peer_did(1,1, service_endpoint=\"https://www.example.com/bob\")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 13,
- "metadata": {},
- "outputs": [],
- "source": [
- "bob_routed_message = Message(\n",
- " id = str(uuid.uuid4()),\n",
- " type=\"https://didcomm.org/routing/2.0/forward\",\n",
- " body={\"next\": alice_did},\n",
- " to=[mediator_did],\n",
- " attachments=[Attachment(\n",
- " data=AttachmentDataJson(json=json.loads(bob_basic_message_packed.packed_msg))\n",
- " )]\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 14,
- "metadata": {},
- "outputs": [],
- "source": [
- "bob_routed_message_packed = await pack_encrypted(\n",
- " resolvers_config = ResolversConfig(\n",
- " secrets_resolver = secrets_resolver,\n",
- " did_resolver = DIDResolverPeerDID()\n",
- " ),\n",
- " message = bob_routed_message,\n",
- " frm = bob_did_to_mediator,\n",
- " to = mediator_did,\n",
- " sign_frm = None,\n",
- " pack_config = PackEncryptedConfig(protect_sender_id=False)\n",
- ")"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Sending to Mediator"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 15,
- "metadata": {},
- "outputs": [],
- "source": [
- "headers = {\"Content-Type\": \"application/didcomm-encrypted+json\"}\n",
- "resp = requests.post(mediator_endpoint, headers=headers, data = bob_routed_message_packed.packed_msg)\n"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": []
- }
- ],
- "metadata": {
- "kernelspec": {
- "display_name": "Python 3 (ipykernel)",
- "language": "python",
- "name": "python3"
- },
- "language_info": {
- "codemirror_mode": {
- "name": "ipython",
- "version": 3
- },
- "file_extension": ".py",
- "mimetype": "text/x-python",
- "name": "python",
- "nbconvert_exporter": "python",
- "pygments_lexer": "ipython3",
- "version": "3.10.6"
- }
- },
- "nbformat": 4,
- "nbformat_minor": 4
-}
diff --git a/mercury/roots-id-mediator/notebooks/test_mediator.ipynb b/mercury/roots-id-mediator/notebooks/test_mediator.ipynb
deleted file mode 100644
index e91775992c..0000000000
--- a/mercury/roots-id-mediator/notebooks/test_mediator.ipynb
+++ /dev/null
@@ -1,414 +0,0 @@
-{
- "cells": [
- {
- "cell_type": "code",
- "execution_count": 13,
- "metadata": {},
- "outputs": [],
- "source": [
- "import json\n",
- "import base64\n",
- "import qrcode\n",
- "import requests\n",
- "import datetime\n",
- "import urllib.parse\n",
- "import uuid\n",
- "import matplotlib.pyplot as plt\n",
- "from pymongo import MongoClient\n",
- "from typing import Optional, List\n",
- "from didcomm.common.types import DID, VerificationMethodType, VerificationMaterial, VerificationMaterialFormat\n",
- "from didcomm.did_doc.did_doc import DIDDoc, VerificationMethod, DIDCommService\n",
- "from didcomm.did_doc.did_resolver import DIDResolver\n",
- "from didcomm.message import Message, FromPrior\n",
- "from didcomm.secrets.secrets_resolver_demo import SecretsResolverDemo\n",
- "from didcomm.unpack import unpack, UnpackResult\n",
- "from didcomm.common.resolvers import ResolversConfig\n",
- "from didcomm.pack_encrypted import pack_encrypted, PackEncryptedConfig, PackEncryptedResult\n",
- "from peerdid.core.did_doc_types import DIDCommServicePeerDID\n",
- "from didcomm.secrets.secrets_util import generate_x25519_keys_as_jwk_dict, generate_ed25519_keys_as_jwk_dict, jwk_to_secret\n",
- "from peerdid import peer_did\n",
- "from peerdid.did_doc import DIDDocPeerDID\n",
- "from peerdid.types import VerificationMaterialAuthentication, VerificationMethodTypeAuthentication, VerificationMaterialAgreement, VerificationMethodTypeAgreement, VerificationMaterialFormatPeerDID"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "## Helpers"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 14,
- "metadata": {},
- "outputs": [],
- "source": [
- "secrets_resolver = SecretsResolverDemo()"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 15,
- "metadata": {},
- "outputs": [],
- "source": [
- "class DIDResolverPeerDID(DIDResolver):\n",
- " async def resolve(self, did: DID) -> DIDDoc:\n",
- " did_doc_json = peer_did.resolve_peer_did(did, format = VerificationMaterialFormatPeerDID.JWK)\n",
- " did_doc = DIDDocPeerDID.from_json(did_doc_json)\n",
- "\n",
- " return DIDDoc(\n",
- " did=did_doc.did,\n",
- " key_agreement_kids = did_doc.agreement_kids,\n",
- " authentication_kids = did_doc.auth_kids,\n",
- " verification_methods = [\n",
- " VerificationMethod(\n",
- " id = m.id,\n",
- " type = VerificationMethodType.JSON_WEB_KEY_2020,\n",
- " controller = m.controller,\n",
- " verification_material = VerificationMaterial(\n",
- " format = VerificationMaterialFormat.JWK,\n",
- " value = json.dumps(m.ver_material.value)\n",
- " )\n",
- " )\n",
- " for m in did_doc.authentication + did_doc.key_agreement\n",
- " ],\n",
- " didcomm_services = [\n",
- " DIDCommService(\n",
- " id = s.id,\n",
- " service_endpoint = s.service_endpoint,\n",
- " routing_keys = s.routing_keys,\n",
- " accept = s.accept\n",
- " )\n",
- " for s in did_doc.service\n",
- " if isinstance(s, DIDCommServicePeerDID)\n",
- " ] if did_doc.service else []\n",
- " )"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 16,
- "metadata": {},
- "outputs": [],
- "source": [
- "async def create_peer_did(self,\n",
- " auth_keys_count: int = 1,\n",
- " agreement_keys_count: int = 1,\n",
- " service_endpoint: Optional[str] = None,\n",
- " service_routing_keys: Optional[List[str]] = None\n",
- " ) -> str:\n",
- " # 1. generate keys in JWK format\n",
- " agreem_keys = [generate_x25519_keys_as_jwk_dict() for _ in range(agreement_keys_count)]\n",
- " auth_keys = [generate_ed25519_keys_as_jwk_dict() for _ in range(auth_keys_count)]\n",
- "\n",
- " # 2. prepare the keys for peer DID lib\n",
- " agreem_keys_peer_did = [\n",
- " VerificationMaterialAgreement(\n",
- " type=VerificationMethodTypeAgreement.JSON_WEB_KEY_2020,\n",
- " format=VerificationMaterialFormatPeerDID.JWK,\n",
- " value=k[1],\n",
- " )\n",
- " for k in agreem_keys\n",
- " ]\n",
- " auth_keys_peer_did = [\n",
- " VerificationMaterialAuthentication(\n",
- " type=VerificationMethodTypeAuthentication.JSON_WEB_KEY_2020,\n",
- " format=VerificationMaterialFormatPeerDID.JWK,\n",
- " value=k[1],\n",
- " )\n",
- " for k in auth_keys\n",
- " ]\n",
- "\n",
- " # 3. generate service\n",
- " service = None\n",
- " if service_endpoint:\n",
- " service = json.dumps(\n",
- " DIDCommServicePeerDID(\n",
- " id=\"new-id\",\n",
- " service_endpoint=service_endpoint, routing_keys=service_routing_keys,\n",
- " accept=[\"didcomm/v2\"]\n",
- " ).to_dict()\n",
- " )\n",
- "\n",
- " # 4. call peer DID lib\n",
- " # if we have just one key (auth), then use numalg0 algorithm\n",
- " # otherwise use numalg2 algorithm\n",
- " if len(auth_keys_peer_did) == 1 and not agreem_keys_peer_did and not service:\n",
- " did = peer_did.create_peer_did_numalgo_0(auth_keys_peer_did[0])\n",
- " else:\n",
- " did = peer_did.create_peer_did_numalgo_2(\n",
- " encryption_keys=agreem_keys_peer_did,\n",
- " signing_keys=auth_keys_peer_did,\n",
- " service=service,\n",
- " )\n",
- "\n",
- " # 5. set KIDs as in DID DOC for secrets and store the secret in the secrets resolver\n",
- " did_doc = DIDDocPeerDID.from_json(peer_did.resolve_peer_did(did))\n",
- " for auth_key, kid in zip(auth_keys, did_doc.auth_kids):\n",
- " private_key = auth_key[0]\n",
- " private_key[\"kid\"] = kid\n",
- " await secrets_resolver.add_key(jwk_to_secret(private_key))\n",
- "\n",
- " for agreem_key, kid in zip(agreem_keys, did_doc.agreement_kids):\n",
- " private_key = agreem_key[0]\n",
- " private_key[\"kid\"] = kid\n",
- " await secrets_resolver.add_key(jwk_to_secret(private_key))\n",
- "\n",
- " return did\n"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Receiving the OOB message"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 23,
- "metadata": {},
- "outputs": [],
- "source": [
- "oob_url = requests.get(\"http://rootsid-mediator:8000/oob_url\").text\n",
- "#oob_url = requests.get(\"https://mediator.rootsid.cloud/oob_url\").text\n",
- "#oob_url = requests.get(\"http://127.0.0.1:8000/oob_url\").text\n",
- "received_msg_encoded = oob_url.split(\"=\")[1]\n",
- "received_msg_decoded = json.loads(str(base64.urlsafe_b64decode(received_msg_encoded + \"==\"), \"utf-8\"))\n",
- "\n"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "## Preparing message"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 24,
- "metadata": {},
- "outputs": [],
- "source": [
- "bob_did = await create_peer_did(1,1, service_endpoint=\"https://www.example.com/bob\")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 25,
- "metadata": {},
- "outputs": [],
- "source": [
- "# bob_response_message = Message(\n",
- "# body = { \"response_requested\": True },\n",
- "# custom_headers = [{\"return_route\": \"all\"}],\n",
- "# id = str(uuid.uuid4()),\n",
- "# #pthid = received_msg_decoded[\"id\"],\n",
- "# type = \"https://didcomm.org/trust-ping/2.0/ping\",\n",
- "# frm = bob_did,\n",
- "# to = [received_msg_decoded[\"from\"]]\n",
- "# )\n",
- "# bob_response_message = Message(\n",
- "# custom_headers = [{\n",
- "# \"return_route\": \"all\",\n",
- "# \"created_time\": int(datetime.datetime.now().timestamp()) \n",
- "# }],\n",
- "# id = str(uuid.uuid4()),\n",
- "# #pthid = received_msg_decoded[\"id\"],\n",
- "# type = \"https://didcomm.org/basicmessage/2.0/message\",\n",
- "# frm = bob_did,\n",
- "# to = [received_msg_decoded[\"from\"]],\n",
- "# body = {\"content\": \"Who won the soccer world cup in 1986?\"}\n",
- "# )\n",
- "# bob_response_message = Message(\n",
- "# custom_headers = [{\"return_route\": \"all\"}],\n",
- "# id = str(uuid.uuid4()),\n",
- "# #pthid = received_msg_decoded[\"id\"],\n",
- "# type = \"https://didcomm.org/coordinate-mediation/2.0/keylist-query\",\n",
- "# body = {}\n",
- "# )\n",
- "# bob_response_message = Message(\n",
- "# custom_headers = [{\"return_route\": \"all\"}],\n",
- "# id = str(uuid.uuid4()),\n",
- "# #pthid = received_msg_decoded[\"id\"],\n",
- "# type = \"https://didcomm.org/coordinate-mediation/2.0/keylist-update\",\n",
- "# body = {\n",
- "# \"updates\": [\n",
- "# {\n",
- "# \"recipient_key\": \"did:key:z6MkpTHR8VNsBxYAAWHut2Geadd9jSwuBV8xRoAnwWsdvktH2\",\n",
- "# \"action\": \"remove\"\n",
- "# }\n",
- "# ]\n",
- " \n",
- "# }\n",
- "# )\n",
- "# bob_response_message = Message(\n",
- "# custom_headers = [{\n",
- "# \"return_route\": \"all\"}],\n",
- "# id = str(uuid.uuid4()),\n",
- "# #pthid = received_msg_decoded[\"id\"],\n",
- "# type = \"https://didcomm.org/discover-features/2.0/queries\",\n",
- "# frm = bob_did,\n",
- "# to = [received_msg_decoded[\"from\"]],\n",
- "# body = {\n",
- "# \"queries\": [\n",
- "# { \"feature-type\": \"protocol\", \"match\": \"https://didcomm.org/basicmessage/2.*\" }\n",
- "# ]\n",
- "# }\n",
- "# )\n",
- "bob_response_message = Message(\n",
- " custom_headers = [{\n",
- " \"return_route\": \"all\"}],\n",
- " id = str(uuid.uuid4()),\n",
- " #pthid = received_msg_decoded[\"id\"],\n",
- " type = \"https://didcomm.org/shorten-url/1.0/request-shortened-url\",\n",
- " frm = bob_did,\n",
- " to = [received_msg_decoded[\"from\"]],\n",
- " body = {\n",
- " \"url\": \"https://my.example.com/superlongurl\",\n",
- " \"requested_validity_seconds\": 86400,\n",
- " \"goal_code\": \"shorten.oobv2\",\n",
- "# \"short_url_slug\": \"algo\"\n",
- " }\n",
- ")\n",
- "# bob_response_message = Message(\n",
- "# custom_headers = [{\n",
- "# \"return_route\": \"all\"}],\n",
- "# id = str(uuid.uuid4()),\n",
- "# #pthid = received_msg_decoded[\"id\"],\n",
- "# type = \"https://didcomm.org/shorten-url/1.0/invalidate-shortened-url\",\n",
- "# frm = bob_did,\n",
- "# to = [received_msg_decoded[\"from\"]],\n",
- "# body = {\n",
- "# \"shortened_url\": \"http://127.0.0.1:8000/qr?_oobid=eaf4166322d04ddba2829f0807b6a7cf\",\n",
- "# }\n",
- "# )\n"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 26,
- "metadata": {},
- "outputs": [],
- "source": [
- "bob_packed_msg = await pack_encrypted(\n",
- " resolvers_config = ResolversConfig(\n",
- " secrets_resolver = secrets_resolver,\n",
- " did_resolver = DIDResolverPeerDID()\n",
- " ),\n",
- " message = bob_response_message,\n",
- " frm = bob_did,\n",
- " to = received_msg_decoded[\"from\"],\n",
- " sign_frm = None,\n",
- " pack_config = PackEncryptedConfig(protect_sender_id=False)\n",
- ")"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "### Sending the message to Mediator"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 27,
- "metadata": {},
- "outputs": [],
- "source": [
- "alice_did_doc = json.loads(peer_did.resolve_peer_did(received_msg_decoded[\"from\"]))\n",
- "alice_endpoint = alice_did_doc[\"service\"][0][\"serviceEndpoint\"]\n",
- "headers = {\"Content-Type\": \"application/didcomm-encrypted+json\"}\n",
- "resp = requests.post(alice_endpoint, headers=headers, data = bob_packed_msg.packed_msg)\n"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "## Decoding response\n"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 28,
- "metadata": {},
- "outputs": [],
- "source": [
- "bob_unpack_msg = await unpack(\n",
- " resolvers_config=ResolversConfig(\n",
- " secrets_resolver=secrets_resolver,\n",
- " did_resolver=DIDResolverPeerDID()\n",
- " ),\n",
- " packed_msg= resp.json()\n",
- ")"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 29,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "UnpackResult(message=Message(id='f7c12a75-692d-4ebf-8acb-8fc48643ccdd', type='https://didcomm.org/shorten-url/1.0/shortened-url', body={'shortened_url': 'http://rootsid-mediator:8000/qr?_oobid=d74c9499dbb641fdb1a68127db13a104', 'expires_time': 1663691324}, frm=None, to=None, created_time=None, expires_time=None, from_prior=FromPrior(iss='did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19', sub='did:peer:2.Ez6LSbqVNNhbMNXdtL7ez2niXipSj62mDLVeU8MEFTVsPvKNZ.Vz6MkrjCuG265wE87Czr91xx6eReNbcRs4WAxjwKsCiZksYrh.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19', aud=None, exp=None, nbf=None, iat=None, jti=None), please_ack=None, ack=None, thid='1f76f358-c442-43ec-a681-5d062b2f1e87', pthid=None, attachments=None, custom_headers=None), metadata=Metadata(encrypted=True, authenticated=True, non_repudiation=False, anonymous_sender=False, re_wrapped_in_forward=False, encrypted_from='did:peer:2.Ez6LSbqVNNhbMNXdtL7ez2niXipSj62mDLVeU8MEFTVsPvKNZ.Vz6MkrjCuG265wE87Czr91xx6eReNbcRs4WAxjwKsCiZksYrh.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19#6LSbqVNNhbMNXdtL7ez2niXipSj62mDLVeU8MEFTVsPvKNZ', encrypted_to=['did:peer:2.Ez6LSoa8yc91UCZ7joALgHiWDCnCHjywHVVtzPFvXuUTkiaaz.Vz6MkhcYw1on97mu1Z38pkndRMUMQnGzijYuv1H3ymxxNG6az.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwczovL3d3dy5leGFtcGxlLmNvbS9ib2IiLCJhIjpbImRpZGNvbW0vdjIiXX0#6LSoa8yc91UCZ7joALgHiWDCnCHjywHVVtzPFvXuUTkiaaz'], sign_from=None, from_prior_issuer_kid='did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19#6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX', enc_alg_auth=, enc_alg_anon=None, sign_alg=None, signed_message=None, from_prior_jwt='eyJhbGciOiJFZERTQSIsInR5cCI6IkpXVCIsImtpZCI6ImRpZDpwZWVyOjIuRXo2TFNmdVlvZUU4QXJvclJuVkVIRzZnMVRVYjlZNjZLZkczNVdYcmdEbnJmWGtkVi5WejZNa3ZaVlp3SzlSVGtuTThEN0JKM0Q3aVphdTNBSFlKV0M2a1VLcWtvZEtobVdYLlNleUpwWkNJNkltNWxkeTFwWkNJc0luUWlPaUprYlNJc0luTWlPaUpvZEhSd09pOHZjbTl2ZEhOcFpDMXRaV1JwWVhSdmNqbzRNREF3SWl3aVlTSTZXeUprYVdSamIyMXRMM1l5SWwxOSM2TWt2WlZad0s5UlRrbk04RDdCSjNEN2laYXUzQUhZSldDNmtVS3Frb2RLaG1XWCJ9.eyJpc3MiOiJkaWQ6cGVlcjoyLkV6NkxTZnVZb2VFOEFyb3JSblZFSEc2ZzFUVWI5WTY2S2ZHMzVXWHJnRG5yZlhrZFYuVno2TWt2WlZad0s5UlRrbk04RDdCSjNEN2laYXUzQUhZSldDNmtVS3Frb2RLaG1XWC5TZXlKcFpDSTZJbTVsZHkxcFpDSXNJblFpT2lKa2JTSXNJbk1pT2lKb2RIUndPaTh2Y205dmRITnBaQzF0WldScFlYUnZjam80TURBd0lpd2lZU0k2V3lKa2FXUmpiMjF0TDNZeUlsMTkiLCJzdWIiOiJkaWQ6cGVlcjoyLkV6NkxTYnFWTk5oYk1OWGR0TDdlejJuaVhpcFNqNjJtRExWZVU4TUVGVFZzUHZLTlouVno2TWtyakN1RzI2NXdFODdDenI5MXh4NmVSZU5iY1JzNFdBeGp3S3NDaVprc1lyaC5TZXlKcFpDSTZJbTVsZHkxcFpDSXNJblFpT2lKa2JTSXNJbk1pT2lKb2RIUndPaTh2Y205dmRITnBaQzF0WldScFlYUnZjam80TURBd0lpd2lZU0k2V3lKa2FXUmpiMjF0TDNZeUlsMTkifQ.dJc_Vb81O17RxR5jnaoZUF3q6L06ilvEZij_8fA8jImjnxYaX-d_I6KF6uZq6eP0xc79MTLUZg05E2P4-UlhAg'))\n"
- ]
- }
- ],
- "source": [
- "print(bob_unpack_msg)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": 30,
- "metadata": {},
- "outputs": [
- {
- "name": "stdout",
- "output_type": "stream",
- "text": [
- "Message(id='f7c12a75-692d-4ebf-8acb-8fc48643ccdd', type='https://didcomm.org/shorten-url/1.0/shortened-url', body={'shortened_url': 'http://rootsid-mediator:8000/qr?_oobid=d74c9499dbb641fdb1a68127db13a104', 'expires_time': 1663691324}, frm=None, to=None, created_time=None, expires_time=None, from_prior=FromPrior(iss='did:peer:2.Ez6LSfuYoeE8ArorRnVEHG6g1TUb9Y66KfG35WXrgDnrfXkdV.Vz6MkvZVZwK9RTknM8D7BJ3D7iZau3AHYJWC6kUKqkodKhmWX.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19', sub='did:peer:2.Ez6LSbqVNNhbMNXdtL7ez2niXipSj62mDLVeU8MEFTVsPvKNZ.Vz6MkrjCuG265wE87Czr91xx6eReNbcRs4WAxjwKsCiZksYrh.SeyJpZCI6Im5ldy1pZCIsInQiOiJkbSIsInMiOiJodHRwOi8vcm9vdHNpZC1tZWRpYXRvcjo4MDAwIiwiYSI6WyJkaWRjb21tL3YyIl19', aud=None, exp=None, nbf=None, iat=None, jti=None), please_ack=None, ack=None, thid='1f76f358-c442-43ec-a681-5d062b2f1e87', pthid=None, attachments=None, custom_headers=None)\n"
- ]
- }
- ],
- "source": [
- "print(bob_unpack_msg.message)"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": []
- }
- ],
- "metadata": {
- "kernelspec": {
- "display_name": "Python 3 (ipykernel)",
- "language": "python",
- "name": "python3"
- },
- "language_info": {
- "codemirror_mode": {
- "name": "ipython",
- "version": 3
- },
- "file_extension": ".py",
- "mimetype": "text/x-python",
- "name": "python",
- "nbconvert_exporter": "python",
- "pygments_lexer": "ipython3",
- "version": "3.10.6"
- }
- },
- "nbformat": 4,
- "nbformat_minor": 4
-}
diff --git a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFilterFormat.scala b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFilterFormat.scala
similarity index 78%
rename from mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFilterFormat.scala
rename to mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFilterFormat.scala
index 4a8f415ad0..e7c0296801 100644
--- a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFilterFormat.scala
+++ b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFilterFormat.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.mercury.vc.anoncreds
+package org.hyperledger.identus.vc.anoncreds
-import io.iohk.atala.mercury.protocol.issuecredential.IssueCredentialProposeFormat
+import org.hyperledger.identus.mercury.protocol.issuecredential.IssueCredentialProposeFormat
/** @see
* https://github.com/hyperledger/aries-rfcs/blob/main/features/0771-anoncreds-attachments/README.md#credential-filter-format
diff --git a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFormat.scala b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFormat.scala
similarity index 81%
rename from mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFormat.scala
rename to mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFormat.scala
index 2f44f70f1f..04f00f68ae 100644
--- a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFormat.scala
+++ b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialFormat.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.mercury.vc.anoncreds
+package org.hyperledger.identus.vc.anoncreds
-import io.iohk.atala.mercury.protocol.issuecredential.IssueCredentialIssuedFormat
+import org.hyperledger.identus.mercury.protocol.issuecredential.IssueCredentialIssuedFormat
/** @see
* https://github.com/hyperledger/aries-rfcs/blob/main/features/0771-anoncreds-attachments/README.md#credential-format
diff --git a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialOfferFormat.scala b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialOfferFormat.scala
similarity index 85%
rename from mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialOfferFormat.scala
rename to mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialOfferFormat.scala
index 823ec1a3ce..d77fd0f1f3 100644
--- a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialOfferFormat.scala
+++ b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialOfferFormat.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.mercury.vc.anoncreds
+package org.hyperledger.identus.vc.anoncreds
-import io.iohk.atala.mercury.protocol.issuecredential.IssueCredentialOfferFormat
+import org.hyperledger.identus.mercury.protocol.issuecredential.IssueCredentialOfferFormat
/** @see
* https://github.com/hyperledger/aries-rfcs/blob/main/features/0771-anoncreds-attachments/README.md#credential-offer-format
diff --git a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialRequestFormat.scala b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialRequestFormat.scala
similarity index 77%
rename from mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialRequestFormat.scala
rename to mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialRequestFormat.scala
index 9cb886b32e..4f849234b7 100644
--- a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialRequestFormat.scala
+++ b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/CredentialRequestFormat.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.mercury.vc.anoncreds
+package org.hyperledger.identus.vc.anoncreds
-import io.iohk.atala.mercury.protocol.issuecredential.IssueCredentialRequestFormat
+import org.hyperledger.identus.mercury.protocol.issuecredential.IssueCredentialRequestFormat
/** https://github.com/hyperledger/aries-rfcs/blob/main/features/0771-anoncreds-attachments/README.md#credential-request-format
*/
diff --git a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofFormat.scala b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofFormat.scala
similarity index 80%
rename from mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofFormat.scala
rename to mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofFormat.scala
index 2d1d7d5246..802f388f35 100644
--- a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofFormat.scala
+++ b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofFormat.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.mercury.vc.anoncreds
+package org.hyperledger.identus.vc.anoncreds
-import io.iohk.atala.mercury.protocol.issuecredential.IssueCredentialRequestFormat
+import org.hyperledger.identus.mercury.protocol.issuecredential.IssueCredentialRequestFormat
type TODO = Any
diff --git a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofRequestFormat.scala b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofRequestFormat.scala
similarity index 88%
rename from mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofRequestFormat.scala
rename to mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofRequestFormat.scala
index 51c3c636cc..f379214e37 100644
--- a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofRequestFormat.scala
+++ b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/anoncreds/ProofRequestFormat.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.mercury.vc.anoncreds
+package org.hyperledger.identus.vc.anoncreds
-import io.iohk.atala.mercury.protocol.presentproof.PresentCredentialRequestFormat
+import org.hyperledger.identus.mercury.protocol.presentproof.PresentCredentialRequestFormat
/** @see
* https://github.com/hyperledger/aries-rfcs/blob/main/features/0771-anoncreds-attachments/README.md#proof-request-format
diff --git a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/jwt/ProposeCredential.scala b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/dif/ProposeCredential.scala
similarity index 98%
rename from mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/jwt/ProposeCredential.scala
rename to mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/dif/ProposeCredential.scala
index 01caa50161..0e832e405e 100644
--- a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/jwt/ProposeCredential.scala
+++ b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/dif/ProposeCredential.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.vc.jwt
+package org.hyperledger.identus.vc.dif
type DID = String
diff --git a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/dif/ProposeCredential.scala b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/jwt/ProposeCredential.scala
similarity index 98%
rename from mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/dif/ProposeCredential.scala
rename to mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/jwt/ProposeCredential.scala
index df53ca6dc1..27996720b3 100644
--- a/mercury/mercury-library/vc/src/main/scala/io/iohk/atala/mercury/vc/dif/ProposeCredential.scala
+++ b/mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/jwt/ProposeCredential.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.mercury.vc.dif
+package org.hyperledger.identus.vc.jwt
type DID = String
diff --git a/package.json b/package.json
index b3d7ac8d33..63e3ebe4cb 100644
--- a/package.json
+++ b/package.json
@@ -1,5 +1,5 @@
{
- "name": "atala-prism-building-blocks",
+ "name": "identus-cloud-agent",
"version": "1.31.0",
"engines": {
"node": ">=16.13.0"
@@ -28,7 +28,7 @@
"prerelease": "snapshot"
}
],
- "tagFormat": "prism-agent-v${version}",
+ "tagFormat": "cloud-agent-v${version}",
"plugins": [
"@semantic-release/commit-analyzer",
"@semantic-release/release-notes-generator",
@@ -41,7 +41,7 @@
[
"@semantic-release/exec",
{
- "prepareCmd": "sed -i.bak \"s/PRISM_AGENT_VERSION=.*/PRISM_AGENT_VERSION=${nextRelease.version}/\" ./infrastructure/local/.env && rm -f ./infrastructure/local/.env.bak"
+ "prepareCmd": "sed -i.bak \"s/AGENT_VERSION=.*/AGENT_VERSION=${nextRelease.version}/\" ./infrastructure/local/.env && rm -f ./infrastructure/local/.env.bak"
}
],
[
@@ -53,7 +53,7 @@
[
"@semantic-release/exec",
{
- "prepareCmd": "sbt \"prismAgentServer/test:runMain io.iohk.atala.api.util.Tapir2StaticOAS ${process.env.PWD}/prism-agent/service/api/http/prism-agent-openapi-spec.yaml ${nextRelease.version}\""
+ "prepareCmd": "sbt \"prismAgentServer/test:runMain org.hyperledger.identus.api.util.Tapir2StaticOAS ${process.env.PWD}/cloud-agent/service/api/http/cloud-agent-openapi-spec.yaml ${nextRelease.version}\""
}
],
[
@@ -89,7 +89,7 @@
[
"@semantic-release/exec",
{
- "prepareCmd": "docker buildx build --platform=linux/arm64,linux/amd64 --push -t ghcr.io/hyperledger/identus-cloud-agent:${nextRelease.version} ./prism-agent/service/server/target/docker/stage"
+ "prepareCmd": "docker buildx build --platform=linux/arm64,linux/amd64 --push -t ghcr.io/hyperledger/identus-cloud-agent:${nextRelease.version} ./cloud-agent/service/server/target/docker/stage"
}
],
[
@@ -107,13 +107,13 @@
"DEPENDENCIES.md",
"package.json",
"package-lock.json",
- "prism-agent/service/api/http/prism-agent-openapi-spec.yaml",
+ "cloud-agent/service/api/http/cloud-agent-openapi-spec.yaml",
"infrastructure/charts/agent/Chart.yaml",
"infrastructure/charts/index.yaml",
"infrastructure/charts/*.tgz",
"infrastructure/local/.env"
],
- "message": "chore(release): cut open enterprise agent ${nextRelease.version} release\n\n${nextRelease.notes}\n\nSigned-off-by: Allain Magyar "
+ "message": "chore(release): cut Identus Cloud agent ${nextRelease.version} release\n\n${nextRelease.notes}\n\nSigned-off-by: Allain Magyar "
}
],
[
@@ -123,7 +123,7 @@
"notifyOnFail": true,
"markdownReleaseNotes": true,
"onSuccessTemplate": {
- "text": "A new version of Opent Enterprise Agent successfully released!\nVersion: `$npm_package_version`\nTag: $repo_url/releases/tag/$npm_package_version\n\nRelease notes:\n$release_notes"
+ "text": "A new version of Identus Cloud Agent successfully released!\nVersion: `$npm_package_version`\nTag: $repo_url/releases/tag/$npm_package_version\n\nRelease notes:\n$release_notes"
}
}
]
diff --git a/pollux/lib/CHANGELOG.md b/pollux/CHANGELOG.md
similarity index 100%
rename from pollux/lib/CHANGELOG.md
rename to pollux/CHANGELOG.md
diff --git a/pollux/lib/README.md b/pollux/README.md
similarity index 100%
rename from pollux/lib/README.md
rename to pollux/README.md
diff --git a/pollux/lib/anoncreds/README_anoncreds.md b/pollux/anoncreds/README_anoncreds.md
similarity index 100%
rename from pollux/lib/anoncreds/README_anoncreds.md
rename to pollux/anoncreds/README_anoncreds.md
diff --git a/pollux/lib/anoncreds/anoncreds-jvm-1.0-SNAPSHOT.jar b/pollux/anoncreds/anoncreds-jvm-1.0-SNAPSHOT.jar
similarity index 100%
rename from pollux/lib/anoncreds/anoncreds-jvm-1.0-SNAPSHOT.jar
rename to pollux/anoncreds/anoncreds-jvm-1.0-SNAPSHOT.jar
diff --git a/pollux/lib/anoncreds/native-lib/NATIVE/darwin-aarch64/libuniffi_anoncreds_wrapper.dylib b/pollux/anoncreds/native-lib/NATIVE/darwin-aarch64/libuniffi_anoncreds_wrapper.dylib
similarity index 100%
rename from pollux/lib/anoncreds/native-lib/NATIVE/darwin-aarch64/libuniffi_anoncreds_wrapper.dylib
rename to pollux/anoncreds/native-lib/NATIVE/darwin-aarch64/libuniffi_anoncreds_wrapper.dylib
diff --git a/pollux/lib/anoncreds/native-lib/NATIVE/darwin-x86-64/libuniffi_anoncreds_wrapper.dylib b/pollux/anoncreds/native-lib/NATIVE/darwin-x86-64/libuniffi_anoncreds_wrapper.dylib
similarity index 100%
rename from pollux/lib/anoncreds/native-lib/NATIVE/darwin-x86-64/libuniffi_anoncreds_wrapper.dylib
rename to pollux/anoncreds/native-lib/NATIVE/darwin-x86-64/libuniffi_anoncreds_wrapper.dylib
diff --git a/pollux/lib/anoncreds/native-lib/NATIVE/linux-aarch64/libuniffi_anoncreds_wrapper.so b/pollux/anoncreds/native-lib/NATIVE/linux-aarch64/libuniffi_anoncreds_wrapper.so
similarity index 100%
rename from pollux/lib/anoncreds/native-lib/NATIVE/linux-aarch64/libuniffi_anoncreds_wrapper.so
rename to pollux/anoncreds/native-lib/NATIVE/linux-aarch64/libuniffi_anoncreds_wrapper.so
diff --git a/pollux/lib/anoncreds/native-lib/NATIVE/linux-x86-64/libuniffi_anoncreds_wrapper.so b/pollux/anoncreds/native-lib/NATIVE/linux-x86-64/libuniffi_anoncreds_wrapper.so
similarity index 100%
rename from pollux/lib/anoncreds/native-lib/NATIVE/linux-x86-64/libuniffi_anoncreds_wrapper.so
rename to pollux/anoncreds/native-lib/NATIVE/linux-x86-64/libuniffi_anoncreds_wrapper.so
diff --git a/pollux/lib/anoncreds/native-lib/helper_script_to_update.sh b/pollux/anoncreds/native-lib/helper_script_to_update.sh
similarity index 100%
rename from pollux/lib/anoncreds/native-lib/helper_script_to_update.sh
rename to pollux/anoncreds/native-lib/helper_script_to_update.sh
diff --git a/pollux/lib/anoncreds/src/main/scala/io/iohk/atala/pollux/anoncreds/AnoncredLib.scala b/pollux/anoncreds/src/main/scala/org/hyperledger/identus/pollux/anoncreds/AnoncredLib.scala
similarity index 99%
rename from pollux/lib/anoncreds/src/main/scala/io/iohk/atala/pollux/anoncreds/AnoncredLib.scala
rename to pollux/anoncreds/src/main/scala/org/hyperledger/identus/pollux/anoncreds/AnoncredLib.scala
index 5d6b3c7cf4..28ce3726b9 100644
--- a/pollux/lib/anoncreds/src/main/scala/io/iohk/atala/pollux/anoncreds/AnoncredLib.scala
+++ b/pollux/anoncreds/src/main/scala/org/hyperledger/identus/pollux/anoncreds/AnoncredLib.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.anoncreds
+package org.hyperledger.identus.pollux.anoncreds
import scala.jdk.CollectionConverters.*
import scala.language.implicitConversions
diff --git a/pollux/lib/anoncreds/src/main/scala/io/iohk/atala/pollux/anoncreds/Models.scala b/pollux/anoncreds/src/main/scala/org/hyperledger/identus/pollux/anoncreds/Models.scala
similarity index 99%
rename from pollux/lib/anoncreds/src/main/scala/io/iohk/atala/pollux/anoncreds/Models.scala
rename to pollux/anoncreds/src/main/scala/org/hyperledger/identus/pollux/anoncreds/Models.scala
index 38f9d4014e..180aa19949 100644
--- a/pollux/lib/anoncreds/src/main/scala/io/iohk/atala/pollux/anoncreds/Models.scala
+++ b/pollux/anoncreds/src/main/scala/org/hyperledger/identus/pollux/anoncreds/Models.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.anoncreds
+package org.hyperledger.identus.pollux.anoncreds
import uniffi.anoncreds_wrapper.{
Nonce,
diff --git a/pollux/lib/anoncredsTest/src/test/scala/Uniffy.scala b/pollux/anoncredsTest/src/test/scala/Uniffy.scala
similarity index 100%
rename from pollux/lib/anoncredsTest/src/test/scala/Uniffy.scala
rename to pollux/anoncredsTest/src/test/scala/Uniffy.scala
diff --git a/pollux/lib/anoncredsTest/src/test/scala/io/iohk/atala/pollux/anoncreds/PoCNewLib.scala b/pollux/anoncredsTest/src/test/scala/org/hyperledger/identus/pollux/anoncreds/PoCNewLib.scala
similarity index 94%
rename from pollux/lib/anoncredsTest/src/test/scala/io/iohk/atala/pollux/anoncreds/PoCNewLib.scala
rename to pollux/anoncredsTest/src/test/scala/org/hyperledger/identus/pollux/anoncreds/PoCNewLib.scala
index fd75b61a4b..6c74014750 100644
--- a/pollux/lib/anoncredsTest/src/test/scala/io/iohk/atala/pollux/anoncreds/PoCNewLib.scala
+++ b/pollux/anoncredsTest/src/test/scala/org/hyperledger/identus/pollux/anoncreds/PoCNewLib.scala
@@ -1,10 +1,17 @@
-package io.iohk.atala.pollux.anoncreds
+package org.hyperledger.identus.pollux.anoncreds
import org.scalatest.flatspec.AnyFlatSpec
import scala.jdk.CollectionConverters.*
+import org.hyperledger.identus.pollux.anoncreds.{
+ AnoncredLinkSecretWithId,
+ AnoncredLinkSecret,
+ AnoncredPresentationRequest,
+ AnoncredLib,
+ AnoncredCredentialRequests
+}
-/** polluxAnoncredsTest/Test/testOnly io.iohk.atala.pollux.anoncreds.PoCNewLib
+/** polluxAnoncredsTest/Test/testOnly org.hyperledger.identus.pollux.anoncreds.PoCNewLib
*/
class PoCNewLib extends AnyFlatSpec {
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/CredentialFormat.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/CredentialFormat.scala
similarity index 86%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/CredentialFormat.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/CredentialFormat.scala
index 0208a9f848..94bf99ca62 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/CredentialFormat.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/CredentialFormat.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.model
+package org.hyperledger.identus.pollux.core.model
enum CredentialFormat:
case JWT extends CredentialFormat
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/CredentialOfferAttachment.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/CredentialOfferAttachment.scala
similarity index 68%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/CredentialOfferAttachment.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/CredentialOfferAttachment.scala
index 7a5d89faaf..101d528b8e 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/CredentialOfferAttachment.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/CredentialOfferAttachment.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.core.model
+package org.hyperledger.identus.pollux.core.model
import io.circe._
import io.circe.generic.semiauto._
-import io.iohk.atala.pollux.core.model.presentation.{Options, PresentationDefinition}
+import org.hyperledger.identus.pollux.core.model.presentation.{Options, PresentationDefinition}
final case class CredentialOfferAttachment(options: Options, presentation_definition: PresentationDefinition)
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/CredentialStatusList.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/CredentialStatusList.scala
similarity index 83%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/CredentialStatusList.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/CredentialStatusList.scala
index c59e02533e..748d6f0512 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/CredentialStatusList.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/CredentialStatusList.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.core.model
+package org.hyperledger.identus.pollux.core.model
-import io.iohk.atala.castor.core.model.did.CanonicalPrismDID
-import io.iohk.atala.pollux.vc.jwt.StatusPurpose
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.castor.core.model.did.CanonicalPrismDID
+import org.hyperledger.identus.pollux.vc.jwt.StatusPurpose
+import org.hyperledger.identus.shared.models.WalletId
import java.time.Instant
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/DidCommID.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/DidCommID.scala
similarity index 83%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/DidCommID.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/DidCommID.scala
index fdab0c041e..47fcced892 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/DidCommID.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/DidCommID.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.model
+package org.hyperledger.identus.pollux.core.model
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/IssueCredentialRecord.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/IssueCredentialRecord.scala
similarity index 93%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/IssueCredentialRecord.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/IssueCredentialRecord.scala
index c803f3421f..f9c6d1b5ad 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/IssueCredentialRecord.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/IssueCredentialRecord.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.core.model
+package org.hyperledger.identus.pollux.core.model
-import io.iohk.atala.castor.core.model.did.CanonicalPrismDID
-import io.iohk.atala.mercury.protocol.issuecredential.{
+import org.hyperledger.identus.castor.core.model.did.CanonicalPrismDID
+import org.hyperledger.identus.mercury.protocol.issuecredential.{
IssueCredential,
IssueCredentialIssuedFormat,
IssueCredentialOfferFormat,
@@ -9,8 +9,8 @@ import io.iohk.atala.mercury.protocol.issuecredential.{
OfferCredential,
RequestCredential
}
-import io.iohk.atala.pollux.anoncreds.AnoncredCredentialRequestMetadata
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.*
+import org.hyperledger.identus.pollux.anoncreds.AnoncredCredentialRequestMetadata
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.*
import java.time.Instant
import java.time.temporal.ChronoUnit
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/PresentationRecord.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/PresentationRecord.scala
similarity index 94%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/PresentationRecord.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/PresentationRecord.scala
index 7d0c5f2ef9..874c46348d 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/PresentationRecord.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/PresentationRecord.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.core.model
+package org.hyperledger.identus.pollux.core.model
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.presentproof.{Presentation, ProposePresentation, RequestPresentation}
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.presentproof.{Presentation, ProposePresentation, RequestPresentation}
import java.time.Instant
import java.time.temporal.ChronoUnit
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/VerificationPolicy.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/VerificationPolicy.scala
similarity index 95%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/VerificationPolicy.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/VerificationPolicy.scala
index fa4bf4693b..8b93e8140e 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/VerificationPolicy.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/VerificationPolicy.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.model
+package org.hyperledger.identus.pollux.core.model
import zio.{Clock, Random}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialRepositoryError.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialRepositoryError.scala
similarity index 94%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialRepositoryError.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialRepositoryError.scala
index 7d74c40b8a..4d83cdef1e 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialRepositoryError.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialRepositoryError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.model.error
+package org.hyperledger.identus.pollux.core.model.error
sealed trait CredentialRepositoryError extends Throwable
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialSchemaError.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialSchemaError.scala
similarity index 80%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialSchemaError.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialSchemaError.scala
index ac7cd1f1bf..e536fafac6 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialSchemaError.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialSchemaError.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.model.error
+package org.hyperledger.identus.pollux.core.model.error
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaError
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaError
sealed trait CredentialSchemaError {
def message: String
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialServiceError.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialServiceError.scala
similarity index 92%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialServiceError.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialServiceError.scala
index 0087db326b..567b3d96db 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialServiceError.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialServiceError.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.core.model.error
+package org.hyperledger.identus.pollux.core.model.error
-import io.iohk.atala.pollux.core.model.DidCommID
-import io.iohk.atala.pollux.vc.jwt.W3cCredentialPayload
+import org.hyperledger.identus.pollux.core.model.DidCommID
+import org.hyperledger.identus.pollux.vc.jwt.W3cCredentialPayload
import java.util.UUID
@@ -49,7 +49,7 @@ object CredentialServiceError {
final case class CreateCredentialPayloadFromRecordError(cause: Throwable) extends CredentialServiceError
final case class CredentialRequestValidationError(error: String) extends CredentialServiceError
final case class CredentialIdNotDefined(credential: W3cCredentialPayload) extends CredentialServiceError
- final case class CredentialSchemaError(cause: io.iohk.atala.pollux.core.model.error.CredentialSchemaError)
+ final case class CredentialSchemaError(cause: org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError)
extends CredentialServiceError
final case class UnsupportedVCClaimsValue(error: String) extends CredentialServiceError
final case class UnsupportedVCClaimsMediaType(media_type: String) extends CredentialServiceError
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialStatusListServiceError.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialStatusListServiceError.scala
similarity index 89%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialStatusListServiceError.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialStatusListServiceError.scala
index d0ffc298b9..acc655ff89 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/CredentialStatusListServiceError.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/CredentialStatusListServiceError.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.model.error
+package org.hyperledger.identus.pollux.core.model.error
-import io.iohk.atala.pollux.core.model.DidCommID
+import org.hyperledger.identus.pollux.core.model.DidCommID
import java.util.UUID
diff --git a/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/LinkSecretError.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/LinkSecretError.scala
new file mode 100644
index 0000000000..f3974e92c3
--- /dev/null
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/LinkSecretError.scala
@@ -0,0 +1,3 @@
+package org.hyperledger.identus.pollux.core.model.error
+
+final case class LinkSecretError(cause: Throwable)
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/PresentationError.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/PresentationError.scala
similarity index 93%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/PresentationError.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/PresentationError.scala
index 257116b21e..3957089e68 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/PresentationError.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/PresentationError.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.model.error
+package org.hyperledger.identus.pollux.core.model.error
-import io.iohk.atala.pollux.core.model.DidCommID
+import org.hyperledger.identus.pollux.core.model.DidCommID
sealed trait PresentationError
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/VerificationPolicyError.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/VerificationPolicyError.scala
similarity index 85%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/VerificationPolicyError.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/VerificationPolicyError.scala
index 295fdc606a..4eceb217e8 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/VerificationPolicyError.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/error/VerificationPolicyError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.model.error
+package org.hyperledger.identus.pollux.core.model.error
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/presentation/PresentationAttachment.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/presentation/PresentationAttachment.scala
similarity index 97%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/presentation/PresentationAttachment.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/presentation/PresentationAttachment.scala
index dd21733d6f..1086a6f15a 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/presentation/PresentationAttachment.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/presentation/PresentationAttachment.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.model.presentation
+package org.hyperledger.identus.pollux.core.model.presentation
import io.circe._
import io.circe.generic.semiauto._
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialDefinition.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/CredentialDefinition.scala
similarity index 95%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialDefinition.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/CredentialDefinition.scala
index 98823ed3f5..4fa741851a 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialDefinition.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/CredentialDefinition.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.core.model.schema
+package org.hyperledger.identus.pollux.core.model.schema
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError.*
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError.*
import zio.*
import zio.json.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchema.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/CredentialSchema.scala
similarity index 92%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchema.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/CredentialSchema.scala
index 8c12ad125a..eced17c030 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchema.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/CredentialSchema.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.pollux.core.model.schema
+package org.hyperledger.identus.pollux.core.model.schema
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError.*
-import io.iohk.atala.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
-import io.iohk.atala.pollux.core.model.schema.`type`.{
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError.*
+import org.hyperledger.identus.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
+import org.hyperledger.identus.pollux.core.model.schema.`type`.{
AnoncredSchemaType,
CredentialJsonSchemaType,
CredentialSchemaType
}
-import io.iohk.atala.pollux.core.model.schema.validator.{JsonSchemaValidator, JsonSchemaValidatorImpl}
-import io.iohk.atala.pollux.core.service.URIDereferencer
+import org.hyperledger.identus.pollux.core.model.schema.validator.{JsonSchemaValidator, JsonSchemaValidatorImpl}
+import org.hyperledger.identus.pollux.core.service.URIDereferencer
import zio.*
import zio.json.*
import zio.json.ast.Json
diff --git a/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/AnoncredSchemaType.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/AnoncredSchemaType.scala
new file mode 100644
index 0000000000..68b8b134c2
--- /dev/null
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/AnoncredSchemaType.scala
@@ -0,0 +1,27 @@
+package org.hyperledger.identus.pollux.core.model.schema.`type`
+
+import com.networknt.schema.*
+import org.hyperledger.identus.pollux.core.model.schema.Schema
+import org.hyperledger.identus.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
+import org.hyperledger.identus.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1.*
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaError
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaUtils
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaValidatorImpl
+import org.hyperledger.identus.pollux.core.model.schema.validator.SchemaSerDes
+import zio.*
+import zio.json.*
+
+object AnoncredSchemaType extends CredentialSchemaType {
+
+ val anondcredShemaBasedSerDes: SchemaSerDes[AnoncredSchemaSerDesV1] = AnoncredSchemaSerDesV1.schemaSerDes
+ val `type`: String = AnoncredSchemaSerDesV1.version
+
+ override def validate(schema: Schema): IO[JsonSchemaError, Unit] = {
+ for {
+ jsonSchemaSchema <- anondcredShemaBasedSerDes.initialiseJsonSchema
+ schemaValidator = JsonSchemaValidatorImpl(jsonSchemaSchema)
+ jsonSchemaNode <- JsonSchemaUtils.toJsonNode(schema)
+ _ <- schemaValidator.validate(jsonSchemaNode)
+ } yield ()
+ }
+}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialJsonSchemaSerDesV1.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialJsonSchemaSerDesV1.scala
similarity index 98%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialJsonSchemaSerDesV1.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialJsonSchemaSerDesV1.scala
index d256711bae..e0659beae9 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialJsonSchemaSerDesV1.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialJsonSchemaSerDesV1.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.model.schema.`type`
+package org.hyperledger.identus.pollux.core.model.schema.`type`
-import io.iohk.atala.pollux.core.model.schema.validator.SchemaSerDes
+import org.hyperledger.identus.pollux.core.model.schema.validator.SchemaSerDes
import zio.*
import zio.json.*
import zio.json.ast.Json
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialJsonSchemaType.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialJsonSchemaType.scala
similarity index 61%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialJsonSchemaType.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialJsonSchemaType.scala
index 0d13270551..dba94c421c 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialJsonSchemaType.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialJsonSchemaType.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.core.model.schema.`type`
+package org.hyperledger.identus.pollux.core.model.schema.`type`
-import io.iohk.atala.pollux.core.model.schema.Schema
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaError
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaValidatorImpl
+import org.hyperledger.identus.pollux.core.model.schema.Schema
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaError
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaValidatorImpl
import zio.*
import zio.json.*
diff --git a/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialSchemaType.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialSchemaType.scala
new file mode 100644
index 0000000000..a63a363be0
--- /dev/null
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/CredentialSchemaType.scala
@@ -0,0 +1,11 @@
+package org.hyperledger.identus.pollux.core.model.schema.`type`
+
+import org.hyperledger.identus.pollux.core.model.schema.Schema
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaError
+import zio.IO
+
+trait CredentialSchemaType {
+ val `type`: String
+
+ def validate(schema: Schema): IO[JsonSchemaError, Unit]
+}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/anoncred/AnoncredSchemaSerDesV1.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/anoncred/AnoncredSchemaSerDesV1.scala
similarity index 89%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/anoncred/AnoncredSchemaSerDesV1.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/anoncred/AnoncredSchemaSerDesV1.scala
index 580a2dab54..3890974da2 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/anoncred/AnoncredSchemaSerDesV1.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/type/anoncred/AnoncredSchemaSerDesV1.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.model.schema.`type`.anoncred
+package org.hyperledger.identus.pollux.core.model.schema.`type`.anoncred
-import io.iohk.atala.pollux.core.model.schema.validator.SchemaSerDes
+import org.hyperledger.identus.pollux.core.model.schema.validator.SchemaSerDes
import zio.*
import zio.json.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaError.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaError.scala
similarity index 86%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaError.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaError.scala
index 5fbff289a0..73993f1959 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaError.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.model.schema.validator
+package org.hyperledger.identus.pollux.core.model.schema.validator
sealed trait JsonSchemaError {
def error: String
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaUtils.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaUtils.scala
similarity index 92%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaUtils.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaUtils.scala
index bf1b687e1f..b19f4a5da8 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaUtils.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaUtils.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.core.model.schema.validator
+package org.hyperledger.identus.pollux.core.model.schema.validator
import com.fasterxml.jackson.databind.JsonNode
import com.fasterxml.jackson.databind.ObjectMapper
import com.networknt.schema.*
import com.networknt.schema.SpecVersion.VersionFlag
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaError.*
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaError.*
import zio.*
import zio.json.ast.Json
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaValidator.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaValidator.scala
similarity index 79%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaValidator.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaValidator.scala
index 39ac14cbe7..31e002323e 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaValidator.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaValidator.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.model.schema.validator
+package org.hyperledger.identus.pollux.core.model.schema.validator
import com.fasterxml.jackson.databind.JsonNode
import zio.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaValidatorImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaValidatorImpl.scala
similarity index 78%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaValidatorImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaValidatorImpl.scala
index ccc0e2d662..7ad58c51b1 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/JsonSchemaValidatorImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/JsonSchemaValidatorImpl.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.core.model.schema.validator
+package org.hyperledger.identus.pollux.core.model.schema.validator
import com.networknt.schema.*
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError.*
-import io.iohk.atala.pollux.core.model.schema.Schema
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError.*
+import org.hyperledger.identus.pollux.core.model.schema.Schema
import zio.*
case class JsonSchemaValidatorImpl(schemaValidator: JsonSchema) extends JsonSchemaValidator {
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/SchemaSerDes.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/SchemaSerDes.scala
similarity index 91%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/SchemaSerDes.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/SchemaSerDes.scala
index 365f8a0251..be7010e055 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/validator/SchemaSerDes.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/schema/validator/SchemaSerDes.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.core.model.schema.validator
+package org.hyperledger.identus.pollux.core.model.schema.validator
import com.networknt.schema.JsonSchema
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaError.*
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaError.*
import zio.json.*
import zio.json.ast.Json
import zio.json.ast.Json.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/secret/CredentialDefinitionSecret.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/secret/CredentialDefinitionSecret.scala
similarity index 80%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/secret/CredentialDefinitionSecret.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/secret/CredentialDefinitionSecret.scala
index 6fabba4e35..5697d331d0 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/secret/CredentialDefinitionSecret.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/model/secret/CredentialDefinitionSecret.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.model.secret
+package org.hyperledger.identus.pollux.core.model.secret
-import io.iohk.atala.agent.walletapi.storage.GenericSecret
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecret
import zio.json.ast.Json
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialDefinitionRepository.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialDefinitionRepository.scala
similarity index 71%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialDefinitionRepository.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialDefinitionRepository.scala
index 9948aea3f5..29e892fa5c 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialDefinitionRepository.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialDefinitionRepository.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition
-import io.iohk.atala.pollux.core.repository.Repository.SearchCapability
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition
+import org.hyperledger.identus.pollux.core.repository.Repository.SearchCapability
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{RIO, Task}
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialDefinitionRepositoryInMemory.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialDefinitionRepositoryInMemory.scala
similarity index 92%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialDefinitionRepositoryInMemory.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialDefinitionRepositoryInMemory.scala
index f3d4743f88..dd70e656c9 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialDefinitionRepositoryInMemory.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialDefinitionRepositoryInMemory.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.error.CredentialRepositoryError.*
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.error.CredentialRepositoryError.*
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialRepository.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepository.scala
similarity index 85%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialRepository.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepository.scala
index f919f33e46..659cc01aac 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialRepository.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepository.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.mercury.protocol.issuecredential.{IssueCredential, RequestCredential}
-import io.iohk.atala.pollux.anoncreds.AnoncredCredentialRequestMetadata
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.ProtocolState
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.mercury.protocol.issuecredential.{IssueCredential, RequestCredential}
+import org.hyperledger.identus.pollux.anoncreds.AnoncredCredentialRequestMetadata
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.ProtocolState
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
trait CredentialRepository {
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialRepositoryInMemory.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepositoryInMemory.scala
similarity index 95%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialRepositoryInMemory.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepositoryInMemory.scala
index a952b8b223..a407ba898e 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialRepositoryInMemory.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepositoryInMemory.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.mercury.protocol.issuecredential.{IssueCredential, RequestCredential}
-import io.iohk.atala.pollux.anoncreds.AnoncredCredentialRequestMetadata
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.ProtocolState
-import io.iohk.atala.pollux.core.model.error.CredentialRepositoryError.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.mercury.protocol.issuecredential.{IssueCredential, RequestCredential}
+import org.hyperledger.identus.pollux.anoncreds.AnoncredCredentialRequestMetadata
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.ProtocolState
+import org.hyperledger.identus.pollux.core.model.error.CredentialRepositoryError.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import java.time.Instant
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialSchemaRepository.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialSchemaRepository.scala
similarity index 65%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialSchemaRepository.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialSchemaRepository.scala
index 85315d0162..bcbbbc62cc 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialSchemaRepository.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialSchemaRepository.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema.*
-import io.iohk.atala.pollux.core.repository.Repository.SearchCapability
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema.*
+import org.hyperledger.identus.pollux.core.repository.Repository.SearchCapability
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{RIO, Task}
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialStatusListRepository.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialStatusListRepository.scala
similarity index 81%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialStatusListRepository.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialStatusListRepository.scala
index f6c3958797..66497fd5cd 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialStatusListRepository.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialStatusListRepository.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.vc.jwt.Issuer
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.vc.jwt.Issuer
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialStatusListRepositoryInMemory.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialStatusListRepositoryInMemory.scala
similarity index 94%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialStatusListRepositoryInMemory.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialStatusListRepositoryInMemory.scala
index cb4521dddb..7b0c95f5d6 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/CredentialStatusListRepositoryInMemory.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/CredentialStatusListRepositoryInMemory.scala
@@ -1,18 +1,18 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.pollux.core.model.CredentialStatusList
-import io.iohk.atala.pollux.vc.jwt.{Issuer, StatusPurpose, revocation}
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.pollux.core.model.CredentialStatusList
+import org.hyperledger.identus.pollux.vc.jwt.{Issuer, StatusPurpose, revocation}
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.vc.jwt.revocation.BitStringError.{
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.vc.jwt.revocation.BitStringError.{
DecodingError,
EncodingError,
IndexOutOfBounds,
InvalidSize
}
-import io.iohk.atala.castor.core.model.did.{CanonicalPrismDID, PrismDID}
-import io.iohk.atala.pollux.vc.jwt.revocation.{BitString, VCStatusList2021}
+import org.hyperledger.identus.castor.core.model.did.{CanonicalPrismDID, PrismDID}
+import org.hyperledger.identus.pollux.vc.jwt.revocation.{BitString, VCStatusList2021}
import java.time.Instant
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/PresentationRepository.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepository.scala
similarity index 87%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/PresentationRepository.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepository.scala
index 5f361ac2fa..2a04082ea4 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/PresentationRepository.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepository.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.mercury.protocol.presentproof.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.PresentationRecord.ProtocolState
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.mercury.protocol.presentproof.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.PresentationRecord.ProtocolState
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
trait PresentationRepository {
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/PresentationRepositoryInMemory.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepositoryInMemory.scala
similarity index 95%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/PresentationRepositoryInMemory.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepositoryInMemory.scala
index 76cb0f0154..f96a943002 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/PresentationRepositoryInMemory.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepositoryInMemory.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.mercury.protocol.presentproof.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.PresentationRecord.ProtocolState
-import io.iohk.atala.pollux.core.model.error.PresentationError.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.mercury.protocol.presentproof.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.PresentationRecord.ProtocolState
+import org.hyperledger.identus.pollux.core.model.error.PresentationError.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import java.time.Instant
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/VerificationPolicyRepository.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/VerificationPolicyRepository.scala
similarity index 82%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/VerificationPolicyRepository.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/VerificationPolicyRepository.scala
index 773e90d57e..cf8b9b0df8 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/VerificationPolicyRepository.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/VerificationPolicyRepository.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.pollux.core.model.VerificationPolicy
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.VerificationPolicy
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/repository.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/repository.scala
similarity index 77%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/repository.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/repository.scala
index 7b4ea2940f..5b8f422039 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/repository/repository.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/repository/repository.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.RIO
trait Repository[F[_], T]
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionService.scala
similarity index 83%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionService.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionService.scala
index d6933172b8..7d562f67bd 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionService.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionService.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{IO, ZIO}
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionServiceImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionServiceImpl.scala
similarity index 77%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionServiceImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionServiceImpl.scala
index 01ea444476..fd49b15378 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionServiceImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionServiceImpl.scala
@@ -1,19 +1,19 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.agent.walletapi.storage
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.pollux.anoncreds.{AnoncredLib, AnoncredSchemaDef}
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError.{SchemaError, URISyntaxError}
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition.{Filter, FilteredEntries}
-import io.iohk.atala.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaError
-import io.iohk.atala.pollux.core.model.secret.CredentialDefinitionSecret
-import io.iohk.atala.pollux.core.repository.CredentialDefinitionRepository
-import io.iohk.atala.pollux.core.repository.Repository.SearchQuery
-import io.iohk.atala.pollux.core.service.CredentialDefinitionService.Error.*
-import io.iohk.atala.pollux.core.service.serdes.{
+import org.hyperledger.identus.agent.walletapi.storage
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.pollux.anoncreds.{AnoncredLib, AnoncredSchemaDef}
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError.{SchemaError, URISyntaxError}
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition.{Filter, FilteredEntries}
+import org.hyperledger.identus.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaError
+import org.hyperledger.identus.pollux.core.model.secret.CredentialDefinitionSecret
+import org.hyperledger.identus.pollux.core.repository.CredentialDefinitionRepository
+import org.hyperledger.identus.pollux.core.repository.Repository.SearchQuery
+import org.hyperledger.identus.pollux.core.service.CredentialDefinitionService.Error.*
+import org.hyperledger.identus.pollux.core.service.serdes.{
PrivateCredentialDefinitionSchemaSerDesV1,
ProofKeyCredentialDefinitionSchemaSerDesV1,
PublicCredentialDefinitionSerDesV1
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialSchemaService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialSchemaService.scala
similarity index 83%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialSchemaService.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialSchemaService.scala
index d8ed4d6f75..7066f87bcf 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialSchemaService.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialSchemaService.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema.*
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema.*
import zio.{IO, ZIO}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import java.util.UUID
trait CredentialSchemaService {
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialSchemaServiceImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialSchemaServiceImpl.scala
similarity index 86%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialSchemaServiceImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialSchemaServiceImpl.scala
index 29b943f601..d99475344c 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialSchemaServiceImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialSchemaServiceImpl.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema.FilteredEntries
-import io.iohk.atala.pollux.core.repository.CredentialSchemaRepository
-import io.iohk.atala.pollux.core.repository.Repository.SearchQuery
-import io.iohk.atala.pollux.core.service.CredentialSchemaService.Error.*
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema.FilteredEntries
+import org.hyperledger.identus.pollux.core.repository.CredentialSchemaRepository
+import org.hyperledger.identus.pollux.core.repository.Repository.SearchQuery
+import org.hyperledger.identus.pollux.core.service.CredentialSchemaService.Error.*
import zio.ZIO.{fail, getOrFailWith, succeed}
import zio.{URLayer, ZLayer}
import zio.IO
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialService.scala
similarity index 90%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialService.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialService.scala
index 85e453ce08..bfa79f650f 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialService.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialService.scala
@@ -1,14 +1,19 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import io.circe.syntax.*
import io.circe.{Json, JsonObject}
-import io.iohk.atala.castor.core.model.did.CanonicalPrismDID
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.issuecredential.{Attribute, IssueCredential, OfferCredential, RequestCredential}
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.castor.core.model.did.CanonicalPrismDID
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.issuecredential.{
+ Attribute,
+ IssueCredential,
+ OfferCredential,
+ RequestCredential
+}
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{IO, ZIO}
import java.nio.charset.StandardCharsets
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceImpl.scala
similarity index 96%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceImpl.scala
index 9b4e5fe06e..c59868ffce 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceImpl.scala
@@ -1,34 +1,34 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import io.circe.Json
import io.circe.syntax.*
-import io.iohk.atala.agent.walletapi.model.{ManagedDIDState, PublicationState}
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.castor.core.model.did.{CanonicalPrismDID, PrismDID, VerificationRelationship}
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.mercury.model.*
-import io.iohk.atala.mercury.protocol.issuecredential.*
-import io.iohk.atala.pollux.*
-import io.iohk.atala.pollux.anoncreds.{
+import org.hyperledger.identus.agent.walletapi.model.{ManagedDIDState, PublicationState}
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.castor.core.model.did.{CanonicalPrismDID, PrismDID, VerificationRelationship}
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.mercury.model.*
+import org.hyperledger.identus.mercury.protocol.issuecredential.*
+import org.hyperledger.identus.pollux.*
+import org.hyperledger.identus.pollux.anoncreds.{
AnoncredCreateCredentialDefinition,
AnoncredCredential,
AnoncredCredentialOffer,
AnoncredLib
}
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.CredentialFormat.AnonCreds
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.ProtocolState.OfferReceived
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError.*
-import io.iohk.atala.pollux.core.model.presentation.*
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema
-import io.iohk.atala.pollux.core.model.secret.CredentialDefinitionSecret
-import io.iohk.atala.pollux.core.repository.{CredentialRepository, CredentialStatusListRepository}
-import io.iohk.atala.pollux.vc.jwt.{ES256KSigner, Issuer as JwtIssuer, *}
-import io.iohk.atala.shared.http.{DataUrlResolver, GenericUriResolver}
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.utils.aspects.CustomMetricsAspect
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.CredentialFormat.AnonCreds
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.ProtocolState.OfferReceived
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError.*
+import org.hyperledger.identus.pollux.core.model.presentation.*
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema
+import org.hyperledger.identus.pollux.core.model.secret.CredentialDefinitionSecret
+import org.hyperledger.identus.pollux.core.repository.{CredentialRepository, CredentialStatusListRepository}
+import org.hyperledger.identus.pollux.vc.jwt.{ES256KSigner, Issuer as JwtIssuer, *}
+import org.hyperledger.identus.shared.http.{DataUrlResolver, GenericUriResolver}
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.utils.aspects.CustomMetricsAspect
import zio.*
import zio.prelude.ZValidation
@@ -470,7 +470,7 @@ private class CredentialServiceImpl(
)
(privateKey, publicKey) = ecKeyPair
jwtIssuer = JwtIssuer(
- io.iohk.atala.pollux.vc.jwt.DID(jwtIssuerDID.toString),
+ org.hyperledger.identus.pollux.vc.jwt.DID(jwtIssuerDID.toString),
ES256KSigner(privateKey),
publicKey
)
@@ -1088,7 +1088,7 @@ private class CredentialServiceImpl(
issuanceDate = issuanceDate,
maybeExpirationDate = record.validityPeriod.map(sec => issuanceDate.plusSeconds(sec.toLong)),
maybeCredentialSchema =
- record.schemaUri.map(id => io.iohk.atala.pollux.vc.jwt.CredentialSchema(id, VC_JSON_SCHEMA_TYPE)),
+ record.schemaUri.map(id => org.hyperledger.identus.pollux.vc.jwt.CredentialSchema(id, VC_JSON_SCHEMA_TYPE)),
maybeCredentialStatus = Some(credentialStatus),
credentialSubject = claims.add("id", jwtPresentation.iss.asJson).asJson,
maybeRefreshService = None,
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceNotifier.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceNotifier.scala
similarity index 92%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceNotifier.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceNotifier.scala
index 504b82b5d1..b350435772 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialServiceNotifier.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceNotifier.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import io.circe.Json
-import io.iohk.atala.castor.core.model.did.CanonicalPrismDID
-import io.iohk.atala.event.notification.*
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.issuecredential.{IssueCredential, OfferCredential, RequestCredential}
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.pollux.core.model.{DidCommID, IssueCredentialRecord}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.castor.core.model.did.CanonicalPrismDID
+import org.hyperledger.identus.event.notification.*
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.issuecredential.{IssueCredential, OfferCredential, RequestCredential}
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.pollux.core.model.{DidCommID, IssueCredentialRecord}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{URLayer, ZIO, ZLayer, IO}
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialStatusListService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialStatusListService.scala
similarity index 67%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialStatusListService.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialStatusListService.scala
index e3b9930c9a..59c96f37bc 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialStatusListService.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialStatusListService.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.pollux.core.model.{CredentialStatusList, CredentialStatusListWithCreds, DidCommID}
-import io.iohk.atala.pollux.core.model.error.CredentialStatusListServiceError
+import org.hyperledger.identus.pollux.core.model.{CredentialStatusList, CredentialStatusListWithCreds, DidCommID}
+import org.hyperledger.identus.pollux.core.model.error.CredentialStatusListServiceError
import zio.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletAccessContext
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialStatusListServiceImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialStatusListServiceImpl.scala
similarity index 78%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialStatusListServiceImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialStatusListServiceImpl.scala
index f272a1784d..1b6e7c0b13 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/CredentialStatusListServiceImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/CredentialStatusListServiceImpl.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.pollux.core.model.{CredentialStatusList, CredentialStatusListWithCreds, DidCommID}
-import io.iohk.atala.pollux.core.repository.CredentialStatusListRepository
+import org.hyperledger.identus.pollux.core.model.{CredentialStatusList, CredentialStatusListWithCreds, DidCommID}
+import org.hyperledger.identus.pollux.core.repository.CredentialStatusListRepository
import zio.*
-import io.iohk.atala.pollux.core.model.error.CredentialStatusListServiceError
-import io.iohk.atala.pollux.core.model.error.CredentialStatusListServiceError.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.error.CredentialStatusListServiceError
+import org.hyperledger.identus.pollux.core.model.error.CredentialStatusListServiceError.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/HttpURIDereferencerImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/HttpURIDereferencerImpl.scala
similarity index 88%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/HttpURIDereferencerImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/HttpURIDereferencerImpl.scala
index 56057c9f7b..3e6afcd3e4 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/HttpURIDereferencerImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/HttpURIDereferencerImpl.scala
@@ -1,6 +1,10 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.pollux.core.service.URIDereferencerError.{ConnectionError, ResourceNotFound, UnexpectedError}
+import org.hyperledger.identus.pollux.core.service.URIDereferencerError.{
+ ConnectionError,
+ ResourceNotFound,
+ UnexpectedError
+}
import zio.*
import zio.http.*
import java.net.URI
diff --git a/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/LinkSecretService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/LinkSecretService.scala
new file mode 100644
index 0000000000..553078b39b
--- /dev/null
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/LinkSecretService.scala
@@ -0,0 +1,12 @@
+package org.hyperledger.identus.pollux.core.service
+
+import org.hyperledger.identus.pollux.anoncreds.AnoncredLinkSecretWithId
+import org.hyperledger.identus.pollux.core.model.error.LinkSecretError
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import zio.ZIO
+
+trait LinkSecretService {
+ type Result[T] = ZIO[WalletAccessContext, LinkSecretError, T]
+
+ def fetchOrCreate(): Result[AnoncredLinkSecretWithId]
+}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/LinkSecretServiceImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/LinkSecretServiceImpl.scala
similarity index 80%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/LinkSecretServiceImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/LinkSecretServiceImpl.scala
index 88e51199be..ced6cfdbf1 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/LinkSecretServiceImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/LinkSecretServiceImpl.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.agent.walletapi.storage.{GenericSecret, GenericSecretStorage}
-import io.iohk.atala.pollux.anoncreds.{AnoncredLinkSecret, AnoncredLinkSecretWithId}
-import io.iohk.atala.pollux.core.model.error.LinkSecretError
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.agent.walletapi.storage.{GenericSecret, GenericSecretStorage}
+import org.hyperledger.identus.pollux.anoncreds.{AnoncredLinkSecret, AnoncredLinkSecretWithId}
+import org.hyperledger.identus.pollux.core.model.error.LinkSecretError
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.json.ast.Json
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/MockCredentialService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/MockCredentialService.scala
similarity index 93%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/MockCredentialService.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/MockCredentialService.scala
index 75ba7a19f8..41012cbd55 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/MockCredentialService.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/MockCredentialService.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import io.circe.Json
-import io.iohk.atala.castor.core.model.did.CanonicalPrismDID
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.issuecredential.{IssueCredential, OfferCredential, RequestCredential}
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.pollux.core.model.{DidCommID, IssueCredentialRecord}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.castor.core.model.did.CanonicalPrismDID
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.issuecredential.{IssueCredential, OfferCredential, RequestCredential}
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.pollux.core.model.{DidCommID, IssueCredentialRecord}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.mock.{Mock, Proxy}
import zio.{IO, URLayer, ZIO, ZLayer, mock}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/MockPresentationService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/MockPresentationService.scala
similarity index 91%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/MockPresentationService.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/MockPresentationService.scala
index 3faba1a4c9..7093eaed45 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/MockPresentationService.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/MockPresentationService.scala
@@ -1,14 +1,19 @@
-package io.iohk.atala.pollux.core.service
-
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.presentproof.{Presentation, ProofType, ProposePresentation, RequestPresentation}
-import io.iohk.atala.pollux.anoncreds.AnoncredPresentation
-import io.iohk.atala.pollux.core.model.error.PresentationError
-import io.iohk.atala.pollux.core.model.presentation.Options
-import io.iohk.atala.pollux.core.model.{DidCommID, PresentationRecord}
-import io.iohk.atala.pollux.core.service.serdes.{AnoncredCredentialProofsV1, AnoncredPresentationRequestV1}
-import io.iohk.atala.pollux.vc.jwt.{Issuer, PresentationPayload, W3cCredentialPayload}
-import io.iohk.atala.shared.models.WalletAccessContext
+package org.hyperledger.identus.pollux.core.service
+
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.presentproof.{
+ Presentation,
+ ProofType,
+ ProposePresentation,
+ RequestPresentation
+}
+import org.hyperledger.identus.pollux.anoncreds.AnoncredPresentation
+import org.hyperledger.identus.pollux.core.model.error.PresentationError
+import org.hyperledger.identus.pollux.core.model.presentation.Options
+import org.hyperledger.identus.pollux.core.model.{DidCommID, PresentationRecord}
+import org.hyperledger.identus.pollux.core.service.serdes.{AnoncredCredentialProofsV1, AnoncredPresentationRequestV1}
+import org.hyperledger.identus.pollux.vc.jwt.{Issuer, PresentationPayload, W3cCredentialPayload}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.mock.{Mock, Proxy}
import zio.{IO, URLayer, ZIO, ZLayer, mock}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/PresentationService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/PresentationService.scala
similarity index 87%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/PresentationService.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/PresentationService.scala
index b54df6784c..621f38f570 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/PresentationService.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/PresentationService.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.pollux.core.service
-
-import io.iohk.atala.mercury.model.*
-import io.iohk.atala.mercury.protocol.presentproof.*
-import io.iohk.atala.pollux.anoncreds.AnoncredPresentation
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.error.PresentationError
-import io.iohk.atala.pollux.core.model.presentation.*
-import io.iohk.atala.pollux.core.service.serdes.{AnoncredCredentialProofsV1, AnoncredPresentationRequestV1}
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.shared.models.WalletAccessContext
+package org.hyperledger.identus.pollux.core.service
+
+import org.hyperledger.identus.mercury.model.*
+import org.hyperledger.identus.mercury.protocol.presentproof.*
+import org.hyperledger.identus.pollux.anoncreds.AnoncredPresentation
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.error.PresentationError
+import org.hyperledger.identus.pollux.core.model.presentation.*
+import org.hyperledger.identus.pollux.core.service.serdes.{AnoncredCredentialProofsV1, AnoncredPresentationRequestV1}
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.time.Instant
@@ -24,7 +24,7 @@ trait PresentationService {
thid: DidCommID,
connectionId: Option[String],
proofTypes: Seq[ProofType],
- options: Option[io.iohk.atala.pollux.core.model.presentation.Options],
+ options: Option[org.hyperledger.identus.pollux.core.model.presentation.Options],
): ZIO[WalletAccessContext, PresentationError, PresentationRecord]
def createAnoncredPresentationRecord(
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/PresentationServiceImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceImpl.scala
similarity index 96%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/PresentationServiceImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceImpl.scala
index a355f9d847..0670081021 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/PresentationServiceImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceImpl.scala
@@ -1,24 +1,24 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import cats.*
import cats.implicits.*
import io.circe.*
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.mercury.model.*
-import io.iohk.atala.mercury.protocol.issuecredential.IssueCredentialIssuedFormat
-import io.iohk.atala.mercury.protocol.presentproof.*
-import io.iohk.atala.pollux.anoncreds.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.error.PresentationError
-import io.iohk.atala.pollux.core.model.error.PresentationError.*
-import io.iohk.atala.pollux.core.model.presentation.*
-import io.iohk.atala.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
-import io.iohk.atala.pollux.core.repository.{CredentialRepository, PresentationRepository}
-import io.iohk.atala.pollux.core.service.serdes.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.utils.aspects.CustomMetricsAspect
+import org.hyperledger.identus.mercury.model.*
+import org.hyperledger.identus.mercury.protocol.issuecredential.IssueCredentialIssuedFormat
+import org.hyperledger.identus.mercury.protocol.presentproof.*
+import org.hyperledger.identus.pollux.anoncreds.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.error.PresentationError
+import org.hyperledger.identus.pollux.core.model.error.PresentationError.*
+import org.hyperledger.identus.pollux.core.model.presentation.*
+import org.hyperledger.identus.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
+import org.hyperledger.identus.pollux.core.repository.{CredentialRepository, PresentationRepository}
+import org.hyperledger.identus.pollux.core.service.serdes.*
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.utils.aspects.CustomMetricsAspect
import zio.*
import java.net.URI
@@ -230,7 +230,7 @@ private class PresentationServiceImpl(
thid: DidCommID,
connectionId: Option[String],
proofTypes: Seq[ProofType],
- maybeOptions: Option[io.iohk.atala.pollux.core.model.presentation.Options]
+ maybeOptions: Option[org.hyperledger.identus.pollux.core.model.presentation.Options]
): ZIO[WalletAccessContext, PresentationError, PresentationRecord] = {
createPresentationRecord(
pairwiseVerifierDID,
@@ -409,7 +409,7 @@ private class PresentationServiceImpl(
Seq[JwtVerifiableCredentialPayload]
] =
issuedCredentials.map { signedCredential =>
- decode[io.iohk.atala.mercury.model.Base64](signedCredential)
+ decode[org.hyperledger.identus.mercury.model.Base64](signedCredential)
.flatMap(x => Right(new String(java.util.Base64.getDecoder.decode(x.base64))))
.flatMap(x => Right(JwtVerifiableCredentialPayload(JWT(x))))
.left
@@ -417,12 +417,12 @@ private class PresentationServiceImpl(
}.sequence
val maybePresentationOptions
- : Either[PresentationError, Option[io.iohk.atala.pollux.core.model.presentation.Options]] =
+ : Either[PresentationError, Option[org.hyperledger.identus.pollux.core.model.presentation.Options]] =
requestPresentation.attachments.headOption
.map(attachment =>
- decode[io.iohk.atala.mercury.model.JsonData](attachment.data.asJson.noSpaces)
+ decode[org.hyperledger.identus.mercury.model.JsonData](attachment.data.asJson.noSpaces)
.flatMap(data =>
- io.iohk.atala.pollux.core.model.presentation.PresentationAttachment.given_Decoder_PresentationAttachment
+ org.hyperledger.identus.pollux.core.model.presentation.PresentationAttachment.given_Decoder_PresentationAttachment
.decodeJson(data.json.asJson)
.map(_.options)
.leftMap(err =>
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/PresentationServiceNotifier.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceNotifier.scala
similarity index 90%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/PresentationServiceNotifier.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceNotifier.scala
index 0739b63067..662dec0066 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/PresentationServiceNotifier.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceNotifier.scala
@@ -1,15 +1,20 @@
-package io.iohk.atala.pollux.core.service
-
-import io.iohk.atala.event.notification.{Event, EventNotificationService}
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.presentproof.{Presentation, ProofType, ProposePresentation, RequestPresentation}
-import io.iohk.atala.pollux.anoncreds.AnoncredPresentation
-import io.iohk.atala.pollux.core.model.error.PresentationError
-import io.iohk.atala.pollux.core.model.presentation.Options
-import io.iohk.atala.pollux.core.model.{DidCommID, PresentationRecord}
-import io.iohk.atala.pollux.core.service.serdes.{AnoncredCredentialProofsV1, AnoncredPresentationRequestV1}
-import io.iohk.atala.pollux.vc.jwt.{Issuer, PresentationPayload, W3cCredentialPayload}
-import io.iohk.atala.shared.models.WalletAccessContext
+package org.hyperledger.identus.pollux.core.service
+
+import org.hyperledger.identus.event.notification.{Event, EventNotificationService}
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.presentproof.{
+ Presentation,
+ ProofType,
+ ProposePresentation,
+ RequestPresentation
+}
+import org.hyperledger.identus.pollux.anoncreds.AnoncredPresentation
+import org.hyperledger.identus.pollux.core.model.error.PresentationError
+import org.hyperledger.identus.pollux.core.model.presentation.Options
+import org.hyperledger.identus.pollux.core.model.{DidCommID, PresentationRecord}
+import org.hyperledger.identus.pollux.core.service.serdes.{AnoncredCredentialProofsV1, AnoncredPresentationRequestV1}
+import org.hyperledger.identus.pollux.vc.jwt.{Issuer, PresentationPayload, W3cCredentialPayload}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{IO, URLayer, ZIO, ZLayer}
import java.time.Instant
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/ResourceURIDereferencerImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/ResourceURIDereferencerImpl.scala
similarity index 88%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/ResourceURIDereferencerImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/ResourceURIDereferencerImpl.scala
index 9acace6865..7b79ed8f2c 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/ResourceURIDereferencerImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/ResourceURIDereferencerImpl.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.pollux.core.service.URIDereferencerError.ResourceNotFound
+import org.hyperledger.identus.pollux.core.service.URIDereferencerError.ResourceNotFound
import zio.*
import java.net.URI
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/URIDereferencer.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/URIDereferencer.scala
similarity index 90%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/URIDereferencer.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/URIDereferencer.scala
index a53a119f51..7dab42afb9 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/URIDereferencer.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/URIDereferencer.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import zio.IO
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/VerificationPolicyService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/VerificationPolicyService.scala
similarity index 77%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/VerificationPolicyService.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/VerificationPolicyService.scala
index 63c0c5c0bc..20da0f5ad6 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/VerificationPolicyService.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/VerificationPolicyService.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.pollux.core.model.error.VerificationPolicyError
-import io.iohk.atala.pollux.core.model.{VerificationPolicy, VerificationPolicyConstraint}
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.error.VerificationPolicyError
+import org.hyperledger.identus.pollux.core.model.{VerificationPolicy, VerificationPolicyConstraint}
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/VerificationPolicyServiceImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/VerificationPolicyServiceImpl.scala
similarity index 85%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/VerificationPolicyServiceImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/VerificationPolicyServiceImpl.scala
index 96dd1bb20a..70ddce207d 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/VerificationPolicyServiceImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/VerificationPolicyServiceImpl.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.pollux.core.model.error.VerificationPolicyError
-import io.iohk.atala.pollux.core.model.{VerificationPolicy, VerificationPolicyConstraint}
-import io.iohk.atala.pollux.core.repository.VerificationPolicyRepository
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.error.VerificationPolicyError
+import org.hyperledger.identus.pollux.core.model.{VerificationPolicy, VerificationPolicyConstraint}
+import org.hyperledger.identus.pollux.core.repository.VerificationPolicyRepository
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import java.util.UUID
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredCredentialProofsV1.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredCredentialProofsV1.scala
similarity index 93%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredCredentialProofsV1.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredCredentialProofsV1.scala
index fc8dfdd3ef..a28807b781 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredCredentialProofsV1.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredCredentialProofsV1.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.service.serdes
+package org.hyperledger.identus.pollux.core.service.serdes
-import io.iohk.atala.pollux.core.model.schema.validator.SchemaSerDes
+import org.hyperledger.identus.pollux.core.model.schema.validator.SchemaSerDes
import zio.*
import zio.json.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationRequestV1.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationRequestV1.scala
similarity index 96%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationRequestV1.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationRequestV1.scala
index e16fe79fff..18edcfe9e0 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationRequestV1.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationRequestV1.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.service.serdes
+package org.hyperledger.identus.pollux.core.service.serdes
-import io.iohk.atala.pollux.core.model.schema.validator.SchemaSerDes
+import org.hyperledger.identus.pollux.core.model.schema.validator.SchemaSerDes
import zio.*
import zio.json.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationV1.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationV1.scala
similarity index 99%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationV1.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationV1.scala
index f773f8311a..ccca4fa58c 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationV1.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationV1.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.service.serdes
+package org.hyperledger.identus.pollux.core.service.serdes
-import io.iohk.atala.pollux.core.model.schema.validator.SchemaSerDes
+import org.hyperledger.identus.pollux.core.model.schema.validator.SchemaSerDes
import zio.*
import zio.json.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/PrivateCredentialDefinitionSchemaSerDesV1.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/PrivateCredentialDefinitionSchemaSerDesV1.scala
similarity index 95%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/PrivateCredentialDefinitionSchemaSerDesV1.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/PrivateCredentialDefinitionSchemaSerDesV1.scala
index 6f7cadea72..5bea91b7f2 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/PrivateCredentialDefinitionSchemaSerDesV1.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/PrivateCredentialDefinitionSchemaSerDesV1.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.service.serdes
+package org.hyperledger.identus.pollux.core.service.serdes
-import io.iohk.atala.pollux.core.model.schema.validator.SchemaSerDes
+import org.hyperledger.identus.pollux.core.model.schema.validator.SchemaSerDes
import zio.*
import zio.json.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/ProofKeyCredentialDefinitionSchemaSerDesV1.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/ProofKeyCredentialDefinitionSchemaSerDesV1.scala
similarity index 90%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/ProofKeyCredentialDefinitionSchemaSerDesV1.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/ProofKeyCredentialDefinitionSchemaSerDesV1.scala
index cf840d3f54..ee15cf065e 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/ProofKeyCredentialDefinitionSchemaSerDesV1.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/ProofKeyCredentialDefinitionSchemaSerDesV1.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.service.serdes
+package org.hyperledger.identus.pollux.core.service.serdes
-import io.iohk.atala.pollux.core.model.schema.validator.SchemaSerDes
+import org.hyperledger.identus.pollux.core.model.schema.validator.SchemaSerDes
import zio.*
import zio.json.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesV1.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesV1.scala
similarity index 97%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesV1.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesV1.scala
index 98f0055459..af6e84ae26 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesV1.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesV1.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.service.serdes
+package org.hyperledger.identus.pollux.core.service.serdes
-import io.iohk.atala.pollux.core.model.schema.validator.SchemaSerDes
+import org.hyperledger.identus.pollux.core.model.schema.validator.SchemaSerDes
import zio.*
import zio.json.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerification.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerification.scala
similarity index 92%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerification.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerification.scala
index 670849bd89..187c73eba8 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerification.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerification.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.service.verification
+package org.hyperledger.identus.pollux.core.service.verification
import java.time.OffsetDateTime
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationService.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationService.scala
similarity index 85%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationService.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationService.scala
index 915bd6e10b..272a4c5fbd 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationService.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationService.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.service.verification
+package org.hyperledger.identus.pollux.core.service.verification
import zio.*
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceError.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceError.scala
similarity index 74%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceError.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceError.scala
index 500fdcb052..17a8d99f7a 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceError.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.service.verification
+package org.hyperledger.identus.pollux.core.service.verification
sealed trait VcVerificationServiceError {
def error: String
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImpl.scala b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceImpl.scala
similarity index 96%
rename from pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImpl.scala
rename to pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceImpl.scala
index 3a3665f9ab..f32099b66b 100644
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImpl.scala
+++ b/pollux/core/src/main/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceImpl.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.core.service.verification
+package org.hyperledger.identus.pollux.core.service.verification
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema
-import io.iohk.atala.pollux.core.service.URIDereferencer
-import io.iohk.atala.pollux.vc.jwt.{DidResolver, JWT, JWTVerification, JwtCredential}
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema
+import org.hyperledger.identus.pollux.core.service.URIDereferencer
+import org.hyperledger.identus.pollux.vc.jwt.{DidResolver, JWT, JWTVerification, JwtCredential}
import zio.{IO, *}
import java.time.OffsetDateTime
diff --git a/pollux/lib/core/src/test/resources/anoncred-presentation-schema-example.json b/pollux/core/src/test/resources/anoncred-presentation-schema-example.json
similarity index 100%
rename from pollux/lib/core/src/test/resources/anoncred-presentation-schema-example.json
rename to pollux/core/src/test/resources/anoncred-presentation-schema-example.json
diff --git a/pollux/lib/core/src/test/resources/anoncred-schema-example.json b/pollux/core/src/test/resources/anoncred-schema-example.json
similarity index 100%
rename from pollux/lib/core/src/test/resources/anoncred-schema-example.json
rename to pollux/core/src/test/resources/anoncred-schema-example.json
diff --git a/pollux/lib/core/src/test/resources/logback.xml b/pollux/core/src/test/resources/logback.xml
similarity index 100%
rename from pollux/lib/core/src/test/resources/logback.xml
rename to pollux/core/src/test/resources/logback.xml
diff --git a/prism-agent/service/server/src/test/resources/vc-schema-example.json b/pollux/core/src/test/resources/vc-schema-example.json
similarity index 100%
rename from prism-agent/service/server/src/test/resources/vc-schema-example.json
rename to pollux/core/src/test/resources/vc-schema-example.json
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/model/presentation/PresentationAttachmentSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/model/presentation/PresentationAttachmentSpec.scala
similarity index 98%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/model/presentation/PresentationAttachmentSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/model/presentation/PresentationAttachmentSpec.scala
index 56b973c376..b7532faa79 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/model/presentation/PresentationAttachmentSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/model/presentation/PresentationAttachmentSpec.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.model.presentation
+package org.hyperledger.identus.pollux.core.model.presentation
import io.circe.Json
import io.circe.parser.*
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/model/schema/AnoncredSchemaTypeSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/model/schema/AnoncredSchemaTypeSpec.scala
similarity index 95%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/model/schema/AnoncredSchemaTypeSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/model/schema/AnoncredSchemaTypeSpec.scala
index 3fe70a7f31..6668608db2 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/model/schema/AnoncredSchemaTypeSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/model/schema/AnoncredSchemaTypeSpec.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.core.model.schema
+package org.hyperledger.identus.pollux.core.model.schema
-import io.iohk.atala.pollux.core.model.schema.`type`.AnoncredSchemaType
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaError
+import org.hyperledger.identus.pollux.core.model.schema.`type`.AnoncredSchemaType
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaError
import zio.*
import zio.json.*
import zio.json.ast.Json
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchemaSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/model/schema/CredentialSchemaSpec.scala
similarity index 94%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchemaSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/model/schema/CredentialSchemaSpec.scala
index 52eecfc3ad..91875493ae 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/model/schema/CredentialSchemaSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/model/schema/CredentialSchemaSpec.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.pollux.core.model.schema
+package org.hyperledger.identus.pollux.core.model.schema
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError
-import io.iohk.atala.pollux.core.model.error.CredentialSchemaError.SchemaError
-import io.iohk.atala.pollux.core.model.schema.AnoncredSchemaTypeSpec.test
-import io.iohk.atala.pollux.core.model.schema.`type`.AnoncredSchemaType
-import io.iohk.atala.pollux.core.model.schema.`type`.CredentialJsonSchemaType
-import io.iohk.atala.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaError.JsonValidationErrors
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError
+import org.hyperledger.identus.pollux.core.model.error.CredentialSchemaError.SchemaError
+import org.hyperledger.identus.pollux.core.model.schema.AnoncredSchemaTypeSpec.test
+import org.hyperledger.identus.pollux.core.model.schema.`type`.AnoncredSchemaType
+import org.hyperledger.identus.pollux.core.model.schema.`type`.CredentialJsonSchemaType
+import org.hyperledger.identus.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
+import org.hyperledger.identus.pollux.core.model.schema.validator.JsonSchemaError.JsonValidationErrors
import zio.Scope
import zio.json.*
import zio.json.ast.Json
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/CredentialRepositoryInMemorySpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepositoryInMemorySpec.scala
similarity index 70%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/CredentialRepositoryInMemorySpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepositoryInMemorySpec.scala
index 159707de7f..4693dbdb87 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/CredentialRepositoryInMemorySpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepositoryInMemorySpec.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
import zio._
import zio.test._
-/** core/testOnly io.iohk.atala.pollux.core.repository.CredentialRepositoryInMemorySpec */
+/** core/testOnly org.hyperledger.identus.pollux.core.repository.CredentialRepositoryInMemorySpec */
object CredentialRepositoryInMemorySpec extends ZIOSpecDefault {
override def spec: Spec[TestEnvironment with Scope, Any] =
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/CredentialRepositorySpecSuite.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepositorySpecSuite.scala
similarity index 97%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/CredentialRepositorySpecSuite.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepositorySpecSuite.scala
index 39e3f65995..4935966a79 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/CredentialRepositorySpecSuite.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/CredentialRepositorySpecSuite.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.issuecredential.{IssueCredential, RequestCredential}
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.*
-import io.iohk.atala.pollux.core.model.error.CredentialRepositoryError.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.issuecredential.{IssueCredential, RequestCredential}
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.*
+import org.hyperledger.identus.pollux.core.model.error.CredentialRepositoryError.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.test.*
import zio.test.Assertion.*
import zio.{Exit, ZIO, ZLayer}
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/PresentationRepositoryInMemorySpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepositoryInMemorySpec.scala
similarity index 87%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/PresentationRepositoryInMemorySpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepositoryInMemorySpec.scala
index b18b570dc3..3cf53f45e1 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/PresentationRepositoryInMemorySpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepositoryInMemorySpec.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
import zio._
import zio.test._
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/PresentationRepositorySpecSuite.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepositorySpecSuite.scala
similarity index 97%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/PresentationRepositorySpecSuite.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepositorySpecSuite.scala
index b396ee05f5..5b51bf6c10 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/repository/PresentationRepositorySpecSuite.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/repository/PresentationRepositorySpecSuite.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.core.repository
+package org.hyperledger.identus.pollux.core.repository
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.presentproof.{Presentation, ProposePresentation, RequestPresentation}
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.PresentationRecord.*
-import io.iohk.atala.pollux.core.service.serdes.{AnoncredCredentialProofV1, AnoncredCredentialProofsV1}
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.presentproof.{Presentation, ProposePresentation, RequestPresentation}
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.PresentationRecord.*
+import org.hyperledger.identus.pollux.core.service.serdes.{AnoncredCredentialProofV1, AnoncredCredentialProofsV1}
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.test.*
import zio.test.Assertion.*
import zio.{ZIO, ZLayer}
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionServiceImplSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionServiceImplSpec.scala
similarity index 96%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionServiceImplSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionServiceImplSpec.scala
index 6ed020b520..49f582b547 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionServiceImplSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionServiceImplSpec.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import zio.*
import zio.test.*
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionServiceSpecHelper.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionServiceSpecHelper.scala
similarity index 74%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionServiceSpecHelper.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionServiceSpecHelper.scala
index 723007a49f..c952ae38c1 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialDefinitionServiceSpecHelper.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialDefinitionServiceSpecHelper.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.agent.walletapi.memory.GenericSecretStorageInMemory
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition
-import io.iohk.atala.pollux.core.repository.CredentialDefinitionRepositoryInMemory
-import io.iohk.atala.shared.models.WalletId.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.agent.walletapi.memory.GenericSecretStorageInMemory
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition
+import org.hyperledger.identus.pollux.core.repository.CredentialDefinitionRepositoryInMemory
+import org.hyperledger.identus.shared.models.WalletId.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import java.time.OffsetDateTime
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialServiceImplSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceImplSpec.scala
similarity index 96%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialServiceImplSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceImplSpec.scala
index 94840909fb..6e41874de8 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialServiceImplSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceImplSpec.scala
@@ -1,21 +1,20 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import io.circe.Json
import io.circe.syntax.*
-import io.iohk.atala.agent.walletapi.service.MockManagedDIDService
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.castor.core.model.did.VerificationRelationship.AssertionMethod
-import io.iohk.atala.castor.core.service.MockDIDService
-import io.iohk.atala.mercury.model
-import io.iohk.atala.mercury.model.*
-import io.iohk.atala.mercury.protocol.issuecredential.*
-import io.iohk.atala.pollux.anoncreds.AnoncredCredential
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.{ProtocolState, Role}
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError.*
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.agent.walletapi.service.MockManagedDIDService
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship.AssertionMethod
+import org.hyperledger.identus.castor.core.service.MockDIDService
+import org.hyperledger.identus.mercury.model.{Base64 => MyBase64, *}
+import org.hyperledger.identus.mercury.protocol.issuecredential.*
+import org.hyperledger.identus.pollux.anoncreds.AnoncredCredential
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.{ProtocolState, Role}
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError.*
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import zio.mock.MockSpecDefault
import zio.test.*
@@ -603,7 +602,7 @@ object CredentialServiceImplSpec extends MockSpecDefault with CredentialServiceS
assertTrue(record.issueCredentialData.isDefined) &&
assertTrue(record.issueCredentialData.get.attachments.nonEmpty) &&
assertTrue(record.issueCredentialData.get.attachments.head.data match
- case model.Base64(value) =>
+ case MyBase64(value) =>
val ba = new String(Base64.getUrlDecoder.decode(value))
AnoncredCredential(ba).credDefId == credDefId
case _ => false
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialServiceNotifierSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceNotifierSpec.scala
similarity index 92%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialServiceNotifierSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceNotifierSpec.scala
index 4bbba5c2b0..db8e8a3c77 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialServiceNotifierSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceNotifierSpec.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.event.notification.{EventNotificationService, EventNotificationServiceImpl}
-import io.iohk.atala.mercury.protocol.issuecredential.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.ProtocolState
-import io.iohk.atala.pollux.core.model.error.CredentialServiceError
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.event.notification.{EventNotificationService, EventNotificationServiceImpl}
+import org.hyperledger.identus.mercury.protocol.issuecredential.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.ProtocolState
+import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import zio.mock.{Expectation, MockSpecDefault}
import zio.test.*
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialServiceSpecHelper.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceSpecHelper.scala
similarity index 86%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialServiceSpecHelper.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceSpecHelper.scala
index 51921eb8e0..722376ebb8 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/CredentialServiceSpecHelper.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/CredentialServiceSpecHelper.scala
@@ -1,22 +1,22 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import io.circe.Json
-import io.iohk.atala.agent.walletapi.memory.GenericSecretStorageInMemory
-import io.iohk.atala.agent.walletapi.service.ManagedDIDService
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.castor.core.service.DIDService
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, DidId}
-import io.iohk.atala.mercury.protocol.issuecredential.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.presentation.{ClaimFormat, Ldp, Options, PresentationDefinition}
-import io.iohk.atala.pollux.core.repository.{
+import org.hyperledger.identus.agent.walletapi.memory.GenericSecretStorageInMemory
+import org.hyperledger.identus.agent.walletapi.service.ManagedDIDService
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.castor.core.model.did.PrismDID
+import org.hyperledger.identus.castor.core.service.DIDService
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, DidId}
+import org.hyperledger.identus.mercury.protocol.issuecredential.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.presentation.{ClaimFormat, Ldp, Options, PresentationDefinition}
+import org.hyperledger.identus.pollux.core.repository.{
CredentialDefinitionRepositoryInMemory,
CredentialRepositoryInMemory,
CredentialStatusListRepositoryInMemory
}
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import java.util.UUID
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/LinkSecretServiceImplSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/LinkSecretServiceImplSpec.scala
similarity index 74%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/LinkSecretServiceImplSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/LinkSecretServiceImplSpec.scala
index c65219bc37..49b4fa59fe 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/LinkSecretServiceImplSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/LinkSecretServiceImplSpec.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
-import io.iohk.atala.agent.walletapi.memory.GenericSecretStorageInMemory
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.pollux.anoncreds.AnoncredLinkSecret
-import io.iohk.atala.shared.models.WalletId.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.agent.walletapi.memory.GenericSecretStorageInMemory
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.pollux.anoncreds.AnoncredLinkSecret
+import org.hyperledger.identus.shared.models.WalletId.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import zio.test.*
import zio.test.TestAspect.*
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/PresentationServiceNotifierSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceNotifierSpec.scala
similarity index 92%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/PresentationServiceNotifierSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceNotifierSpec.scala
index f08aa46f16..adc49fca4c 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/PresentationServiceNotifierSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceNotifierSpec.scala
@@ -1,17 +1,21 @@
-package io.iohk.atala.pollux.core.service
-
-import io.iohk.atala.event.notification.{EventNotificationService, EventNotificationServiceImpl}
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.mercury.protocol.presentproof.{PresentCredentialRequestFormat, Presentation, RequestPresentation}
-import io.iohk.atala.pollux.core.model.PresentationRecord.ProtocolState
-import io.iohk.atala.pollux.core.model.{CredentialFormat, DidCommID, PresentationRecord}
+package org.hyperledger.identus.pollux.core.service
+
+import org.hyperledger.identus.event.notification.{EventNotificationService, EventNotificationServiceImpl}
+import org.hyperledger.identus.mercury.model.DidId
+import org.hyperledger.identus.mercury.protocol.presentproof.{
+ PresentCredentialRequestFormat,
+ Presentation,
+ RequestPresentation
+}
+import org.hyperledger.identus.pollux.core.model.PresentationRecord.ProtocolState
+import org.hyperledger.identus.pollux.core.model.{CredentialFormat, DidCommID, PresentationRecord}
import zio.mock.Expectation
import zio.test.{Assertion, Spec, TestEnvironment, ZIOSpecDefault, assertTrue}
import zio.{Scope, ZIO, ZLayer}
import java.time.Instant
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
object PresentationServiceNotifierSpec extends ZIOSpecDefault with PresentationServiceSpecHelper {
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/PresentationServiceSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceSpec.scala
similarity index 96%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/PresentationServiceSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceSpec.scala
index abe9b32a1a..b647cfd993 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/PresentationServiceSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceSpec.scala
@@ -1,29 +1,29 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import io.circe.parser.decode
import io.circe.syntax.*
-import io.iohk.atala.agent.walletapi.storage.GenericSecretStorage
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, Base64, DidId}
-import io.iohk.atala.mercury.protocol.issuecredential.{IssueCredential, IssueCredentialIssuedFormat}
-import io.iohk.atala.mercury.protocol.presentproof.*
-import io.iohk.atala.pollux.anoncreds.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.IssueCredentialRecord.*
-import io.iohk.atala.pollux.core.model.PresentationRecord.*
-import io.iohk.atala.pollux.core.model.error.PresentationError
-import io.iohk.atala.pollux.core.model.error.PresentationError.*
-import io.iohk.atala.pollux.core.model.presentation.Options
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition.Input
-import io.iohk.atala.pollux.core.model.secret.CredentialDefinitionSecret
-import io.iohk.atala.pollux.core.repository.{CredentialRepository, PresentationRepository}
-import io.iohk.atala.pollux.core.service.serdes.{
+import org.hyperledger.identus.agent.walletapi.storage.GenericSecretStorage
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, Base64, DidId}
+import org.hyperledger.identus.mercury.protocol.issuecredential.{IssueCredential, IssueCredentialIssuedFormat}
+import org.hyperledger.identus.mercury.protocol.presentproof.*
+import org.hyperledger.identus.pollux.anoncreds.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.IssueCredentialRecord.*
+import org.hyperledger.identus.pollux.core.model.PresentationRecord.*
+import org.hyperledger.identus.pollux.core.model.error.PresentationError
+import org.hyperledger.identus.pollux.core.model.error.PresentationError.*
+import org.hyperledger.identus.pollux.core.model.presentation.Options
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition.Input
+import org.hyperledger.identus.pollux.core.model.secret.CredentialDefinitionSecret
+import org.hyperledger.identus.pollux.core.repository.{CredentialRepository, PresentationRepository}
+import org.hyperledger.identus.pollux.core.service.serdes.{
AnoncredCredentialProofV1,
AnoncredCredentialProofsV1,
AnoncredPresentationRequestV1,
AnoncredPresentationV1
}
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import zio.test.*
import zio.test.Assertion.*
@@ -92,9 +92,9 @@ object PresentationServiceSpec extends ZIOSpecDefault with PresentationServiceSp
val maybePresentationOptions =
record.requestPresentationData.get.attachments.headOption
.map(attachment =>
- decode[io.iohk.atala.mercury.model.JsonData](attachment.data.asJson.noSpaces)
+ decode[org.hyperledger.identus.mercury.model.JsonData](attachment.data.asJson.noSpaces)
.flatMap(data =>
- io.iohk.atala.pollux.core.model.presentation.PresentationAttachment.given_Decoder_PresentationAttachment
+ org.hyperledger.identus.pollux.core.model.presentation.PresentationAttachment.given_Decoder_PresentationAttachment
.decodeJson(data.json.asJson)
.map(_.options)
)
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/PresentationServiceSpecHelper.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceSpecHelper.scala
similarity index 86%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/PresentationServiceSpecHelper.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceSpecHelper.scala
index bbb32df467..558c24be92 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/PresentationServiceSpecHelper.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/PresentationServiceSpecHelper.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.pollux.core.service
+package org.hyperledger.identus.pollux.core.service
import com.nimbusds.jose.jwk.*
-import io.iohk.atala.agent.walletapi.memory.GenericSecretStorageInMemory
-import io.iohk.atala.mercury.model.{AttachmentDescriptor, DidId}
-import io.iohk.atala.mercury.protocol.presentproof.*
-import io.iohk.atala.mercury.{AgentPeerService, PeerDID}
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.error.PresentationError
-import io.iohk.atala.pollux.core.repository.*
-import io.iohk.atala.pollux.core.service.serdes.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.agent.walletapi.memory.GenericSecretStorageInMemory
+import org.hyperledger.identus.mercury.model.{AttachmentDescriptor, DidId}
+import org.hyperledger.identus.mercury.protocol.presentproof.*
+import org.hyperledger.identus.mercury.{AgentPeerService, PeerDID}
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.error.PresentationError
+import org.hyperledger.identus.pollux.core.repository.*
+import org.hyperledger.identus.pollux.core.service.serdes.*
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import java.security.*
@@ -55,12 +55,12 @@ trait PresentationServiceSpecHelper {
)
}
- protected def requestCredential = io.iohk.atala.mercury.protocol.issuecredential.RequestCredential(
+ protected def requestCredential = org.hyperledger.identus.mercury.protocol.issuecredential.RequestCredential(
from = DidId("did:prism:aaa"),
to = DidId("did:prism:bbb"),
thid = Some(UUID.randomUUID.toString),
- body =
- io.iohk.atala.mercury.protocol.issuecredential.RequestCredential.Body(goal_code = Some("credential issuance")),
+ body = org.hyperledger.identus.mercury.protocol.issuecredential.RequestCredential
+ .Body(goal_code = Some("credential issuance")),
attachments = Nil
)
@@ -158,7 +158,7 @@ trait PresentationServiceSpecHelper {
pairwiseProverDID: DidId = DidId("did:prism:prover-pairwise"),
thid: DidCommID = DidCommID(),
schemaId: _root_.java.lang.String = "schemaId",
- options: Option[io.iohk.atala.pollux.core.model.presentation.Options] = None
+ options: Option[org.hyperledger.identus.pollux.core.model.presentation.Options] = None
): ZIO[WalletAccessContext, PresentationError, PresentationRecord] = {
val proofType = ProofType(schemaId, None, None)
svc.createJwtPresentationRecord(
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationRequestSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationRequestSpec.scala
similarity index 97%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationRequestSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationRequestSpec.scala
index 85a18f3204..3abbb9f4db 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationRequestSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationRequestSpec.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.service.serdes
+package org.hyperledger.identus.pollux.core.service.serdes
import zio.*
import zio.test.*
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationSpec.scala
similarity index 97%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationSpec.scala
index 275bc181be..d3795f378c 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/serdes/AnoncredPresentationSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/serdes/AnoncredPresentationSpec.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.core.service.serdes
+package org.hyperledger.identus.pollux.core.service.serdes
-import io.iohk.atala.pollux.core.service.serdes.AnoncredPresentationV1.*
+import org.hyperledger.identus.pollux.core.service.serdes.AnoncredPresentationV1.*
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesSpec.scala
similarity index 98%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesSpec.scala
index aa10648519..e3de5b4407 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/serdes/PublicCredentialDefinitionSchemaSerDesSpec.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.core.service.serdes
+package org.hyperledger.identus.pollux.core.service.serdes
import zio.*
import zio.test.*
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImplSpec.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceImplSpec.scala
similarity index 98%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImplSpec.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceImplSpec.scala
index c621819224..53cb5ba626 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceImplSpec.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceImplSpec.scala
@@ -1,13 +1,13 @@
-package io.iohk.atala.pollux.core.service.verification
+package org.hyperledger.identus.pollux.core.service.verification
import io.circe.*
import io.circe.syntax.*
-import io.iohk.atala.agent.walletapi.service.MockManagedDIDService
-import io.iohk.atala.castor.core.service.MockDIDService
-import io.iohk.atala.pollux.core.service.ResourceURIDereferencerImpl
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.agent.walletapi.service.MockManagedDIDService
+import org.hyperledger.identus.castor.core.service.MockDIDService
+import org.hyperledger.identus.pollux.core.service.ResourceURIDereferencerImpl
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import zio.Config.OffsetDateTime
import zio.test.*
diff --git a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala
similarity index 72%
rename from pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala
rename to pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala
index a4778a9072..0febf9aded 100644
--- a/pollux/lib/core/src/test/scala/io/iohk/atala/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala
+++ b/pollux/core/src/test/scala/org/hyperledger/identus/pollux/core/service/verification/VcVerificationServiceSpecHelper.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.pollux.core.service.verification
-
-import io.iohk.atala.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.castor.core.service.{DIDService, MockDIDService}
-import io.iohk.atala.pollux.core.service.{ResourceURIDereferencerImpl, URIDereferencer}
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.shared.models.WalletId.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+package org.hyperledger.identus.pollux.core.service.verification
+
+import org.hyperledger.identus.agent.walletapi.service.{ManagedDIDService, MockManagedDIDService}
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.castor.core.service.{DIDService, MockDIDService}
+import org.hyperledger.identus.pollux.core.service.{ResourceURIDereferencerImpl, URIDereferencer}
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.shared.models.WalletId.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import zio.*
import zio.mock.Expectation
@@ -18,7 +18,7 @@ trait VcVerificationServiceSpecHelper {
protected val issuer =
Issuer(
- did = io.iohk.atala.pollux.vc.jwt.DID(issuerDidData.id.did.toString),
+ did = org.hyperledger.identus.pollux.vc.jwt.DID(issuerDidData.id.did.toString),
signer = ES256KSigner(issuerKp.privateKey.toJavaPrivateKey),
publicKey = issuerKp.publicKey.toJavaPublicKey
)
diff --git a/pollux/lib/issue-protocol-state.md b/pollux/issue-protocol-state.md
similarity index 100%
rename from pollux/lib/issue-protocol-state.md
rename to pollux/issue-protocol-state.md
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/LinkSecretError.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/LinkSecretError.scala
deleted file mode 100644
index 3854f345c6..0000000000
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/error/LinkSecretError.scala
+++ /dev/null
@@ -1,3 +0,0 @@
-package io.iohk.atala.pollux.core.model.error
-
-final case class LinkSecretError(cause: Throwable)
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/AnoncredSchemaType.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/AnoncredSchemaType.scala
deleted file mode 100644
index 10c53f6f5f..0000000000
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/AnoncredSchemaType.scala
+++ /dev/null
@@ -1,27 +0,0 @@
-package io.iohk.atala.pollux.core.model.schema.`type`
-
-import com.networknt.schema.*
-import io.iohk.atala.pollux.core.model.schema.Schema
-import io.iohk.atala.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1
-import io.iohk.atala.pollux.core.model.schema.`type`.anoncred.AnoncredSchemaSerDesV1.*
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaError
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaUtils
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaValidatorImpl
-import io.iohk.atala.pollux.core.model.schema.validator.SchemaSerDes
-import zio.*
-import zio.json.*
-
-object AnoncredSchemaType extends CredentialSchemaType {
-
- val anondcredShemaBasedSerDes: SchemaSerDes[AnoncredSchemaSerDesV1] = AnoncredSchemaSerDesV1.schemaSerDes
- val `type`: String = AnoncredSchemaSerDesV1.version
-
- override def validate(schema: Schema): IO[JsonSchemaError, Unit] = {
- for {
- jsonSchemaSchema <- anondcredShemaBasedSerDes.initialiseJsonSchema
- schemaValidator = JsonSchemaValidatorImpl(jsonSchemaSchema)
- jsonSchemaNode <- JsonSchemaUtils.toJsonNode(schema)
- _ <- schemaValidator.validate(jsonSchemaNode)
- } yield ()
- }
-}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialSchemaType.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialSchemaType.scala
deleted file mode 100644
index dccc047b0f..0000000000
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/model/schema/type/CredentialSchemaType.scala
+++ /dev/null
@@ -1,11 +0,0 @@
-package io.iohk.atala.pollux.core.model.schema.`type`
-
-import io.iohk.atala.pollux.core.model.schema.Schema
-import io.iohk.atala.pollux.core.model.schema.validator.JsonSchemaError
-import zio.IO
-
-trait CredentialSchemaType {
- val `type`: String
-
- def validate(schema: Schema): IO[JsonSchemaError, Unit]
-}
diff --git a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/LinkSecretService.scala b/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/LinkSecretService.scala
deleted file mode 100644
index f0d6aa2448..0000000000
--- a/pollux/lib/core/src/main/scala/io/iohk/atala/pollux/core/service/LinkSecretService.scala
+++ /dev/null
@@ -1,12 +0,0 @@
-package io.iohk.atala.pollux.core.service
-
-import io.iohk.atala.pollux.anoncreds.AnoncredLinkSecretWithId
-import io.iohk.atala.pollux.core.model.error.LinkSecretError
-import io.iohk.atala.shared.models.WalletAccessContext
-import zio.ZIO
-
-trait LinkSecretService {
- type Result[T] = ZIO[WalletAccessContext, LinkSecretError, T]
-
- def fetchOrCreate(): Result[AnoncredLinkSecretWithId]
-}
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V10__presentation_records_add_thid_unique_constraint.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V10__presentation_records_add_thid_unique_constraint.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V10__presentation_records_add_thid_unique_constraint.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V10__presentation_records_add_thid_unique_constraint.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V11__issue_credential_extend_schema_id.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V11__issue_credential_extend_schema_id.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V11__issue_credential_extend_schema_id.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V11__issue_credential_extend_schema_id.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V12__verification_policies_reset_nonce.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V12__verification_policies_reset_nonce.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V12__verification_policies_reset_nonce.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V12__verification_policies_reset_nonce.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V13__credential_schema_tables.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V13__credential_schema_tables.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V13__credential_schema_tables.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V13__credential_schema_tables.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V14__add_rls_policy.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V14__add_rls_policy.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V14__add_rls_policy.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V14__add_rls_policy.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V15__add_anoncreds_columns.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V15__add_anoncreds_columns.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V15__add_anoncreds_columns.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V15__add_anoncreds_columns.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V16__revocation_status_lists_table_and_columns.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V16__revocation_status_lists_table_and_columns.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V16__revocation_status_lists_table_and_columns.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V16__revocation_status_lists_table_and_columns.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V17__add_anoncred_credentials_to_use_columns.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V17__add_anoncred_credentials_to_use_columns.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V17__add_anoncred_credentials_to_use_columns.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V17__add_anoncred_credentials_to_use_columns.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V18__issue_credential_rename_schema_id.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V18__issue_credential_rename_schema_id.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V18__issue_credential_rename_schema_id.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V18__issue_credential_rename_schema_id.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V19__update_revocation_status_list_table_and_columns.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V19__update_revocation_status_list_table_and_columns.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V19__update_revocation_status_list_table_and_columns.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V19__update_revocation_status_list_table_and_columns.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V1__init_tables.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V1__init_tables.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V1__init_tables.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V1__init_tables.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V3__schema_registry_tables.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V3__schema_registry_tables.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V3__schema_registry_tables.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V3__schema_registry_tables.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V5__create_protocol_state_index.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V5__create_protocol_state_index.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V5__create_protocol_state_index.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V5__create_protocol_state_index.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V6__verification_policy_tables.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V6__verification_policy_tables.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V6__verification_policy_tables.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V6__verification_policy_tables.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V8__credential_schema_tables.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V8__credential_schema_tables.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V8__credential_schema_tables.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V8__credential_schema_tables.sql
diff --git a/pollux/lib/sql-doobie/src/main/resources/sql/pollux/V9__issue_credential_drop_subjectId_not_null.sql b/pollux/sql-doobie/src/main/resources/sql/pollux/V9__issue_credential_drop_subjectId_not_null.sql
similarity index 100%
rename from pollux/lib/sql-doobie/src/main/resources/sql/pollux/V9__issue_credential_drop_subjectId_not_null.sql
rename to pollux/sql-doobie/src/main/resources/sql/pollux/V9__issue_credential_drop_subjectId_not_null.sql
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/JWTCredentialRow.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/JWTCredentialRow.scala
similarity index 70%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/JWTCredentialRow.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/JWTCredentialRow.scala
index 697a973cf9..1b889efb3f 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/JWTCredentialRow.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/JWTCredentialRow.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.sql.model
+package org.hyperledger.identus.pollux.sql.model
private[sql] final case class JWTCredentialRow(
batchId: String,
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/CredentialDefinition.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/CredentialDefinition.scala
similarity index 92%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/CredentialDefinition.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/CredentialDefinition.scala
index 224c0a81c9..6fa9d39679 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/CredentialDefinition.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/CredentialDefinition.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.sql.model.db
+package org.hyperledger.identus.pollux.sql.model.db
import io.getquill.*
import io.getquill.context.json.PostgresJsonExtensions
import io.getquill.doobie.DoobieContext
import io.getquill.idiom.*
-import io.iohk.atala.pollux.core.model.schema.{CorrectnessProof, Definition}
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.pollux.core.model.schema.{CorrectnessProof, Definition}
+import org.hyperledger.identus.shared.models.WalletId
import java.time.OffsetDateTime
import java.time.temporal.ChronoUnit
@@ -37,7 +37,7 @@ case class CredentialDefinition(
object CredentialDefinition {
def fromModel(
- m: io.iohk.atala.pollux.core.model.schema.CredentialDefinition,
+ m: org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition,
walletId: WalletId
): CredentialDefinition =
CredentialDefinition(
@@ -61,8 +61,8 @@ object CredentialDefinition {
def toModel(
db: CredentialDefinition
- ): io.iohk.atala.pollux.core.model.schema.CredentialDefinition = {
- io.iohk.atala.pollux.core.model.schema.CredentialDefinition(
+ ): org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition = {
+ org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition(
guid = db.guid,
id = db.id,
name = db.name,
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/CredentialSchema.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/CredentialSchema.scala
similarity index 91%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/CredentialSchema.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/CredentialSchema.scala
index 54e4dfde32..4649497d25 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/CredentialSchema.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/CredentialSchema.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.sql.model.db
+package org.hyperledger.identus.pollux.sql.model.db
import io.getquill.*
import io.getquill.context.json.PostgresJsonExtensions
import io.getquill.doobie.DoobieContext
import io.getquill.idiom.*
-import io.iohk.atala.pollux.core.model.schema.Schema
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.pollux.core.model.schema.Schema
+import org.hyperledger.identus.shared.models.WalletId
import java.time.OffsetDateTime
import java.time.temporal.ChronoUnit
@@ -33,7 +33,7 @@ case class CredentialSchema(
object CredentialSchema {
def fromModel(
- m: io.iohk.atala.pollux.core.model.schema.CredentialSchema,
+ m: org.hyperledger.identus.pollux.core.model.schema.CredentialSchema,
walletId: WalletId
): CredentialSchema =
CredentialSchema(
@@ -52,8 +52,8 @@ object CredentialSchema {
def toModel(
db: CredentialSchema
- ): io.iohk.atala.pollux.core.model.schema.CredentialSchema = {
- io.iohk.atala.pollux.core.model.schema.CredentialSchema(
+ ): org.hyperledger.identus.pollux.core.model.schema.CredentialSchema = {
+ org.hyperledger.identus.pollux.core.model.schema.CredentialSchema(
guid = db.guid,
id = db.id,
name = db.name,
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/VerificationPolicy.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/VerificationPolicy.scala
similarity index 95%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/VerificationPolicy.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/VerificationPolicy.scala
index fbc8120a2c..b2d59df531 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/VerificationPolicy.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/VerificationPolicy.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.sql.model.db
+package org.hyperledger.identus.pollux.sql.model.db
import io.getquill.*
import io.getquill.doobie.DoobieContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletId
import java.util.UUID
import java.time.OffsetDateTime
@@ -26,7 +26,7 @@ case class VerificationPolicyConstraint(
)
object VerificationPolicySql extends DoobieContext.Postgres(SnakeCase) {
- import io.iohk.atala.pollux.sql.repository.VerificationPolicyExtensions._
+ import org.hyperledger.identus.pollux.sql.repository.VerificationPolicyExtensions._
def insert(verificationPolicy: VerificationPolicy) = {
run(quote(query[VerificationPolicy].insertValue(lift(verificationPolicy)).returning(vp => vp)))
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/package.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/package.scala
similarity index 68%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/package.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/package.scala
index 0ae1c4008c..413cc7b6d3 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/model/db/package.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/model/db/package.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.pollux.sql.model
+package org.hyperledger.identus.pollux.sql.model
import io.getquill.MappedEncoding
import java.util.UUID
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletId
package object db {
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/Implicits.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/Implicits.scala
similarity index 76%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/Implicits.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/Implicits.scala
index a741410a42..10064bf2e5 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/Implicits.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/Implicits.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import doobie.util.{Get, Put}
-import io.iohk.atala.castor.core.model.did.{CanonicalPrismDID, PrismDID}
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.vc.jwt.StatusPurpose
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.castor.core.model.did.{CanonicalPrismDID, PrismDID}
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.vc.jwt.StatusPurpose
+import org.hyperledger.identus.shared.models.WalletId
given didCommIDGet: Get[DidCommID] = Get[String].map(DidCommID(_))
given didCommIDPut: Put[DidCommID] = Put[String].contramap(_.value)
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialDefinitionRepository.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialDefinitionRepository.scala
similarity index 83%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialDefinitionRepository.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialDefinitionRepository.scala
index 0b56798c6a..580c335bd9 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialDefinitionRepository.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialDefinitionRepository.scala
@@ -1,14 +1,17 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import doobie.*
import doobie.implicits.*
-import io.iohk.atala.pollux.core.model.schema.CredentialDefinition
-import io.iohk.atala.pollux.core.repository.Repository.*
-import io.iohk.atala.pollux.core.repository.{CredentialDefinitionRepository, Repository}
-import io.iohk.atala.pollux.sql.model.db.{CredentialDefinitionSql, CredentialDefinition as CredentialDefinitionRow}
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.schema.CredentialDefinition
+import org.hyperledger.identus.pollux.core.repository.Repository.*
+import org.hyperledger.identus.pollux.core.repository.{CredentialDefinitionRepository, Repository}
+import org.hyperledger.identus.pollux.sql.model.db.{
+ CredentialDefinitionSql,
+ CredentialDefinition as CredentialDefinitionRow
+}
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.interop.catz.*
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialRepository.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialRepository.scala
similarity index 95%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialRepository.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialRepository.scala
index 7adc183485..b3acabca49 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialRepository.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialRepository.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import cats.data.NonEmptyList
import doobie.*
@@ -8,16 +8,16 @@ import doobie.postgres.implicits.*
import io.circe.*
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.mercury.protocol.issuecredential.{IssueCredential, OfferCredential, RequestCredential}
-import io.iohk.atala.pollux.anoncreds.AnoncredCredentialRequestMetadata
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.error.CredentialRepositoryError
-import io.iohk.atala.pollux.core.model.error.CredentialRepositoryError.*
-import io.iohk.atala.pollux.core.repository.CredentialRepository
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.mercury.protocol.issuecredential.{IssueCredential, OfferCredential, RequestCredential}
+import org.hyperledger.identus.pollux.anoncreds.AnoncredCredentialRequestMetadata
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.error.CredentialRepositoryError
+import org.hyperledger.identus.pollux.core.model.error.CredentialRepositoryError.*
+import org.hyperledger.identus.pollux.core.repository.CredentialRepository
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import org.postgresql.util.PSQLException
import zio.*
import zio.interop.catz.*
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialSchemaRepository.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialSchemaRepository.scala
similarity index 83%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialSchemaRepository.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialSchemaRepository.scala
index b3dc071814..9fc7872121 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialSchemaRepository.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialSchemaRepository.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import doobie.*
import doobie.implicits.*
-import io.iohk.atala.pollux.core.model.schema.CredentialSchema
-import io.iohk.atala.pollux.core.repository.Repository.*
-import io.iohk.atala.pollux.core.repository.{CredentialSchemaRepository, Repository}
-import io.iohk.atala.pollux.sql.model.db.{CredentialSchemaSql, CredentialSchema as CredentialSchemaRow}
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.pollux.core.model.schema.CredentialSchema
+import org.hyperledger.identus.pollux.core.repository.Repository.*
+import org.hyperledger.identus.pollux.core.repository.{CredentialSchemaRepository, Repository}
+import org.hyperledger.identus.pollux.sql.model.db.{CredentialSchemaSql, CredentialSchema as CredentialSchemaRow}
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.interop.catz.*
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialStatusListRepository.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialStatusListRepository.scala
similarity index 92%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialStatusListRepository.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialStatusListRepository.scala
index d32867e714..2d2884e3f9 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialStatusListRepository.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialStatusListRepository.scala
@@ -1,20 +1,20 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import doobie.*
import doobie.implicits.*
import doobie.postgres.*
import doobie.postgres.implicits.*
-import io.iohk.atala.pollux.vc.jwt.{Issuer, StatusPurpose}
-import io.iohk.atala.pollux.vc.jwt.revocation.{BitString, BitStringError, VCStatusList2021}
-import io.iohk.atala.castor.core.model.did.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.repository.CredentialStatusListRepository
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.pollux.vc.jwt.revocation.BitStringError.*
+import org.hyperledger.identus.pollux.vc.jwt.{Issuer, StatusPurpose}
+import org.hyperledger.identus.pollux.vc.jwt.revocation.{BitString, BitStringError, VCStatusList2021}
+import org.hyperledger.identus.castor.core.model.did.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.repository.CredentialStatusListRepository
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.revocation.BitStringError.*
import zio.*
import zio.interop.catz.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
import java.time.Instant
import java.util.UUID
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcPresentationRepository.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcPresentationRepository.scala
similarity index 96%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcPresentationRepository.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcPresentationRepository.scala
index 377d769ff1..1d7ed7c94e 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcPresentationRepository.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcPresentationRepository.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import cats.data.NonEmptyList
import doobie.*
@@ -11,13 +11,13 @@ import io.circe
import io.circe.*
import io.circe.parser.*
import io.circe.syntax.*
-import io.iohk.atala.mercury.protocol.presentproof.*
-import io.iohk.atala.pollux.core.model.*
-import io.iohk.atala.pollux.core.model.PresentationRecord.ProtocolState
-import io.iohk.atala.pollux.core.repository.PresentationRepository
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
+import org.hyperledger.identus.mercury.protocol.presentproof.*
+import org.hyperledger.identus.pollux.core.model.*
+import org.hyperledger.identus.pollux.core.model.PresentationRecord.ProtocolState
+import org.hyperledger.identus.pollux.core.repository.PresentationRepository
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.*
import zio.interop.catz.*
import zio.json.*
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcVerificationPolicyRepository.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcVerificationPolicyRepository.scala
similarity index 89%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcVerificationPolicyRepository.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcVerificationPolicyRepository.scala
index d695cc6eb4..5de7415d14 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/JdbcVerificationPolicyRepository.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/JdbcVerificationPolicyRepository.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import doobie.*
import doobie.util.transactor.Transactor
-import io.iohk.atala.pollux.core.model
-import io.iohk.atala.pollux.core.model.{CredentialSchemaAndTrustedIssuersConstraint, VerificationPolicy}
-import io.iohk.atala.pollux.core.repository.VerificationPolicyRepository
-import io.iohk.atala.pollux.sql.model.db
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.pollux.core.model
+import org.hyperledger.identus.pollux.core.model.{CredentialSchemaAndTrustedIssuersConstraint, VerificationPolicy}
+import org.hyperledger.identus.pollux.core.repository.VerificationPolicyRepository
+import org.hyperledger.identus.pollux.sql.model.db
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import java.time.{OffsetDateTime, ZoneOffset}
@@ -71,7 +71,7 @@ object JdbcVerificationPolicyRepository {
class JdbcVerificationPolicyRepository(xa: Transactor[ContextAwareTask]) extends VerificationPolicyRepository {
import VerificationPolicyExtensions.*
- import io.iohk.atala.pollux.sql.model.db.VerificationPolicySql
+ import org.hyperledger.identus.pollux.sql.model.db.VerificationPolicySql
override def create(
verificationPolicy: model.VerificationPolicy
diff --git a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/Migrations.scala b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/Migrations.scala
similarity index 89%
rename from pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/Migrations.scala
rename to pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/Migrations.scala
index cac7549e18..1a3bf6369b 100644
--- a/pollux/lib/sql-doobie/src/main/scala/io/iohk/atala/pollux/sql/repository/Migrations.scala
+++ b/pollux/sql-doobie/src/main/scala/org/hyperledger/identus/pollux/sql/repository/Migrations.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import doobie.*
import doobie.implicits.*
import doobie.util.transactor.Transactor
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.DbConfig
-import io.iohk.atala.shared.db.Implicits.*
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.DbConfig
+import org.hyperledger.identus.shared.db.Implicits.*
import org.flywaydb.core.Flyway
import zio.*
import zio.interop.catz.*
diff --git a/pollux/lib/sql-doobie/src/test/resources/data/verifiableCredentialClaims.csv b/pollux/sql-doobie/src/test/resources/data/verifiableCredentialClaims.csv
similarity index 100%
rename from pollux/lib/sql-doobie/src/test/resources/data/verifiableCredentialClaims.csv
rename to pollux/sql-doobie/src/test/resources/data/verifiableCredentialClaims.csv
diff --git a/pollux/lib/sql-doobie/src/test/resources/data/verifiableCredentialTypes.csv b/pollux/sql-doobie/src/test/resources/data/verifiableCredentialTypes.csv
similarity index 100%
rename from pollux/lib/sql-doobie/src/test/resources/data/verifiableCredentialTypes.csv
rename to pollux/sql-doobie/src/test/resources/data/verifiableCredentialTypes.csv
diff --git a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/CredentialDefinitionSqlIntegrationSpec.scala b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/CredentialDefinitionSqlIntegrationSpec.scala
similarity index 94%
rename from pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/CredentialDefinitionSqlIntegrationSpec.scala
rename to pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/CredentialDefinitionSqlIntegrationSpec.scala
index 4f1e96510e..c6ffccdadc 100644
--- a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/CredentialDefinitionSqlIntegrationSpec.scala
+++ b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/CredentialDefinitionSqlIntegrationSpec.scala
@@ -1,15 +1,15 @@
-package io.iohk.atala.pollux.sql
+package org.hyperledger.identus.pollux.sql
import com.dimafeng.testcontainers.PostgreSQLContainer
import doobie.*
import doobie.util.transactor.Transactor
import io.getquill.*
-import io.iohk.atala.pollux.sql.model.db.{CredentialDefinition, CredentialDefinitionSql}
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.{WalletAccessContext, WalletId}
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.MigrationAspects.*
+import org.hyperledger.identus.pollux.sql.model.db.{CredentialDefinition, CredentialDefinitionSql}
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.{WalletAccessContext, WalletId}
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.MigrationAspects.*
import zio.*
import zio.json.ast.Json
import zio.test.*
diff --git a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/CredentialSchemaSqlIntegrationSpec.scala b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/CredentialSchemaSqlIntegrationSpec.scala
similarity index 94%
rename from pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/CredentialSchemaSqlIntegrationSpec.scala
rename to pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/CredentialSchemaSqlIntegrationSpec.scala
index 6d11833ef9..ae379a6f9f 100644
--- a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/CredentialSchemaSqlIntegrationSpec.scala
+++ b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/CredentialSchemaSqlIntegrationSpec.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.pollux.sql
+package org.hyperledger.identus.pollux.sql
import com.dimafeng.testcontainers.PostgreSQLContainer
import doobie.*
import doobie.util.transactor.Transactor
import io.getquill.*
-import io.iohk.atala.pollux.sql.model.db.{CredentialSchema, CredentialSchemaSql}
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.MigrationAspects.*
+import org.hyperledger.identus.pollux.sql.model.db.{CredentialSchema, CredentialSchemaSql}
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.MigrationAspects.*
import zio.*
import zio.json.ast.Json
import zio.test.*
diff --git a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/VerificationPolicySqlIntegrationSpec.scala b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/VerificationPolicySqlIntegrationSpec.scala
similarity index 93%
rename from pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/VerificationPolicySqlIntegrationSpec.scala
rename to pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/VerificationPolicySqlIntegrationSpec.scala
index ac24d4851b..57387b8415 100644
--- a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/VerificationPolicySqlIntegrationSpec.scala
+++ b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/VerificationPolicySqlIntegrationSpec.scala
@@ -1,22 +1,22 @@
-package io.iohk.atala.pollux.sql
+package org.hyperledger.identus.pollux.sql
import com.dimafeng.testcontainers.PostgreSQLContainer
import doobie.*
import doobie.util.transactor.Transactor
-import io.iohk.atala.pollux.core.model.{
+import org.hyperledger.identus.pollux.core.model.{
CredentialSchemaAndTrustedIssuersConstraint,
VerificationPolicy,
VerificationPolicyConstraint
}
-import io.iohk.atala.pollux.core.repository.VerificationPolicyRepository
-import io.iohk.atala.pollux.sql.model.db.VerificationPolicySql
-import io.iohk.atala.pollux.sql.repository.JdbcVerificationPolicyRepository
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.Implicits.*
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.MigrationAspects.*
+import org.hyperledger.identus.pollux.core.repository.VerificationPolicyRepository
+import org.hyperledger.identus.pollux.sql.model.db.VerificationPolicySql
+import org.hyperledger.identus.pollux.sql.repository.JdbcVerificationPolicyRepository
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.Implicits.*
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.test.container.MigrationAspects.*
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialRepositorySpec.scala b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialRepositorySpec.scala
similarity index 79%
rename from pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialRepositorySpec.scala
rename to pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialRepositorySpec.scala
index 49e66d9c24..b91608a6d0 100644
--- a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/repository/JdbcCredentialRepositorySpec.scala
+++ b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/repository/JdbcCredentialRepositorySpec.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.pollux.core.repository._
-import io.iohk.atala.shared.db.DbConfig
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.pollux.core.repository._
+import org.hyperledger.identus.shared.db.DbConfig
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
import zio._
import zio.test._
diff --git a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/repository/JdbcPresentationRepositorySpec.scala b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/repository/JdbcPresentationRepositorySpec.scala
similarity index 79%
rename from pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/repository/JdbcPresentationRepositorySpec.scala
rename to pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/repository/JdbcPresentationRepositorySpec.scala
index 6d4e2c3cc7..b4ababcef4 100644
--- a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/pollux/sql/repository/JdbcPresentationRepositorySpec.scala
+++ b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/pollux/sql/repository/JdbcPresentationRepositorySpec.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.sql.repository
+package org.hyperledger.identus.pollux.sql.repository
import com.dimafeng.testcontainers.PostgreSQLContainer
-import io.iohk.atala.pollux.core.repository._
-import io.iohk.atala.shared.db.DbConfig
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
+import org.hyperledger.identus.pollux.core.repository._
+import org.hyperledger.identus.shared.db.DbConfig
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainerSupport
import zio._
import zio.test._
diff --git a/prism-agent/service/server/src/test/scala/io/iohk/atala/container/util/MigrationAspect.scala b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/test/container/MigrationAspect.scala
similarity index 96%
rename from prism-agent/service/server/src/test/scala/io/iohk/atala/container/util/MigrationAspect.scala
rename to pollux/sql-doobie/src/test/scala/org/hyperledger/identus/test/container/MigrationAspect.scala
index 34f2fcfd00..881afaccff 100644
--- a/prism-agent/service/server/src/test/scala/io/iohk/atala/container/util/MigrationAspect.scala
+++ b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/test/container/MigrationAspect.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.container.util
+package org.hyperledger.identus.test.container
import com.dimafeng.testcontainers.PostgreSQLContainer
import org.flywaydb.core.Flyway
import zio.ZIO
-import zio.test.TestAspect.{beforeAll, before}
import zio.test.{TestAspect, TestAspectAtLeastR}
+import zio.test.TestAspect.{beforeAll, before}
object MigrationAspects {
def migrate(schema: String, paths: String*): TestAspectAtLeastR[PostgreSQLContainer] = {
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidJWT.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidJWT.scala
similarity index 98%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidJWT.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidJWT.scala
index 909782cd86..7b7c90fdf0 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidJWT.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidJWT.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import com.nimbusds.jose.{JWSAlgorithm, JWSHeader}
import com.nimbusds.jose.crypto.ECDSASigner
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidResolver.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidResolver.scala
similarity index 97%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidResolver.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidResolver.scala
index aaf5f5260d..63ff932bdc 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidResolver.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/DidResolver.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
-import io.iohk.atala.castor.core.model.did.w3c.{
+import org.hyperledger.identus.castor.core.model.did.w3c.{
DIDDocumentRepr,
DIDResolutionErrorRepr,
PublicKeyJwk,
@@ -9,7 +9,7 @@ import io.iohk.atala.castor.core.model.did.w3c.{
ServiceRepr,
makeW3CResolver
}
-import io.iohk.atala.castor.core.service.DIDService
+import org.hyperledger.identus.castor.core.service.DIDService
import zio.*
import java.time.Instant
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/InstantDecoderEncoder.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/InstantDecoderEncoder.scala
similarity index 89%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/InstantDecoderEncoder.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/InstantDecoderEncoder.scala
index 780b32173a..03c63b74bd 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/InstantDecoderEncoder.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/InstantDecoderEncoder.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import io.circe.{Decoder, Encoder, HCursor}
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala
similarity index 98%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala
index 4b2a21d43c..c40f8f3cdd 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/JWTVerification.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import com.nimbusds.jose.JWSVerifier
import com.nimbusds.jose.crypto.ECDSAVerifier
@@ -8,7 +8,7 @@ import com.nimbusds.jose.util.Base64URL
import com.nimbusds.jwt.SignedJWT
import io.circe
import io.circe.generic.auto.*
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
import pdi.jwt.*
import zio.*
import zio.prelude.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiBaseString.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiBaseString.scala
similarity index 94%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiBaseString.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiBaseString.scala
index d1c881e578..510c771469 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiBaseString.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiBaseString.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import io.circe.*
-import io.iohk.atala.shared.utils.Base64Utils
+import org.hyperledger.identus.shared.utils.Base64Utils
import scodec.bits.ByteVector
case class MultiBaseString(header: MultiBaseString.Header, data: String) {
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiKey.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiKey.scala
similarity index 95%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiKey.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiKey.scala
index 765387358b..f1ed33a4ce 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiKey.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/MultiKey.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import io.circe.*
import io.circe.syntax.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Proof.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Proof.scala
similarity index 97%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Proof.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Proof.scala
index 80b53ab5b0..c27c6999ba 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Proof.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Proof.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import com.nimbusds.jose.crypto.bc.BouncyCastleProviderSingleton
import io.circe.*
@@ -6,8 +6,8 @@ import io.circe.syntax.*
import cats.implicits.*
import java.time.{Instant, ZoneOffset}
import zio.*
-import io.iohk.atala.shared.utils.Json as JsonUtils
-import io.iohk.atala.shared.utils.Base64Utils
+import org.hyperledger.identus.shared.utils.Json as JsonUtils
+import org.hyperledger.identus.shared.utils.Base64Utils
import scodec.bits.ByteVector
import scala.util.Try
import java.security.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/ValidationUtils.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/ValidationUtils.scala
similarity index 88%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/ValidationUtils.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/ValidationUtils.scala
index b5b83512b1..e80d1cdea2 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/ValidationUtils.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/ValidationUtils.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import zio.{Trace, ZIO}
import zio.prelude.{Validation, ZValidation}
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Verifiable.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Verifiable.scala
similarity index 94%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Verifiable.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Verifiable.scala
index 7b3e9b7653..3f768d906f 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Verifiable.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/Verifiable.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import io.circe
import io.circe.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala
similarity index 99%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala
index aba96e8f76..f99dc7a492 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiableCredentialPayload.scala
@@ -1,14 +1,14 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import io.circe
import io.circe.*
import io.circe.generic.auto.*
import io.circe.parser.decode
import io.circe.syntax.*
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.pollux.vc.jwt.revocation.BitString
-import io.iohk.atala.pollux.vc.jwt.schema.{SchemaResolver, SchemaValidator}
-import io.iohk.atala.shared.http.UriResolver
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.pollux.vc.jwt.revocation.BitString
+import org.hyperledger.identus.pollux.vc.jwt.schema.{SchemaResolver, SchemaValidator}
+import org.hyperledger.identus.shared.http.UriResolver
import pdi.jwt.*
import zio.*
import zio.prelude.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiablePresentationPayload.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiablePresentationPayload.scala
similarity index 98%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiablePresentationPayload.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiablePresentationPayload.scala
index eaeae39529..fa7e98ae2c 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiablePresentationPayload.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/VerifiablePresentationPayload.scala
@@ -1,12 +1,12 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import io.circe
import io.circe.*
import io.circe.generic.auto.*
import io.circe.parser.decode
import io.circe.syntax.*
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.shared.http.UriResolver
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.shared.http.UriResolver
import pdi.jwt.{JwtCirce, JwtOptions}
import zio.*
import zio.prelude.*
@@ -432,7 +432,7 @@ object JwtPresentation {
}
def verifyHolderBinding(jwt: JWT): Validation[String, Unit] = {
- import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
+ import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
val decodeJWT = (jwt: JWT) =>
Validation
.fromTry(JwtCirce.decodeRaw(jwt.value, options = JwtOptions(false, false, false)))
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/CredentialDemo.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/CredentialDemo.scala
similarity index 95%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/CredentialDemo.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/CredentialDemo.scala
index bf18fa4f97..fd3c48733a 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/CredentialDemo.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/CredentialDemo.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.vc.jwt.demos
+package org.hyperledger.identus.pollux.vc.jwt.demos
import io.circe.*
import io.circe.parser.decode
import io.circe.syntax.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
import java.time.Instant
@main def CredentialDemo(): Unit =
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialDIDDocumentValidationDemo.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialDIDDocumentValidationDemo.scala
similarity index 97%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialDIDDocumentValidationDemo.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialDIDDocumentValidationDemo.scala
index bdd1f49740..dc4d4a546e 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialDIDDocumentValidationDemo.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialDIDDocumentValidationDemo.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.vc.jwt.demos
+package org.hyperledger.identus.pollux.vc.jwt.demos
import com.nimbusds.jose.jwk.*
import io.circe.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.schema.{PlaceholderSchemaValidator, SchemaResolver}
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.schema.{PlaceholderSchemaValidator, SchemaResolver}
import pdi.jwt.JwtAlgorithm
import zio.*
import zio.Console.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialEncodingDemo.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialEncodingDemo.scala
similarity index 95%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialEncodingDemo.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialEncodingDemo.scala
index 87efa0a00a..bd3347ae8a 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialEncodingDemo.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialEncodingDemo.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.vc.jwt.demos
+package org.hyperledger.identus.pollux.vc.jwt.demos
import io.circe.*
import io.circe.syntax.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
import java.security.*
import java.security.spec.*
import java.time.Instant
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialTemporalVerificationDemo.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialTemporalVerificationDemo.scala
similarity index 97%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialTemporalVerificationDemo.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialTemporalVerificationDemo.scala
index f4539cdd9a..07ed493702 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialTemporalVerificationDemo.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtCredentialTemporalVerificationDemo.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.vc.jwt.demos
+package org.hyperledger.identus.pollux.vc.jwt.demos
import io.circe.*
import io.circe.syntax.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
import java.security.*
import java.security.spec.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationCredentialDemo.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationCredentialDemo.scala
similarity index 95%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationCredentialDemo.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationCredentialDemo.scala
index 0554e26e91..f103d787e3 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationCredentialDemo.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationCredentialDemo.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.vc.jwt.demos
+package org.hyperledger.identus.pollux.vc.jwt.demos
import io.circe.*
import io.circe.syntax.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
-import io.iohk.atala.pollux.vc.jwt.PresentationPayload.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.PresentationPayload.Implicits.*
import java.security.*
import java.security.spec.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationTemporalVerificationDemo.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationTemporalVerificationDemo.scala
similarity index 97%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationTemporalVerificationDemo.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationTemporalVerificationDemo.scala
index ae4ac3ce0e..8eab14abec 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationTemporalVerificationDemo.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationTemporalVerificationDemo.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.pollux.vc.jwt.demos
+package org.hyperledger.identus.pollux.vc.jwt.demos
import io.circe.*
import io.circe.syntax.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
-import io.iohk.atala.pollux.vc.jwt.PresentationPayload.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.PresentationPayload.Implicits.*
import java.security.*
import java.security.spec.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationVerificationDemo.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationVerificationDemo.scala
similarity index 97%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationVerificationDemo.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationVerificationDemo.scala
index aed191ac15..2139cb95bd 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationVerificationDemo.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/JwtPresentationVerificationDemo.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.pollux.vc.jwt.demos
+package org.hyperledger.identus.pollux.vc.jwt.demos
import com.nimbusds.jose.jwk.{Curve, ECKey}
import io.circe.*
import io.circe.syntax.*
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
-import io.iohk.atala.pollux.vc.jwt.PresentationPayload.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
+import org.hyperledger.identus.pollux.vc.jwt.PresentationPayload.Implicits.*
import pdi.jwt.JwtAlgorithm
import zio.Console.printLine
import zio.{UIO, ZIO, ZIOAppDefault}
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/SchemaDemo.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/SchemaDemo.scala
similarity index 97%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/SchemaDemo.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/SchemaDemo.scala
index 992c3525ca..77bea1dd20 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/SchemaDemo.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/demos/SchemaDemo.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt.demos
+package org.hyperledger.identus.pollux.vc.jwt.demos
import io.circe.*
import net.reactivecore.cjs.{DocumentValidator, Loader}
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitString.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitString.scala
similarity index 95%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitString.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitString.scala
index 1a0b6cd198..21ca1009ae 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitString.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitString.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.vc.jwt.revocation
+package org.hyperledger.identus.pollux.vc.jwt.revocation
-import io.iohk.atala.pollux.vc.jwt.revocation.BitStringError.{DecodingError, EncodingError, IndexOutOfBounds}
+import org.hyperledger.identus.pollux.vc.jwt.revocation.BitStringError.{DecodingError, EncodingError, IndexOutOfBounds}
import zio.{IO, UIO, ZIO}
import java.io.{ByteArrayInputStream, ByteArrayOutputStream}
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021.scala
similarity index 94%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021.scala
index 2822eb36ae..8634947837 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.pollux.vc.jwt.revocation
+package org.hyperledger.identus.pollux.vc.jwt.revocation
import io.circe.syntax.*
import io.circe.{Json, JsonObject}
-import io.iohk.atala.pollux.vc.jwt.*
-import io.iohk.atala.pollux.vc.jwt.revocation.VCStatusList2021Error.{DecodingError, EncodingError}
+import org.hyperledger.identus.pollux.vc.jwt.*
+import org.hyperledger.identus.pollux.vc.jwt.revocation.VCStatusList2021Error.{DecodingError, EncodingError}
import zio.*
import java.time.Instant
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/PlaceholderSchemaValidator.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/PlaceholderSchemaValidator.scala
similarity index 88%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/PlaceholderSchemaValidator.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/PlaceholderSchemaValidator.scala
index e1011927f8..d78e69fc0b 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/PlaceholderSchemaValidator.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/PlaceholderSchemaValidator.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt.schema
+package org.hyperledger.identus.pollux.vc.jwt.schema
import io.circe
import io.circe.Json
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/ReactiveCoreSchemaValidator.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/ReactiveCoreSchemaValidator.scala
similarity index 93%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/ReactiveCoreSchemaValidator.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/ReactiveCoreSchemaValidator.scala
index eebd3da51f..e57ef5299e 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/ReactiveCoreSchemaValidator.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/ReactiveCoreSchemaValidator.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt.schema
+package org.hyperledger.identus.pollux.vc.jwt.schema
import io.circe
import io.circe.generic.auto.*
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaResolver.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaResolver.scala
similarity index 53%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaResolver.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaResolver.scala
index 5f8ef41ff7..886a758006 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaResolver.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaResolver.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.pollux.vc.jwt.schema
+package org.hyperledger.identus.pollux.vc.jwt.schema
import io.circe.Json
-import io.iohk.atala.pollux.vc.jwt.CredentialSchema
+import org.hyperledger.identus.pollux.vc.jwt.CredentialSchema
import zio.IO
trait SchemaResolver {
diff --git a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaValidator.scala b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaValidator.scala
similarity index 73%
rename from pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaValidator.scala
rename to pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaValidator.scala
index ad76e91719..8cef04a10a 100644
--- a/pollux/lib/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaValidator.scala
+++ b/pollux/vc-jwt/src/main/scala/io/iohk/atala/pollux/vc/jwt/schema/SchemaValidator.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt.schema
+package org.hyperledger.identus.pollux.vc.jwt.schema
import zio.prelude.Validation;
import io.circe.Json
diff --git a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ECDSAVerifierTest.scala b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ECDSAVerifierTest.scala
similarity index 94%
rename from pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ECDSAVerifierTest.scala
rename to pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ECDSAVerifierTest.scala
index 53ed7d8c98..10e3467227 100644
--- a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ECDSAVerifierTest.scala
+++ b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ECDSAVerifierTest.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import com.nimbusds.jose.crypto.bc.BouncyCastleProviderSingleton
import com.nimbusds.jose.jwk.Curve
diff --git a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ES256KSignerTest.scala b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ES256KSignerTest.scala
similarity index 94%
rename from pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ES256KSignerTest.scala
rename to pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ES256KSignerTest.scala
index 42dea6ad31..118a4e9156 100644
--- a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ES256KSignerTest.scala
+++ b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/ES256KSignerTest.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import com.nimbusds.jose.crypto.bc.BouncyCastleProviderSingleton
import com.nimbusds.jose.jwk.Curve
diff --git a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/JWTVerificationTest.scala b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/JWTVerificationTest.scala
similarity index 98%
rename from pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/JWTVerificationTest.scala
rename to pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/JWTVerificationTest.scala
index 7f096d5b97..bd4bd545e8 100644
--- a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/JWTVerificationTest.scala
+++ b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/JWTVerificationTest.scala
@@ -1,16 +1,16 @@
-package io.iohk.atala.pollux.vc.jwt
+package org.hyperledger.identus.pollux.vc.jwt
import com.nimbusds.jose.crypto.bc.BouncyCastleProviderSingleton
import com.nimbusds.jose.jwk.gen.ECKeyGenerator
import com.nimbusds.jose.jwk.{Curve, ECKey}
import io.circe.*
import io.circe.syntax.*
-import io.iohk.atala.castor.core.model.did.VerificationRelationship
-import io.iohk.atala.pollux.vc.jwt.CredentialPayload.Implicits.*
+import org.hyperledger.identus.castor.core.model.did.VerificationRelationship
+import org.hyperledger.identus.pollux.vc.jwt.CredentialPayload.Implicits.*
import zio.*
import zio.test.*
import zio.test.Assertion.*
-import io.iohk.atala.shared.http.*
+import org.hyperledger.identus.shared.http.*
import java.security.Security
import java.time.Instant
diff --git a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitStringSpec.scala b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitStringSpec.scala
similarity index 95%
rename from pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitStringSpec.scala
rename to pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitStringSpec.scala
index 186d582faf..dcc5d93fc8 100644
--- a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitStringSpec.scala
+++ b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/BitStringSpec.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.vc.jwt.revocation
+package org.hyperledger.identus.pollux.vc.jwt.revocation
-import io.iohk.atala.pollux.vc.jwt.revocation.BitStringError.{IndexOutOfBounds, InvalidSize}
+import org.hyperledger.identus.pollux.vc.jwt.revocation.BitStringError.{IndexOutOfBounds, InvalidSize}
import zio.*
import zio.test.*
import zio.test.Assertion.*
diff --git a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021Spec.scala b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021Spec.scala
similarity index 95%
rename from pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021Spec.scala
rename to pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021Spec.scala
index a08c2bf0ac..db69cc8952 100644
--- a/pollux/lib/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021Spec.scala
+++ b/pollux/vc-jwt/src/test/scala/io/iohk/atala/pollux/vc/jwt/revocation/VCStatusList2021Spec.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.pollux.vc.jwt.revocation
+package org.hyperledger.identus.pollux.vc.jwt.revocation
-import io.iohk.atala.pollux.vc.jwt.{DID, ES256Signer, Issuer, JwtCredential}
+import org.hyperledger.identus.pollux.vc.jwt.{DID, ES256Signer, Issuer, JwtCredential}
import zio.test.{Spec, ZIOSpecDefault, assertTrue}
import zio.{UIO, ZIO}
diff --git a/prism-agent/client/generator/generate-clients.sh b/prism-agent/client/generator/generate-clients.sh
deleted file mode 100755
index 8126e84dcb..0000000000
--- a/prism-agent/client/generator/generate-clients.sh
+++ /dev/null
@@ -1,20 +0,0 @@
-#!/bin/bash
-set -e
-
-# generate kotlin models
-yarn openapi-generator-cli generate \
- -g kotlin \
- -i ../../service/api/http/prism-agent-openapi-spec.yaml \
- -o ../kotlin \
- --ignore-file-override ../kotlin/.openapi-generator-ignore \
- --additional-properties=packageName=io.iohk.atala.prism,serializationLibrary=gson,enumPropertyNaming=UPPERCASE
-
-# generate typescript models
-yarn openapi-generator-cli generate \
- -g typescript \
- -i ../../service/api/http/prism-agent-openapi-spec.yaml \
- -o ../typescript \
- --ignore-file-override ../typescript/.openapi-generator-ignore
-
-# generate python models
-# yarn openapi-generator-cli generate -g python -i oas.yml --skip-validate-spec -o ../python --ignore-file-override ../python/.openapi-generator-ignore
diff --git a/prism-agent/client/generator/publish-clients.sh b/prism-agent/client/generator/publish-clients.sh
deleted file mode 100755
index 4cc96205c7..0000000000
--- a/prism-agent/client/generator/publish-clients.sh
+++ /dev/null
@@ -1,16 +0,0 @@
-#!/bin/bash
-set -e
-
-PRISM_AGENT_VERSION=${VERSION_TAG:13}
-
-# install dependencies
-yarn
-
-# kotlin
-gradle -p ../kotlin -Pversion=${PRISM_AGENT_VERSION} publish
-
-# typescript
-yarn --cwd ../typescript
-yarn --cwd ../typescript publish --new-version ${PRISM_AGENT_VERSION} --no-git-tag-version
-
-# python
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/PeerDIDRecord.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/PeerDIDRecord.scala
deleted file mode 100644
index 0d9a0c8ff9..0000000000
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/model/PeerDIDRecord.scala
+++ /dev/null
@@ -1,8 +0,0 @@
-package io.iohk.atala.agent.walletapi.model
-
-import io.iohk.atala.mercury.model.DidId
-import io.iohk.atala.shared.models.WalletId
-
-import java.time.Instant
-
-case class PeerDIDRecord(did: DidId, createdAt: Instant, walletId: WalletId)
diff --git a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/WalletSecretStorage.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/WalletSecretStorage.scala
deleted file mode 100644
index bbd7e5316e..0000000000
--- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/WalletSecretStorage.scala
+++ /dev/null
@@ -1,10 +0,0 @@
-package io.iohk.atala.agent.walletapi.storage
-
-import io.iohk.atala.agent.walletapi.model.WalletSeed
-import io.iohk.atala.shared.models.WalletAccessContext
-import zio.*
-
-trait WalletSecretStorage {
- def setWalletSeed(seed: WalletSeed): RIO[WalletAccessContext, Unit]
- def getWalletSeed: RIO[WalletAccessContext, Option[WalletSeed]]
-}
diff --git a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcDIDNonSecretStorageSpec.scala b/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcDIDNonSecretStorageSpec.scala
deleted file mode 100644
index 3ab5831ce1..0000000000
--- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcDIDNonSecretStorageSpec.scala
+++ /dev/null
@@ -1,288 +0,0 @@
-package io.iohk.atala.agent.walletapi.storage
-
-import io.iohk.atala.agent.walletapi.model.ManagedDIDState
-import io.iohk.atala.agent.walletapi.model.PublicationState
-import io.iohk.atala.agent.walletapi.service.WalletManagementService
-import io.iohk.atala.agent.walletapi.service.WalletManagementServiceImpl
-import io.iohk.atala.agent.walletapi.sql.JdbcDIDNonSecretStorage
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletNonSecretStorage
-import io.iohk.atala.agent.walletapi.sql.JdbcWalletSecretStorage
-import io.iohk.atala.castor.core.model.did.PrismDID
-import io.iohk.atala.castor.core.model.did.PrismDIDOperation
-import io.iohk.atala.castor.core.model.did.ScheduledDIDOperationStatus
-import io.iohk.atala.shared.crypto.ApolloSpecHelper
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.sharedtest.containers.PostgresTestContainerSupport
-import io.iohk.atala.test.container.DBTestUtils
-import org.postgresql.util.PSQLException
-import zio.*
-import zio.test.*
-import zio.test.Assertion.*
-
-import scala.collection.compat.immutable.ArraySeq
-
-object JdbcDIDNonSecretStorageSpec
- extends ZIOSpecDefault,
- StorageSpecHelper,
- PostgresTestContainerSupport,
- ApolloSpecHelper {
-
- private def insertDIDStateWithDelay(operation: Seq[PrismDIDOperation.Create], delay: zio.Duration) =
- ZIO.foreach(operation.zipWithIndex) { case (op, idx) =>
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- _ <- storage.insertManagedDID(
- op.did,
- ManagedDIDState(op, idx, PublicationState.Created()),
- Map.empty,
- Map.empty
- )
- _ <- TestClock.adjust(delay)
- } yield ()
- }
-
- override def spec = {
- val testSuite =
- suite("JdbcDIDNonSecretStorageSpec")(
- listDIDStateSpec,
- getDIDStateSpec,
- listDIDLineageSpec,
- setDIDLineageStatusSpec
- ).globalWallet @@ TestAspect.before(DBTestUtils.runMigrationAgentDB)
-
- testSuite
- .provide(
- JdbcDIDNonSecretStorage.layer,
- JdbcWalletNonSecretStorage.layer,
- JdbcWalletSecretStorage.layer,
- WalletManagementServiceImpl.layer,
- systemTransactorLayer,
- contextAwareTransactorLayer,
- pgContainerLayer,
- apolloLayer,
- )
- }
-
- private val listDIDStateSpec = suite("listManagedDIDState")(
- test("initialize with empty list") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- resultsWithCount <- storage.listManagedDID(None, None)
- (results, count) = resultsWithCount
- } yield assert(results)(isEmpty) && assert(count)(isZero)
- },
- test("list stored dids") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- did1 = PrismDID.buildCanonicalFromSuffix("0" * 64).toOption.get
- did2 = PrismDID.buildCanonicalFromSuffix("1" * 64).toOption.get
- createOperation1 <- generateCreateOperation(Seq("key-1"), 0).map(_._1)
- createOperation2 <- generateCreateOperation(Seq("key-1"), 1).map(_._1)
- _ <- storage.insertManagedDID(
- did1,
- ManagedDIDState(createOperation1, 0, PublicationState.Created()),
- Map.empty,
- Map.empty
- )
- _ <- storage.insertManagedDID(
- did2,
- ManagedDIDState(createOperation2, 1, PublicationState.Created()),
- Map.empty,
- Map.empty
- )
- states <- storage.listManagedDID(None, None).map(_._1)
- } yield assert(states.map(_._1))(hasSameElements(Seq(did1, did2)))
- },
- test("list stored dids and return correct item count when using offset and limit") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
- _ <- insertDIDStateWithDelay(operations, 100.millis)
- resultsWithCount <- storage.listManagedDID(offset = Some(20), limit = Some(10))
- (results, count) = resultsWithCount
- dids = results.map(_._1.asCanonical)
- } yield assert(count)(equalTo(50)) && assert(dids)(hasSameElements(operations.drop(20).take(10).map(_.did)))
- },
- test("list stored dids and return correct item count when using offset only") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
- _ <- insertDIDStateWithDelay(operations, 100.millis)
- resultsWithCount <- storage.listManagedDID(offset = Some(20), limit = None)
- (results, count) = resultsWithCount
- dids = results.map(_._1)
- } yield assert(count)(equalTo(50)) && assert(dids)(hasSameElements(operations.drop(20).map(_.did)))
- },
- test("list stored dids and return correct item count when using limit only") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
- _ <- insertDIDStateWithDelay(operations, 100.millis)
- resultsWithCount <- storage.listManagedDID(offset = None, limit = Some(10))
- (results, count) = resultsWithCount
- dids = results.map(_._1)
- } yield assert(count)(equalTo(50)) && assert(dids)(hasSameElements(operations.take(10).map(_.did)))
- },
- test("return empty list when limit is zero") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
- _ <- insertDIDStateWithDelay(operations, 100.millis)
- resultsWithCount <- storage.listManagedDID(offset = None, limit = Some(0))
- (results, count) = resultsWithCount
- dids = results.map(_._1.asCanonical)
- } yield assert(count)(equalTo(50)) && assert(dids)(isEmpty)
- },
- test("fail when limit is negative") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
- _ <- insertDIDStateWithDelay(operations, 100.millis)
- exit <- storage.listManagedDID(offset = None, limit = Some(-1)).exit
- } yield assert(exit)(
- fails(
- isSubtype[PSQLException](hasField("getMessage", _.getMessage(), containsString("LIMIT must not be negative")))
- )
- )
- },
- test("fail when offset is negative") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- operations <- ZIO.foreach(1 to 50)(i => generateCreateOperation(Seq("key-1"), i).map(_._1))
- _ <- insertDIDStateWithDelay(operations, 100.millis)
- exit <- storage.listManagedDID(offset = Some(-1), limit = None).exit
- } yield assert(exit)(
- fails(
- isSubtype[PSQLException](
- hasField("getMessage", _.getMessage(), containsString("OFFSET must not be negative"))
- )
- )
- )
- }
- )
-
- private val getDIDStateSpec = suite("getManagedDIDState")(
- test("return None of state is not found") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- state <- storage.getManagedDIDState(didExample)
- } yield assert(state)(isNone)
- },
- test("return the same state that was set for all variants") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- inputs = Seq[(Int, PublicationState)](
- (1, PublicationState.Created()),
- (2, PublicationState.PublicationPending(ArraySeq.fill(32)(0))),
- (3, PublicationState.Published(ArraySeq.fill(32)(1))),
- )
- states <- ZIO.foreach(inputs) { case (didIndex, publicationState) =>
- val operation = generateCreateOperation(Seq("key-1"), didIndex).map(_._1)
- operation.map(o => ManagedDIDState(o, didIndex, publicationState))
- }
- readStates <- ZIO.foreach(states) { state =>
- for {
- _ <- storage.insertManagedDID(state.createOperation.did, state, Map.empty, Map.empty)
- readState <- storage.getManagedDIDState(state.createOperation.did)
- } yield readState
- }
- } yield assert(readStates.flatten)(hasSameElements(states))
- }
- )
-
- private val listDIDLineageSpec = {
- val initDIDLineage = {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- did1 <- initializeDIDStateAndKeys(Nil, 0)
- did2 <- initializeDIDStateAndKeys(Nil, 1)
- input = Seq(
- (did1, Array.fill[Byte](32)(0), ScheduledDIDOperationStatus.Pending),
- (did1, Array.fill[Byte](32)(1), ScheduledDIDOperationStatus.Confirmed),
- (did2, Array.fill[Byte](32)(2), ScheduledDIDOperationStatus.Pending),
- (did2, Array.fill[Byte](32)(3), ScheduledDIDOperationStatus.Confirmed),
- )
- _ <- ZIO.foreach(input) { case (did, hash, status) =>
- storage.insertDIDUpdateLineage(did, updateLineage(operationId = hash, status = status))
- }
- } yield (did1, did2)
- }
-
- suite("listDIDUpdateLineage")(
- test("initialize with empty lineage") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- lineage <- storage.listUpdateLineage(None, None)
- } yield assert(lineage)(isEmpty)
- },
- test("list all lineage") {
- for {
- _ <- initDIDLineage
- lineage <- ZIO.serviceWithZIO[DIDNonSecretStorage](_.listUpdateLineage(None, None))
- } yield assert(lineage.map(_.operationId))(
- hasSameElements(
- Seq(
- ArraySeq.fill(32)(0),
- ArraySeq.fill(32)(1),
- ArraySeq.fill(32)(2),
- ArraySeq.fill(32)(3),
- )
- )
- )
- },
- test("list lineage filtered by did") {
- for {
- did1 <- initDIDLineage.map(_._1)
- lineage <- ZIO.serviceWithZIO[DIDNonSecretStorage](_.listUpdateLineage(Some(did1), None))
- } yield assert(lineage.map(_.operationId))(
- hasSameElements(Seq(ArraySeq.fill(32)(0), ArraySeq.fill(32)(1)))
- )
- },
- test("list lineage filtered by status") {
- for {
- did1 <- initDIDLineage.map(_._1)
- lineage <- ZIO.serviceWithZIO[DIDNonSecretStorage](
- _.listUpdateLineage(None, Some(ScheduledDIDOperationStatus.Pending))
- )
- } yield assert(lineage.map(_.operationId))(
- hasSameElements(Seq(ArraySeq.fill(32)(0), ArraySeq.fill(32)(2)))
- )
- },
- test("list lineage filtered by did and status") {
- for {
- did1 <- initDIDLineage.map(_._1)
- lineage <- ZIO.serviceWithZIO[DIDNonSecretStorage](
- _.listUpdateLineage(Some(did1), Some(ScheduledDIDOperationStatus.Pending))
- )
- } yield assert(lineage.map(_.operationId))(
- hasSameElements(Seq(ArraySeq.fill(32)(0)))
- )
- }
- )
- }
-
- private val setDIDLineageStatusSpec = suite("setDIDLineageStatus")(
- test("do not fail on setting non-existing did lineage") {
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- _ <- storage.setDIDUpdateLineageStatus(Array.fill(32)(0), ScheduledDIDOperationStatus.Pending)
- } yield assertCompletes
- },
- test("set status for existing did") {
- val operationId = Array.fill[Byte](32)(42)
- for {
- storage <- ZIO.service[DIDNonSecretStorage]
- did <- initializeDIDStateAndKeys(Nil, 0)
- _ <- storage.insertDIDUpdateLineage(
- did,
- updateLineage(operationId = operationId, status = ScheduledDIDOperationStatus.Pending)
- )
- status1 <- storage.listUpdateLineage(Some(did), None).map(_.head.status)
- _ <- storage.setDIDUpdateLineageStatus(operationId, ScheduledDIDOperationStatus.Confirmed)
- status2 <- storage.listUpdateLineage(Some(did), None).map(_.head.status)
- } yield assert(status1)(equalTo(ScheduledDIDOperationStatus.Pending))
- && assert(status2)(equalTo(ScheduledDIDOperationStatus.Confirmed))
- }
- )
-
-}
diff --git a/prism-node/client/scala-client/src/main/resources/package.proto b/prism-node/client/scala-client/src/main/resources/package.proto
index c871a620f7..519ba8f9e4 100644
--- a/prism-node/client/scala-client/src/main/resources/package.proto
+++ b/prism-node/client/scala-client/src/main/resources/package.proto
@@ -1,6 +1,6 @@
syntax = "proto3";
-package io.iohk.atala.prism.protos;
+package org.hyperledger.identus.protos;
import "scalapb/scalapb.proto";
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/db/ContextAwareTask.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/db/ContextAwareTask.scala
similarity index 90%
rename from shared/core/src/main/scala/io/iohk/atala/shared/db/ContextAwareTask.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/db/ContextAwareTask.scala
index 6c9f150768..239e2b1c70 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/db/ContextAwareTask.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/db/ContextAwareTask.scala
@@ -1,11 +1,11 @@
-package io.iohk.atala.shared.db
+package org.hyperledger.identus.shared.db
import doobie.*
import doobie.postgres.implicits.*
import doobie.syntax.ConnectionIOOps
import doobie.util.transactor.Transactor
-import io.iohk.atala.shared.models.WalletAccessContext
-import io.iohk.atala.shared.models.WalletId
+import org.hyperledger.identus.shared.models.WalletAccessContext
+import org.hyperledger.identus.shared.models.WalletId
import zio.*
import zio.interop.catz.*
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/db/DbConfig.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/db/DbConfig.scala
similarity index 74%
rename from shared/core/src/main/scala/io/iohk/atala/shared/db/DbConfig.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/db/DbConfig.scala
index c28cf69263..69fcb6897d 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/db/DbConfig.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/db/DbConfig.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.db
+package org.hyperledger.identus.shared.db
case class DbConfig(
username: String,
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/db/TransactorLayer.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/db/TransactorLayer.scala
similarity index 98%
rename from shared/core/src/main/scala/io/iohk/atala/shared/db/TransactorLayer.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/db/TransactorLayer.scala
index fdbb6164a5..fdd23d41ac 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/db/TransactorLayer.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/db/TransactorLayer.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.db
+package org.hyperledger.identus.shared.db
import cats.effect.Async
import cats.effect.kernel.Resource
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/http/GenericUriResolver.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/http/GenericUriResolver.scala
similarity index 97%
rename from shared/core/src/main/scala/io/iohk/atala/shared/http/GenericUriResolver.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/http/GenericUriResolver.scala
index 737d17b35b..46d1b57e3c 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/http/GenericUriResolver.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/http/GenericUriResolver.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.http
+package org.hyperledger.identus.shared.http
import zio.*
import io.lemonlabs.uri.{DataUrl, Uri, Url, Urn}
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/models/Base64UrlString.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/models/Base64UrlString.scala
similarity index 83%
rename from shared/core/src/main/scala/io/iohk/atala/shared/models/Base64UrlString.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/models/Base64UrlString.scala
index 957bc9771d..ca418cc426 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/models/Base64UrlString.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/models/Base64UrlString.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.shared.models
+package org.hyperledger.identus.shared.models
-import io.iohk.atala.shared.utils.Base64Utils
+import org.hyperledger.identus.shared.utils.Base64Utils
import scala.util.Try
opaque type Base64UrlString = String
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/models/Failure.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/models/Failure.scala
similarity index 86%
rename from shared/core/src/main/scala/io/iohk/atala/shared/models/Failure.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/models/Failure.scala
index c116a78da5..770108ffa0 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/models/Failure.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/models/Failure.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.models
+package org.hyperledger.identus.shared.models
trait Failure {
val statusCode: StatusCode
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/models/HexString.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/models/HexString.scala
similarity index 80%
rename from shared/core/src/main/scala/io/iohk/atala/shared/models/HexString.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/models/HexString.scala
index 333b79bb5e..92dc6641f6 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/models/HexString.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/models/HexString.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.shared.models
+package org.hyperledger.identus.shared.models
-import io.iohk.atala.shared.utils.BytesOps
+import org.hyperledger.identus.shared.utils.BytesOps
import scala.util.Try
opaque type HexString = String
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/models/MultiTenancy.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/models/MultiTenancy.scala
similarity index 96%
rename from shared/core/src/main/scala/io/iohk/atala/shared/models/MultiTenancy.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/models/MultiTenancy.scala
index 87f2d87995..f16719d258 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/models/MultiTenancy.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/models/MultiTenancy.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.models
+package org.hyperledger.identus.shared.models
import java.util.UUID
import scala.language.implicitConversions
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/utils/Base64Utils.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/Base64Utils.scala
similarity index 92%
rename from shared/core/src/main/scala/io/iohk/atala/shared/utils/Base64Utils.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/utils/Base64Utils.scala
index bc1449736b..6de319955b 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/utils/Base64Utils.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/Base64Utils.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.utils
+package org.hyperledger.identus.shared.utils
import java.nio.charset.StandardCharsets
import java.util.Base64
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/utils/BytesOps.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/BytesOps.scala
similarity index 94%
rename from shared/core/src/main/scala/io/iohk/atala/shared/utils/BytesOps.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/utils/BytesOps.scala
index afc5c4dabc..14032fb258 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/utils/BytesOps.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/BytesOps.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.utils
+package org.hyperledger.identus.shared.utils
import java.nio.charset.StandardCharsets
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/utils/DurationOps.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/DurationOps.scala
similarity index 75%
rename from shared/core/src/main/scala/io/iohk/atala/shared/utils/DurationOps.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/utils/DurationOps.scala
index f377973895..f5f297862e 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/utils/DurationOps.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/DurationOps.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.utils
+package org.hyperledger.identus.shared.utils
import java.time.Duration
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/utils/Json.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/Json.scala
similarity index 91%
rename from shared/core/src/main/scala/io/iohk/atala/shared/utils/Json.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/utils/Json.scala
index 2607ddf997..d7ddbb5670 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/utils/Json.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/Json.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.utils
+package org.hyperledger.identus.shared.utils
import org.erdtman.jcs.JsonCanonicalizer
import scala.util.Try
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/utils/Traverse.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/Traverse.scala
similarity index 91%
rename from shared/core/src/main/scala/io/iohk/atala/shared/utils/Traverse.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/utils/Traverse.scala
index 5b66d85356..422a6b7031 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/utils/Traverse.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/Traverse.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.utils
+package org.hyperledger.identus.shared.utils
/** A lightweight DIY version of traverse to not rely on Cats because Scala3 + Cats implicits break the IDE compile
* server making the development counterproductive.
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/utils/aspects/CustomMetricsAspect.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/aspects/CustomMetricsAspect.scala
similarity index 92%
rename from shared/core/src/main/scala/io/iohk/atala/shared/utils/aspects/CustomMetricsAspect.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/utils/aspects/CustomMetricsAspect.scala
index 6c5515b2fc..946888ebea 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/utils/aspects/CustomMetricsAspect.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/aspects/CustomMetricsAspect.scala
@@ -1,10 +1,10 @@
-package io.iohk.atala.shared.utils.aspects
+package org.hyperledger.identus.shared.utils.aspects
import zio.*
import scala.collection.mutable.{Map => MutMap}
import zio.metrics.*
import java.time.{Instant, Clock, Duration}
-import io.iohk.atala.shared.utils.DurationOps.toMetricsSeconds
+import org.hyperledger.identus.shared.utils.DurationOps.toMetricsSeconds
object CustomMetricsAspect {
private val checkpoints: MutMap[String, Instant] = MutMap.empty
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/utils/proto/Path.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/proto/Path.scala
similarity index 86%
rename from shared/core/src/main/scala/io/iohk/atala/shared/utils/proto/Path.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/utils/proto/Path.scala
index 3bec54da43..ff1d9699d7 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/utils/proto/Path.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/proto/Path.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.utils.proto
+package org.hyperledger.identus.shared.utils.proto
/** Representation of sequence of field names pointing to some place in protobuf message
*/
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/utils/proto/ValidationError.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/proto/ValidationError.scala
similarity index 94%
rename from shared/core/src/main/scala/io/iohk/atala/shared/utils/proto/ValidationError.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/utils/proto/ValidationError.scala
index def7687381..ee78c93ada 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/utils/proto/ValidationError.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/proto/ValidationError.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.utils.proto
+package org.hyperledger.identus.shared.utils.proto
sealed trait ValidationError {
def name: String
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/utils/proto/package.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/proto/package.scala
similarity index 95%
rename from shared/core/src/main/scala/io/iohk/atala/shared/utils/proto/package.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/utils/proto/package.scala
index 31cf1161ac..76d129e0ab 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/utils/proto/package.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/utils/proto/package.scala
@@ -1,7 +1,7 @@
-package io.iohk.atala.shared.utils
+package org.hyperledger.identus.shared.utils
import com.google.protobuf.ByteString
-import io.iohk.atala.shared.utils.proto.ValidationError.{InvalidValue, MissingValue}
+import org.hyperledger.identus.shared.utils.proto.ValidationError.{InvalidValue, MissingValue}
package object proto {
diff --git a/shared/core/src/main/scala/io/iohk/atala/shared/validation/ValidationUtils.scala b/shared/core/src/main/scala/org/hyperledger/identus/shared/validation/ValidationUtils.scala
similarity index 90%
rename from shared/core/src/main/scala/io/iohk/atala/shared/validation/ValidationUtils.scala
rename to shared/core/src/main/scala/org/hyperledger/identus/shared/validation/ValidationUtils.scala
index 6456c0e5c4..455ef82e88 100644
--- a/shared/core/src/main/scala/io/iohk/atala/shared/validation/ValidationUtils.scala
+++ b/shared/core/src/main/scala/org/hyperledger/identus/shared/validation/ValidationUtils.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.validation
+package org.hyperledger.identus.shared.validation
import zio.prelude.*
diff --git a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Apollo.scala b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/Apollo.scala
similarity index 97%
rename from shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Apollo.scala
rename to shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/Apollo.scala
index a342fa62d0..8651df618d 100644
--- a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Apollo.scala
+++ b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/Apollo.scala
@@ -1,6 +1,6 @@
-package io.iohk.atala.shared.crypto
+package org.hyperledger.identus.shared.crypto
-import io.iohk.atala.shared.models.HexString
+import org.hyperledger.identus.shared.models.HexString
import org.bouncycastle.jce.ECNamedCurveTable
import org.bouncycastle.jce.provider.BouncyCastleProvider
import org.bouncycastle.jce.spec.ECNamedCurveSpec
diff --git a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/KmpApollo.scala b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/KmpApollo.scala
similarity index 99%
rename from shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/KmpApollo.scala
rename to shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/KmpApollo.scala
index 5cc85400c6..4d043521fd 100644
--- a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/KmpApollo.scala
+++ b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/KmpApollo.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.crypto
+package org.hyperledger.identus.shared.crypto
import io.iohk.atala.prism.apollo.derivation
import io.iohk.atala.prism.apollo.derivation.MnemonicHelper
diff --git a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Prism14Apollo.scala b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/Prism14Apollo.scala
similarity index 98%
rename from shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Prism14Apollo.scala
rename to shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/Prism14Apollo.scala
index 37e049c386..6501618619 100644
--- a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/Prism14Apollo.scala
+++ b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/Prism14Apollo.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.shared.crypto
+package org.hyperledger.identus.shared.crypto
import io.iohk.atala.prism.crypto.EC
import io.iohk.atala.prism.crypto.derivation.DerivationAxis
diff --git a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/jwk/JWK.scala b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/jwk/JWK.scala
similarity index 95%
rename from shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/jwk/JWK.scala
rename to shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/jwk/JWK.scala
index 1e4050a121..fb6e7167e4 100644
--- a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/jwk/JWK.scala
+++ b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/jwk/JWK.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.shared.crypto.jwk
+package org.hyperledger.identus.shared.crypto.jwk
import com.nimbusds.jose.jwk.Curve
import com.nimbusds.jose.jwk.OctetKeyPair
import com.nimbusds.jose.util.Base64URL
-import io.iohk.atala.shared.crypto.*
+import org.hyperledger.identus.shared.crypto.*
import zio.json.*
import zio.json.ast.Json
diff --git a/shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpec.scala b/shared/crypto/src/test/scala/org/hyperledger/identus/shared/crypto/ApolloSpec.scala
similarity index 99%
rename from shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpec.scala
rename to shared/crypto/src/test/scala/org/hyperledger/identus/shared/crypto/ApolloSpec.scala
index c6bd785e43..94cd37ca2b 100644
--- a/shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpec.scala
+++ b/shared/crypto/src/test/scala/org/hyperledger/identus/shared/crypto/ApolloSpec.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.shared.crypto
+package org.hyperledger.identus.shared.crypto
import zio.*
import zio.test.*
import zio.test.Assertion.*
-import io.iohk.atala.shared.models.HexString
+import org.hyperledger.identus.shared.models.HexString
object ApolloSpec extends ZIOSpecDefault {
diff --git a/shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpecHelper.scala b/shared/crypto/src/test/scala/org/hyperledger/identus/shared/crypto/ApolloSpecHelper.scala
similarity index 60%
rename from shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpecHelper.scala
rename to shared/crypto/src/test/scala/org/hyperledger/identus/shared/crypto/ApolloSpecHelper.scala
index 98e278a6dc..baff9c483f 100644
--- a/shared/crypto/src/test/scala/io/iohk/atala/shared/crypto/ApolloSpecHelper.scala
+++ b/shared/crypto/src/test/scala/org/hyperledger/identus/shared/crypto/ApolloSpecHelper.scala
@@ -1,6 +1,7 @@
-package io.iohk.atala.shared.crypto
+package org.hyperledger.identus.shared.crypto
import zio.*
+import org.hyperledger.identus.shared.crypto.Apollo
trait ApolloSpecHelper {
protected val apollo: Apollo = Apollo.default
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakContainerCustom.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakContainerCustom.scala
index f39af6f44c..ab8344f56d 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakContainerCustom.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakContainerCustom.scala
@@ -1,8 +1,8 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import com.dimafeng.testcontainers.SingleContainer
import dasniko.testcontainers.keycloak.ExtendableKeycloakContainer
-import io.iohk.atala.sharedtest.containers.KeycloakTestContainer.keycloakContainer
+import org.hyperledger.identus.sharedtest.containers.KeycloakTestContainer.keycloakContainer
import org.testcontainers.utility.DockerImageName
import zio.{TaskLayer, ZIO, ZLayer}
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainer.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainer.scala
index 4ac35afc86..b8568422d9 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainer.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainer.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import org.testcontainers.utility.DockerImageName
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainerSupport.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainerSupport.scala
index 53b2a66f8a..506d4673f4 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainerSupport.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainerSupport.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import org.keycloak.admin.client.Keycloak
import org.keycloak.representations.idm.{
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainerSupportSpec.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainerSupportSpec.scala
index 46722b6641..599209341f 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainerSupportSpec.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/KeycloakTestContainerSupportSpec.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import zio.ZIO
import zio.test.*
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgreSQLContainerCustom.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgreSQLContainerCustom.scala
index b77d3094e6..f29b677e29 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgreSQLContainerCustom.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgreSQLContainerCustom.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import com.dimafeng.testcontainers.{JdbcDatabaseContainer, PostgreSQLContainer}
import org.testcontainers.utility.DockerImageName
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresLayer.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresLayer.scala
index 0a7b3912eb..7bc3e3727e 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresLayer.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresLayer.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import com.dimafeng.testcontainers.PostgreSQLContainer
import doobie.util.transactor.Transactor
-import io.iohk.atala.shared.db.{ContextAwareTask, DbConfig, TransactorLayer}
-import io.iohk.atala.sharedtest.containers.PostgresTestContainer.postgresContainer
+import org.hyperledger.identus.shared.db.{ContextAwareTask, DbConfig, TransactorLayer}
+import org.hyperledger.identus.sharedtest.containers.PostgresTestContainer.postgresContainer
import zio.*
object PostgresLayer {
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresTestContainer.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresTestContainer.scala
index 546b44804f..e5581b1296 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresTestContainer.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresTestContainer.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import com.dimafeng.testcontainers.PostgreSQLContainer
import org.testcontainers.containers.output.OutputFrame
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresTestContainerSupport.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresTestContainerSupport.scala
index 2527765319..0530a619d9 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresTestContainerSupport.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/PostgresTestContainerSupport.scala
@@ -1,9 +1,9 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import com.dimafeng.testcontainers.PostgreSQLContainer
import doobie.util.transactor.Transactor
-import io.iohk.atala.shared.db.ContextAwareTask
-import io.iohk.atala.shared.db.TransactorLayer
+import org.hyperledger.identus.shared.db.ContextAwareTask
+import org.hyperledger.identus.shared.db.TransactorLayer
import zio.*
trait PostgresTestContainerSupport {
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/VaultContainerCustom.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/VaultContainerCustom.scala
index 6265b031a9..b5bc783506 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/VaultContainerCustom.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/VaultContainerCustom.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import com.dimafeng.testcontainers.{SingleContainer, VaultContainer}
import org.testcontainers.vault.{VaultContainer => JavaVaultContainer}
diff --git a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/VaultTestContainer.scala b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/VaultTestContainer.scala
index f7e8f9adf1..c43edcb4ae 100644
--- a/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/VaultTestContainer.scala
+++ b/shared/test/src/test/scala/io/iohk/atala/sharedtest/containers/VaultTestContainer.scala
@@ -1,4 +1,4 @@
-package io.iohk.atala.sharedtest.containers
+package org.hyperledger.identus.sharedtest.containers
import org.testcontainers.containers.output.OutputFrame
import org.testcontainers.utility.DockerImageName
diff --git a/tests/performance-tests/atala-performance-tests-k6/.babelrc b/tests/performance-tests/agent-performance-tests-k6/.babelrc
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/.babelrc
rename to tests/performance-tests/agent-performance-tests-k6/.babelrc
diff --git a/tests/performance-tests/atala-performance-tests-k6/.env b/tests/performance-tests/agent-performance-tests-k6/.env
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/.env
rename to tests/performance-tests/agent-performance-tests-k6/.env
diff --git a/tests/performance-tests/atala-performance-tests-k6/.gitignore b/tests/performance-tests/agent-performance-tests-k6/.gitignore
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/.gitignore
rename to tests/performance-tests/agent-performance-tests-k6/.gitignore
diff --git a/tests/performance-tests/atala-performance-tests-k6/.npmrc b/tests/performance-tests/agent-performance-tests-k6/.npmrc
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/.npmrc
rename to tests/performance-tests/agent-performance-tests-k6/.npmrc
diff --git a/tests/performance-tests/atala-performance-tests-k6/.yarnrc b/tests/performance-tests/agent-performance-tests-k6/.yarnrc
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/.yarnrc
rename to tests/performance-tests/agent-performance-tests-k6/.yarnrc
diff --git a/tests/performance-tests/atala-performance-tests-k6/README.md b/tests/performance-tests/agent-performance-tests-k6/README.md
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/README.md
rename to tests/performance-tests/agent-performance-tests-k6/README.md
diff --git a/tests/performance-tests/atala-performance-tests-k6/package.json b/tests/performance-tests/agent-performance-tests-k6/package.json
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/package.json
rename to tests/performance-tests/agent-performance-tests-k6/package.json
diff --git a/tests/performance-tests/atala-performance-tests-k6/run.sh b/tests/performance-tests/agent-performance-tests-k6/run.sh
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/run.sh
rename to tests/performance-tests/agent-performance-tests-k6/run.sh
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/actors/Actor.ts b/tests/performance-tests/agent-performance-tests-k6/src/actors/Actor.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/actors/Actor.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/actors/Actor.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/actors/Holder.ts b/tests/performance-tests/agent-performance-tests-k6/src/actors/Holder.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/actors/Holder.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/actors/Holder.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/actors/Issuer.ts b/tests/performance-tests/agent-performance-tests-k6/src/actors/Issuer.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/actors/Issuer.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/actors/Issuer.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/actors/Verifier.ts b/tests/performance-tests/agent-performance-tests-k6/src/actors/Verifier.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/actors/Verifier.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/actors/Verifier.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/actors/index.ts b/tests/performance-tests/agent-performance-tests-k6/src/actors/index.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/actors/index.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/actors/index.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/common/Config.ts b/tests/performance-tests/agent-performance-tests-k6/src/common/Config.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/common/Config.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/common/Config.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/common/ConnectionService.ts b/tests/performance-tests/agent-performance-tests-k6/src/common/ConnectionService.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/common/ConnectionService.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/common/ConnectionService.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/common/CredentialsService.ts b/tests/performance-tests/agent-performance-tests-k6/src/common/CredentialsService.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/common/CredentialsService.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/common/CredentialsService.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/common/DidService.ts b/tests/performance-tests/agent-performance-tests-k6/src/common/DidService.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/common/DidService.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/common/DidService.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/common/HttpService.ts b/tests/performance-tests/agent-performance-tests-k6/src/common/HttpService.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/common/HttpService.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/common/HttpService.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/common/ProofsService.ts b/tests/performance-tests/agent-performance-tests-k6/src/common/ProofsService.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/common/ProofsService.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/common/ProofsService.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/k6chaijs.js b/tests/performance-tests/agent-performance-tests-k6/src/k6chaijs.js
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/k6chaijs.js
rename to tests/performance-tests/agent-performance-tests-k6/src/k6chaijs.js
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/scenarios/default.ts b/tests/performance-tests/agent-performance-tests-k6/src/scenarios/default.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/scenarios/default.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/scenarios/default.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/tests/common.ts b/tests/performance-tests/agent-performance-tests-k6/src/tests/common.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/tests/common.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/tests/common.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/tests/credentials/credential-definition-test.ts b/tests/performance-tests/agent-performance-tests-k6/src/tests/credentials/credential-definition-test.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/tests/credentials/credential-definition-test.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/tests/credentials/credential-definition-test.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/tests/credentials/credential-offer-test.ts b/tests/performance-tests/agent-performance-tests-k6/src/tests/credentials/credential-offer-test.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/tests/credentials/credential-offer-test.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/tests/credentials/credential-offer-test.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/tests/credentials/credential-schema-test.ts b/tests/performance-tests/agent-performance-tests-k6/src/tests/credentials/credential-schema-test.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/tests/credentials/credential-schema-test.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/tests/credentials/credential-schema-test.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/tests/dids/create-prism-did-test.ts b/tests/performance-tests/agent-performance-tests-k6/src/tests/dids/create-prism-did-test.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/tests/dids/create-prism-did-test.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/tests/dids/create-prism-did-test.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/tests/dids/did-publishing-test.ts b/tests/performance-tests/agent-performance-tests-k6/src/tests/dids/did-publishing-test.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/tests/dids/did-publishing-test.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/tests/dids/did-publishing-test.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/tests/flows/connection-flow-test.ts b/tests/performance-tests/agent-performance-tests-k6/src/tests/flows/connection-flow-test.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/tests/flows/connection-flow-test.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/tests/flows/connection-flow-test.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/tests/flows/issuance-flow-test.ts b/tests/performance-tests/agent-performance-tests-k6/src/tests/flows/issuance-flow-test.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/tests/flows/issuance-flow-test.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/tests/flows/issuance-flow-test.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/src/tests/flows/present-proof-flow-test.ts b/tests/performance-tests/agent-performance-tests-k6/src/tests/flows/present-proof-flow-test.ts
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/src/tests/flows/present-proof-flow-test.ts
rename to tests/performance-tests/agent-performance-tests-k6/src/tests/flows/present-proof-flow-test.ts
diff --git a/tests/performance-tests/atala-performance-tests-k6/tsconfig.json b/tests/performance-tests/agent-performance-tests-k6/tsconfig.json
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/tsconfig.json
rename to tests/performance-tests/agent-performance-tests-k6/tsconfig.json
diff --git a/tests/performance-tests/atala-performance-tests-k6/webpack.config.js b/tests/performance-tests/agent-performance-tests-k6/webpack.config.js
similarity index 96%
rename from tests/performance-tests/atala-performance-tests-k6/webpack.config.js
rename to tests/performance-tests/agent-performance-tests-k6/webpack.config.js
index 94fe2bcdff..cc145ae88c 100644
--- a/tests/performance-tests/atala-performance-tests-k6/webpack.config.js
+++ b/tests/performance-tests/agent-performance-tests-k6/webpack.config.js
@@ -24,7 +24,7 @@ module.exports = {
],
},
target: 'web',
- externals: /^(k6|https?\:\/\/)(\/.*)?/,
+ externals: /^(k6|https?:\/\/)(\/.*)?/,
// Generate map files for compiled scripts
devtool: "source-map",
stats: {
diff --git a/tests/performance-tests/atala-performance-tests-k6/yarn.lock b/tests/performance-tests/agent-performance-tests-k6/yarn.lock
similarity index 100%
rename from tests/performance-tests/atala-performance-tests-k6/yarn.lock
rename to tests/performance-tests/agent-performance-tests-k6/yarn.lock
diff --git a/tests/performance-tests/prism-performance-tests/.gitignore b/tests/performance-tests/agent-performance-tests/.gitignore
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/.gitignore
rename to tests/performance-tests/agent-performance-tests/.gitignore
diff --git a/tests/performance-tests/prism-performance-tests/README.md b/tests/performance-tests/agent-performance-tests/README.md
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/README.md
rename to tests/performance-tests/agent-performance-tests/README.md
diff --git a/tests/performance-tests/prism-performance-tests/src/gatling/kotlin/common/Configuration.kt b/tests/performance-tests/agent-performance-tests/bin/gatling/common/Configuration.kt
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/src/gatling/kotlin/common/Configuration.kt
rename to tests/performance-tests/agent-performance-tests/bin/gatling/common/Configuration.kt
diff --git a/tests/performance-tests/prism-performance-tests/src/gatling/kotlin/common/Utils.kt b/tests/performance-tests/agent-performance-tests/bin/gatling/common/Utils.kt
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/src/gatling/kotlin/common/Utils.kt
rename to tests/performance-tests/agent-performance-tests/bin/gatling/common/Utils.kt
diff --git a/tests/performance-tests/prism-performance-tests/src/gatling/resources/gatling.conf b/tests/performance-tests/agent-performance-tests/bin/gatling/gatling.conf
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/src/gatling/resources/gatling.conf
rename to tests/performance-tests/agent-performance-tests/bin/gatling/gatling.conf
diff --git a/tests/performance-tests/prism-performance-tests/src/gatling/kotlin/simulations/ConnectionSimulation.kt b/tests/performance-tests/agent-performance-tests/bin/gatling/simulations/ConnectionSimulation.kt
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/src/gatling/kotlin/simulations/ConnectionSimulation.kt
rename to tests/performance-tests/agent-performance-tests/bin/gatling/simulations/ConnectionSimulation.kt
diff --git a/tests/performance-tests/prism-performance-tests/src/gatling/kotlin/simulations/IssuanceSimulation.kt b/tests/performance-tests/agent-performance-tests/bin/gatling/simulations/IssuanceSimulation.kt
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/src/gatling/kotlin/simulations/IssuanceSimulation.kt
rename to tests/performance-tests/agent-performance-tests/bin/gatling/simulations/IssuanceSimulation.kt
diff --git a/tests/performance-tests/prism-performance-tests/src/gatling/kotlin/steps/ConnectionSteps.kt b/tests/performance-tests/agent-performance-tests/bin/gatling/steps/ConnectionSteps.kt
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/src/gatling/kotlin/steps/ConnectionSteps.kt
rename to tests/performance-tests/agent-performance-tests/bin/gatling/steps/ConnectionSteps.kt
diff --git a/tests/performance-tests/prism-performance-tests/src/gatling/kotlin/steps/IssuanceSteps.kt b/tests/performance-tests/agent-performance-tests/bin/gatling/steps/IssuanceSteps.kt
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/src/gatling/kotlin/steps/IssuanceSteps.kt
rename to tests/performance-tests/agent-performance-tests/bin/gatling/steps/IssuanceSteps.kt
diff --git a/tests/performance-tests/prism-performance-tests/build.gradle.kts b/tests/performance-tests/agent-performance-tests/build.gradle.kts
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/build.gradle.kts
rename to tests/performance-tests/agent-performance-tests/build.gradle.kts
diff --git a/tests/performance-tests/prism-performance-tests/gradle.properties b/tests/performance-tests/agent-performance-tests/gradle.properties
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/gradle.properties
rename to tests/performance-tests/agent-performance-tests/gradle.properties
diff --git a/tests/performance-tests/prism-performance-tests/gradle/wrapper/gradle-wrapper.jar b/tests/performance-tests/agent-performance-tests/gradle/wrapper/gradle-wrapper.jar
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/gradle/wrapper/gradle-wrapper.jar
rename to tests/performance-tests/agent-performance-tests/gradle/wrapper/gradle-wrapper.jar
diff --git a/tests/performance-tests/prism-performance-tests/gradle/wrapper/gradle-wrapper.properties b/tests/performance-tests/agent-performance-tests/gradle/wrapper/gradle-wrapper.properties
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/gradle/wrapper/gradle-wrapper.properties
rename to tests/performance-tests/agent-performance-tests/gradle/wrapper/gradle-wrapper.properties
diff --git a/tests/performance-tests/prism-performance-tests/gradlew b/tests/performance-tests/agent-performance-tests/gradlew
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/gradlew
rename to tests/performance-tests/agent-performance-tests/gradlew
diff --git a/tests/performance-tests/prism-performance-tests/gradlew.bat b/tests/performance-tests/agent-performance-tests/gradlew.bat
similarity index 100%
rename from tests/performance-tests/prism-performance-tests/gradlew.bat
rename to tests/performance-tests/agent-performance-tests/gradlew.bat
diff --git a/tests/performance-tests/agent-performance-tests/settings.gradle.kts b/tests/performance-tests/agent-performance-tests/settings.gradle.kts
new file mode 100644
index 0000000000..c0ded08875
--- /dev/null
+++ b/tests/performance-tests/agent-performance-tests/settings.gradle.kts
@@ -0,0 +1,3 @@
+
+rootProject.name = "agent-performance-tests"
+
diff --git a/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/common/Configuration.kt b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/common/Configuration.kt
new file mode 100644
index 0000000000..c7e2a8b14d
--- /dev/null
+++ b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/common/Configuration.kt
@@ -0,0 +1,45 @@
+package common
+
+import java.util.logging.Level
+
+/**
+ * Configuration for simulations running
+ */
+object Configuration {
+ // Issuer agent
+ val ISSUER_AGENT_URL = System.getenv("ISSUER_AGENT_URL") ?: "http://localhost:8080/prism-agent"
+ val ISSUER_AGENT_API_KEY: String = System.getenv("ISSUER_AGENT_API_KEY") ?: ""
+
+ // Holder agent
+ val HOLDER_AGENT_URL = System.getenv("HOLDER_AGENT_URL") ?: "http://localhost:8090/prism-agent"
+ val HOLDER_AGENT_API_KEY: String = System.getenv("HOLDER_AGENT_API_KEY") ?: ""
+
+ // Verbose debugging mode
+ val LOGGER_LEVEL: Level = if (System.getenv("VERBOSE_SIMULATION").toBoolean()) Level.INFO else Level.WARNING
+
+ // Interval between executing requests while waiting for some condition to happen, seconds
+ const val WAITING_LOOP_PAUSE_INTERVAL: Long = 2L
+
+ // Max iterations of `WAITING_LOOP_PAUSE_INTERVAL` to wait until exit the session
+ const val WAITING_LOOP_MAX_ITERATIONS: Int = 15
+
+ // Name of the counter in the waiting loop
+ const val WAITING_LOOP_COUNTER_NAME: String = "counter"
+
+ // Random credential to be issued during benchmarks
+ // it depends on holderDid session variable (!)
+ val RANDOM_CREDENTIAL: String =
+ """{
+ "schemaId": "schema:1234",
+ "subjectId": "#{holderDid}",
+ "validityPeriod": 3600,
+ "claims": {
+ "prop1": "value1",
+ "prop2": "value2",
+ "prop3": "value3"
+ },
+ "automaticIssuance": false,
+ "awaitConfirmation": false
+ }
+ """.trimIndent()
+}
diff --git a/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/common/Utils.kt b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/common/Utils.kt
new file mode 100644
index 0000000000..27d92cf981
--- /dev/null
+++ b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/common/Utils.kt
@@ -0,0 +1,35 @@
+package common
+
+import java.util.logging.Logger
+
+object Utils {
+
+ /**
+ * Lazy custom logger for any class
+ *
+ * Example of usage:
+ * `val logger by Utils.logger("Connection Steps")`
+ *
+ * @param name Logger name
+ * @return Logger instance
+ */
+ fun R.logger(name: String = this.javaClass.name): Lazy {
+ return lazy {
+ val LOG = Logger.getLogger(name)
+ LOG.level = Configuration.LOGGER_LEVEL
+ LOG
+ }
+ }
+
+ /**
+ * Extracts out-of-band (OOB) invitation from full Connection invitation URL
+ *
+ * Used in Connection protocol of PRISM Agent to get only required OOB part
+ *
+ * @param fullUrl
+ * @return OOB invitation ready to be used in POST request for Prism Agent
+ */
+ fun extractOutOfBandInvitationFromUrl(fullUrl: String): String {
+ return fullUrl.split("=")[1]
+ }
+}
diff --git a/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/simulations/ConnectionSimulation.kt b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/simulations/ConnectionSimulation.kt
new file mode 100644
index 0000000000..0e461e663a
--- /dev/null
+++ b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/simulations/ConnectionSimulation.kt
@@ -0,0 +1,26 @@
+package simulations
+
+import io.gatling.javaapi.core.*
+import io.gatling.javaapi.core.CoreDsl.*
+import steps.ConnectionSteps
+
+/**
+ * Simulation for Atala PRISM V2 Connection protocol
+ */
+class ConnectionSimulation : Simulation() {
+
+ private val settingUpConnection = scenario("Setting up connection").exec(
+ ConnectionSteps.generateInvitation(),
+ ConnectionSteps.inviteeSendsConnectionRequest(),
+ ConnectionSteps.inviterReceivesTheConnectionRequestAndSendsTheConnectionResponseToInvitee(),
+ ConnectionSteps.inviteeAchievesConnectionResponse()
+ )
+
+ init {
+ setUp(
+ settingUpConnection
+ .injectOpen(rampUsers(1)
+ .during(1))
+ )
+ }
+}
diff --git a/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/simulations/IssuanceSimulation.kt b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/simulations/IssuanceSimulation.kt
new file mode 100644
index 0000000000..b821cdb5e0
--- /dev/null
+++ b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/simulations/IssuanceSimulation.kt
@@ -0,0 +1,34 @@
+package simulations
+
+import io.gatling.javaapi.core.*
+import io.gatling.javaapi.core.CoreDsl.*
+import steps.ConnectionSteps
+import steps.IssuanceSteps
+
+/**
+ * Simulation for Atala PRISM V2 Credential Issuance protocol
+ */
+class IssuanceSimulation : Simulation() {
+
+ private val issuingCredential = scenario("Issuing a credential").exec(
+ ConnectionSteps.generateInvitation(),
+ ConnectionSteps.inviteeSendsConnectionRequest(),
+ ConnectionSteps.inviterReceivesTheConnectionRequestAndSendsTheConnectionResponseToInvitee(),
+ ConnectionSteps.inviteeAchievesConnectionResponse(),
+ IssuanceSteps.issuerOffersACredential(),
+ IssuanceSteps.holderAwaitsCredentialOffer(),
+ IssuanceSteps.holderRequestsCredential(),
+ IssuanceSteps.issuerReceivesRequest(),
+ IssuanceSteps.issuerIssuesCredential(),
+ IssuanceSteps.issuerWaitsCredentialIssued(),
+ IssuanceSteps.holderAwaitsCredentialReceived()
+ )
+
+ init {
+ setUp(
+ issuingCredential
+ .injectOpen(rampUsers(1)
+ .during(1))
+ )
+ }
+}
diff --git a/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/steps/ConnectionSteps.kt b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/steps/ConnectionSteps.kt
new file mode 100644
index 0000000000..e983651578
--- /dev/null
+++ b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/steps/ConnectionSteps.kt
@@ -0,0 +1,181 @@
+package steps
+
+import common.Configuration
+import common.Configuration.WAITING_LOOP_COUNTER_NAME
+import common.Configuration.WAITING_LOOP_MAX_ITERATIONS
+import common.Configuration.WAITING_LOOP_PAUSE_INTERVAL
+import common.Utils
+import common.Utils.extractOutOfBandInvitationFromUrl
+import common.Utils.logger
+import io.gatling.javaapi.core.ChainBuilder
+import io.gatling.javaapi.core.CoreDsl.*
+import io.gatling.javaapi.http.HttpDsl.*
+import java.net.HttpURLConnection.HTTP_CREATED
+import java.net.HttpURLConnection.HTTP_OK
+
+object ConnectionSteps {
+
+ private val logger by Utils.logger("Connection Steps")
+
+ /**
+ * Generates a Connection invitation
+ *
+ * Function saves the following session variables to global virtual session user state:
+ * "invitationUrl" - invitation URL to be used next by the holder
+ * "inviterConnectionId" - connection ID for the inviter
+ *
+ * @param url URL of a PRISM Agent
+ * @param apikey secret access api key
+ * @param label Connection invitation label
+ * @return Builder of a Gatling chain of Actions to be used in Gatling Simulation
+ */
+ fun generateInvitation(
+ url: String = Configuration.ISSUER_AGENT_URL,
+ apikey: String = Configuration.ISSUER_AGENT_API_KEY,
+ label: String = "test"
+ ): ChainBuilder =
+ exec(
+ http("Inviter generates connection invitation")
+ .post("$url/connections")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .body(StringBody("""{"label": "$label"}"""))
+ .check(
+ status().shouldBe(HTTP_CREATED),
+ jsonPath("$.invitation.invitationUrl").find().saveAs("invitationUrl"),
+ jsonPath("$.connectionId").find().saveAs("inviterConnectionId")
+ )
+ ).exec { session ->
+ logger.info("Inviter connection ID: ${session.getString("inviterConnectionId")}")
+ session
+ }.exitHereIfFailed()
+
+
+ /**
+ * Invitee sends a connection request using invitor invitationUrl
+ *
+ * Uses `invitationUrl` achieved by executing `generateInvitation` function
+ *
+ * @param url URL of a PRISM Agent
+ * @param apikey secret access api key
+ * @return Builder of a Gatling chain of Actions to be used in Gatling Simulation
+ */
+ fun inviteeSendsConnectionRequest(
+ url: String = Configuration.HOLDER_AGENT_URL,
+ apikey: String = Configuration.HOLDER_AGENT_API_KEY
+ ): ChainBuilder =
+ exec(
+ http("Invitee sends a connection request")
+ .post("$url/connection-invitations")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .body(
+ StringBody { session ->
+ """{ "invitation": "${extractOutOfBandInvitationFromUrl(session.getString("invitationUrl")!!)}" }"""
+ }
+ )
+ .check(
+ status().shouldBe(HTTP_OK),
+ jsonPath("$.connectionId").find().saveAs("inviteeConnectionId"),
+ jsonPath("$.myDid").find().saveAs("holderDid")
+ )
+ ).exec { session ->
+ logger.info("Invitee connection ID: ${session.getString("inviteeConnectionId")}")
+ session
+ }.exitHereIfFailed()
+
+ /**
+ * Inviter receives the connection request and sends the connection response to invitee
+ *
+ * @param url URL of a PRISM Agent
+ * @param apikey secret access api key
+ * @return Builder of a Gatling chain of Actions to be used in Gatling Simulation
+ */
+ fun inviterReceivesTheConnectionRequestAndSendsTheConnectionResponseToInvitee(
+ url: String = Configuration.ISSUER_AGENT_URL,
+ apikey: String = Configuration.ISSUER_AGENT_API_KEY
+ ): ChainBuilder =
+ doWhile(
+ { session -> session.getString("inviterConnectionState") != "ConnectionResponseSent" },
+ WAITING_LOOP_COUNTER_NAME)
+ .on(
+ exec(
+ http("Inviter receives connection request and sends response back")
+ .get("$url/connections/#{inviterConnectionId}")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .check(
+ status().shouldBe(HTTP_OK),
+ jsonPath("$.state").find().saveAs("inviterConnectionState")
+ )
+ ).exec { session ->
+ logger.info("Inviter connection state: ${session.getString("inviterConnectionState")}")
+ session
+ }.pause(WAITING_LOOP_PAUSE_INTERVAL).exitHereIf { session ->
+ session.getInt(WAITING_LOOP_COUNTER_NAME) == WAITING_LOOP_MAX_ITERATIONS
+ }
+ )
+
+ /**
+ * Invitee achieves connection response
+ *
+ * @param url URL of a PRISM Agent
+ * @param apikey secret access api key
+ * @return Builder of a Gatling chain of Actions to be used in Gatling Simulation
+ */
+ fun inviteeAchievesConnectionResponse(
+ url: String = Configuration.HOLDER_AGENT_URL,
+ apikey: String = Configuration.HOLDER_AGENT_API_KEY
+ ): ChainBuilder =
+ doWhile(
+ { session -> session.getString("inviteeConnectionState") != "ConnectionResponseReceived" },
+ WAITING_LOOP_COUNTER_NAME)
+ .on(
+ exec(
+ http("Invitee achieves connection response")
+ .get("$url/connections/#{inviteeConnectionId}" )
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .check(
+ status().shouldBe(HTTP_OK),
+ jsonPath("$.state").find().saveAs("inviteeConnectionState"),
+ )
+ ).exec { session ->
+ logger.info("Invitee connection state: ${session.getString("inviteeConnectionState")}")
+ session
+ }.pause(WAITING_LOOP_PAUSE_INTERVAL).exitHereIf { session ->
+ session.getInt(WAITING_LOOP_COUNTER_NAME) == WAITING_LOOP_MAX_ITERATIONS
+ }
+ )
+
+ /**
+ * Delete all connections from a PRISM Agent
+ *
+ * @param url URL of a PRISM Agent
+ * @param apikey secret access api key
+ * @return Builder of a Gatling chain of Actions to be used in Gatling Simulation
+ */
+ fun deleteAllConnections(
+ url: String = Configuration.ISSUER_AGENT_URL,
+ apikey: String = Configuration.ISSUER_AGENT_API_KEY
+ ): ChainBuilder =
+ exec(
+ http("Get connections")
+ .get("$url/connections")
+ .header("apikey", apikey)
+ .header("content-type", "application/json")
+ .check(
+ status().shouldBe(HTTP_OK),
+ jsonPath("$..connectionId").findAll().saveAs("connections")
+ )
+ ).foreach({ session -> session.getList("connections") }, "connection").on(
+ exec(
+ http("Delete connection")
+ .delete("${url}/connections/#{connection}")
+ .header("apikey", apikey)
+ ).exec { session ->
+ logger.info("Current connection: ${session.getString("connection")}")
+ session
+ }
+ )
+}
diff --git a/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/steps/IssuanceSteps.kt b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/steps/IssuanceSteps.kt
new file mode 100644
index 0000000000..26dc8e5287
--- /dev/null
+++ b/tests/performance-tests/agent-performance-tests/src/gatling/kotlin/steps/IssuanceSteps.kt
@@ -0,0 +1,168 @@
+package steps
+
+import common.Configuration
+import common.Configuration.RANDOM_CREDENTIAL
+import common.Configuration.WAITING_LOOP_COUNTER_NAME
+import common.Configuration.WAITING_LOOP_MAX_ITERATIONS
+import common.Configuration.WAITING_LOOP_PAUSE_INTERVAL
+import common.Utils
+import common.Utils.logger
+import io.gatling.javaapi.core.ChainBuilder
+import io.gatling.javaapi.core.CoreDsl.*
+import io.gatling.javaapi.http.HttpDsl.*
+import java.net.HttpURLConnection.HTTP_CREATED
+import java.net.HttpURLConnection.HTTP_OK
+
+object IssuanceSteps {
+
+ private val logger by Utils.logger()
+
+ fun issuerOffersACredential(
+ url: String = Configuration.ISSUER_AGENT_URL,
+ apikey: String = Configuration.ISSUER_AGENT_API_KEY
+ ): ChainBuilder =
+ exec(
+ http("Issuer offers a credential")
+ .post("$url/issue-credentials/credential-offers")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .body(StringBody(RANDOM_CREDENTIAL))
+ .check(
+ status().shouldBe(HTTP_CREATED),
+ jsonPath("$.recordId").find().saveAs("issuerRecordId")
+ )
+ ).exec { session ->
+ logger.info("Issuer record ID: ${session.getString("issuerRecordId")}")
+ session
+ }.exitHereIfFailed()
+
+ fun holderAwaitsCredentialOffer(
+ url: String = Configuration.HOLDER_AGENT_URL,
+ apikey: String = Configuration.HOLDER_AGENT_API_KEY
+ ): ChainBuilder =
+ doWhile(
+ { session -> session.getString("holderRecordId") == "" },
+ WAITING_LOOP_COUNTER_NAME
+ ).on(
+ exec(
+ http("Holder gets credential records")
+ .get("$url/issue-credentials/records")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .check(
+ status().shouldBe(HTTP_OK),
+ jsonPath("$.items[?(@.subjectId==\"#{holderDid}\")].recordId")
+ .withDefault("")
+ .saveAs("holderRecordId")
+ )
+ ).exec { session ->
+ logger.info("Achieved credential ID: ${session.getString("holderRecordId")}")
+ session
+ }.pause(WAITING_LOOP_PAUSE_INTERVAL).exitHereIf { session ->
+ session.getInt(WAITING_LOOP_COUNTER_NAME) == WAITING_LOOP_MAX_ITERATIONS
+ }
+ )
+
+ fun holderRequestsCredential(
+ url: String = Configuration.HOLDER_AGENT_URL,
+ apikey: String = Configuration.HOLDER_AGENT_API_KEY
+ ): ChainBuilder =
+ exec(
+ http("Holder requests credential")
+ .post("$url/issue-credentials/records/#{holderRecordId}/accept-offer")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .check(
+ status().shouldBe(HTTP_OK)
+ )
+ ).exitHereIfFailed()
+
+ fun issuerReceivesRequest(
+ url: String = Configuration.ISSUER_AGENT_URL,
+ apikey: String = Configuration.ISSUER_AGENT_API_KEY
+ ): ChainBuilder =
+ doWhile(
+ { session -> session.getString("issuerRecordIdState") != "RequestReceived"},
+ WAITING_LOOP_COUNTER_NAME
+ ).on(
+ exec(
+ http("Issuer record state achieves RequestReceived")
+ .get("$url/issue-credentials/records/#{issuerRecordId}")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .check(
+ status().shouldBe(HTTP_OK),
+ jsonPath("$.protocolState").find().saveAs("issuerRecordIdState"),
+ )
+ ).exec { session ->
+ logger.info("Issuer recordId state: ${session.getString("issuerRecordIdState")}")
+ session
+ }.pause(WAITING_LOOP_PAUSE_INTERVAL).exitHereIf { session ->
+ session.getInt(WAITING_LOOP_COUNTER_NAME) == WAITING_LOOP_MAX_ITERATIONS
+ }
+ )
+
+ fun issuerIssuesCredential(
+ url: String = Configuration.ISSUER_AGENT_URL,
+ apikey: String = Configuration.ISSUER_AGENT_API_KEY
+ ): ChainBuilder =
+ exec(
+ http("Issuer issues credential")
+ .post("$url/issue-credentials/records/#{issuerRecordId}/issue-credential")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .check(
+ status().shouldBe(HTTP_OK)
+ )
+ ).exitHereIfFailed()
+
+ fun issuerWaitsCredentialIssued(
+ url: String = Configuration.ISSUER_AGENT_URL,
+ apikey: String = Configuration.ISSUER_AGENT_API_KEY
+ ): ChainBuilder =
+ doWhile(
+ { session -> session.getString("issuerRecordIdState") != "CredentialSent" },
+ WAITING_LOOP_COUNTER_NAME
+ ).on(
+ exec(
+ http("Issuer record state achieves CredentialSent")
+ .get("$url/issue-credentials/records/#{issuerRecordId}")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .check(
+ status().shouldBe(HTTP_OK),
+ jsonPath("$.protocolState").find().saveAs("issuerRecordIdState"),
+ )
+ ).exec { session ->
+ logger.info("Issuer recordId state: ${session.getString("issuerRecordIdState")}")
+ session
+ }.pause(WAITING_LOOP_PAUSE_INTERVAL).exitHereIf { session ->
+ session.getInt(WAITING_LOOP_COUNTER_NAME) == WAITING_LOOP_MAX_ITERATIONS
+ }
+ )
+
+ fun holderAwaitsCredentialReceived(
+ url: String = Configuration.HOLDER_AGENT_URL,
+ apikey: String = Configuration.HOLDER_AGENT_API_KEY
+ ): ChainBuilder =
+ doWhile(
+ { session -> session.getString("holderRecordIdState") != "CredentialReceived" },
+ WAITING_LOOP_COUNTER_NAME
+ ).on(
+ exec(
+ http("Holder record state achieves CredentialReceived")
+ .get("$url/issue-credentials/records/#{holderRecordId}")
+ .header("content-type", "application/json")
+ .header("apikey", apikey)
+ .check(
+ status().shouldBe(HTTP_OK),
+ jsonPath("$.protocolState").find().saveAs("holderRecordIdState"),
+ )
+ ).exec { session ->
+ logger.info("Holder recordId state: ${session.getString("holderRecordIdState")}")
+ session
+ }.pause(WAITING_LOOP_PAUSE_INTERVAL).exitHereIf { session ->
+ session.getInt(WAITING_LOOP_COUNTER_NAME) == WAITING_LOOP_MAX_ITERATIONS
+ }
+ )
+}
diff --git a/tests/performance-tests/agent-performance-tests/src/gatling/resources/gatling.conf b/tests/performance-tests/agent-performance-tests/src/gatling/resources/gatling.conf
new file mode 100644
index 0000000000..c6db76269c
--- /dev/null
+++ b/tests/performance-tests/agent-performance-tests/src/gatling/resources/gatling.conf
@@ -0,0 +1,127 @@
+#########################
+# Gatling Configuration #
+#########################
+
+# This file contains all the settings configurable for Gatling with their default values
+
+gatling {
+ core {
+ #outputDirectoryBaseName = "" # The prefix for each simulation result folder (then suffixed by the report generation timestamp)
+ #runDescription = "" # The description for this simulation run, displayed in each report
+ #encoding = "utf-8" # Encoding to use throughout Gatling for file and string manipulation
+ #simulationClass = "" # The FQCN of the simulation to run (when used in conjunction with noReports, the simulation for which assertions will be validated)
+ #elFileBodiesCacheMaxCapacity = 200 # Cache size for request body EL templates, set to 0 to disable
+ #rawFileBodiesCacheMaxCapacity = 200 # Cache size for request body Raw templates, set to 0 to disable
+ #rawFileBodiesInMemoryMaxSize = 1000 # Below this limit, raw file bodies will be cached in memory
+ #pebbleFileBodiesCacheMaxCapacity = 200 # Cache size for request body Peeble templates, set to 0 to disable
+ #feederAdaptiveLoadModeThreshold = 100 # File size threshold (in MB). Below load eagerly in memory, above use batch mode with default buffer size
+ #shutdownTimeout = 10000 # Milliseconds to wait for the actor system to shutdown
+ extract {
+ regex {
+ #cacheMaxCapacity = 200 # Cache size for the compiled regexes, set to 0 to disable caching
+ }
+ xpath {
+ #cacheMaxCapacity = 200 # Cache size for the compiled XPath queries, set to 0 to disable caching
+ }
+ jsonPath {
+ #cacheMaxCapacity = 200 # Cache size for the compiled jsonPath queries, set to 0 to disable caching
+ }
+ css {
+ #cacheMaxCapacity = 200 # Cache size for the compiled CSS selectors queries, set to 0 to disable caching
+ }
+ }
+ directory {
+ #simulations = user-files/simulations # Directory where simulation classes are located (for bundle packaging only)
+ #resources = user-files/resources # Directory where resources, such as feeder files and request bodies are located (for bundle packaging only)
+ #reportsOnly = "" # If set, name of report folder to look for in order to generate its report
+ #binaries = "" # If set, name of the folder where compiles classes are located: Defaults to GATLING_HOME/target.
+ #results = results # Name of the folder where all reports folder are located
+ }
+ }
+ socket {
+ #connectTimeout = 10000 # Timeout in millis for establishing a TCP socket
+ #tcpNoDelay = true
+ #soKeepAlive = false # if TCP keepalive configured at OS level should be used
+ #soReuseAddress = false
+ }
+ netty {
+ #useNativeTransport = true # if Netty native transport should be used instead of Java NIO
+ #allocator = "pooled" # switch to unpooled for unpooled ByteBufAllocator
+ #maxThreadLocalCharBufferSize = 200000 # Netty's default is 16k
+ }
+ ssl {
+ #useOpenSsl = true # if OpenSSL should be used instead of JSSE (only the latter can be debugged with -Djava.net.debug=ssl)
+ #useOpenSslFinalizers = false # if OpenSSL contexts should be freed with Finalizer or if using RefCounted is fine
+ #handshakeTimeout = 10000 # TLS handshake timeout in millis
+ #useInsecureTrustManager = true # Use an insecure TrustManager that trusts all server certificates
+ #enabledProtocols = [] # Array of enabled protocols for HTTPS, if empty use Netty's defaults
+ #enabledCipherSuites = [] # Array of enabled cipher suites for HTTPS, if empty enable all available ciphers
+ #sessionCacheSize = 0 # SSLSession cache size, set to 0 to use JDK's default
+ #sessionTimeout = 0 # SSLSession timeout in seconds, set to 0 to use JDK's default (24h)
+ #enableSni = true # When set to true, enable Server Name indication (SNI)
+ keyStore {
+ #type = "" # Type of SSLContext's KeyManagers store
+ #file = "" # Location of SSLContext's KeyManagers store
+ #password = "" # Password for SSLContext's KeyManagers store
+ #algorithm = "" # Algorithm used SSLContext's KeyManagers store
+ }
+ trustStore {
+ #type = "" # Type of SSLContext's TrustManagers store
+ #file = "" # Location of SSLContext's TrustManagers store
+ #password = "" # Password for SSLContext's TrustManagers store
+ #algorithm = "" # Algorithm used by SSLContext's TrustManagers store
+ }
+ }
+ charting {
+ #noReports = false # When set to true, don't generate HTML reports
+ #maxPlotPerSeries = 1000 # Number of points per graph in Gatling reports
+ #useGroupDurationMetric = false # Switch group timings from cumulated response time to group duration.
+ indicators {
+ #lowerBound = 800 # Lower bound for the requests' response time to track in the reports and the console summary
+ #higherBound = 1200 # Higher bound for the requests' response time to track in the reports and the console summary
+ #percentile1 = 50 # Value for the 1st percentile to track in the reports, the console summary and Graphite
+ #percentile2 = 75 # Value for the 2nd percentile to track in the reports, the console summary and Graphite
+ #percentile3 = 95 # Value for the 3rd percentile to track in the reports, the console summary and Graphite
+ #percentile4 = 99 # Value for the 4th percentile to track in the reports, the console summary and Graphite
+ }
+ }
+ http {
+ #fetchedCssCacheMaxCapacity = 200 # Cache size for CSS parsed content, set to 0 to disable
+ #fetchedHtmlCacheMaxCapacity = 200 # Cache size for HTML parsed content, set to 0 to disable
+ #perUserCacheMaxCapacity = 200 # Per virtual user cache size, set to 0 to disable
+ #warmUpUrl = "https://gatling.io" # The URL to use to warm-up the HTTP stack (blank means disabled)
+ #enableGA = true # Very light Google Analytics (Gatling and Java version), please support
+ #pooledConnectionIdleTimeout = 60000 # Timeout in millis for a connection to stay idle in the pool
+ #requestTimeout = 60000 # Timeout in millis for performing an HTTP request
+ #enableHostnameVerification = false # When set to true, enable hostname verification: SSLEngine.setHttpsEndpointIdentificationAlgorithm("HTTPS")
+ dns {
+ #queryTimeout = 5000 # Timeout in millis of each DNS query in millis
+ #maxQueriesPerResolve = 6 # Maximum allowed number of DNS queries for a given name resolution
+ }
+ }
+ jms {
+ #replyTimeoutScanPeriod = 1000 # scan period for timedout reply messages
+ }
+ data {
+ #writers = [console, file] # The list of DataWriters to which Gatling write simulation data (currently supported : console, file, graphite)
+ console {
+ #light = false # When set to true, displays a light version without detailed request stats
+ #writePeriod = 5 # Write interval, in seconds
+ }
+ file {
+ #bufferSize = 8192 # FileDataWriter's internal data buffer size, in bytes
+ }
+ leak {
+ #noActivityTimeout = 30 # Period, in seconds, for which Gatling may have no activity before considering a leak may be happening
+ }
+ graphite {
+ #light = false # only send the all* stats
+ #host = "localhost" # The host where the Carbon server is located
+ #port = 2003 # The port to which the Carbon server listens to (2003 is default for plaintext, 2004 is default for pickle)
+ #protocol = "tcp" # The protocol used to send data to Carbon (currently supported : "tcp", "udp")
+ #rootPathPrefix = "gatling" # The common prefix of all metrics sent to Graphite
+ #bufferSize = 8192 # Internal data buffer size, in bytes
+ #writePeriod = 1 # Write period, in seconds
+ }
+ }
+}
diff --git a/tests/performance-tests/prism-performance-tests/settings.gradle.kts b/tests/performance-tests/prism-performance-tests/settings.gradle.kts
deleted file mode 100644
index e38e4a584d..0000000000
--- a/tests/performance-tests/prism-performance-tests/settings.gradle.kts
+++ /dev/null
@@ -1,3 +0,0 @@
-
-rootProject.name = "prism-performance-tests"
-
From 9308b21e46d267265c7fcdbfc88b78ddd5ae6558 Mon Sep 17 00:00:00 2001
From: Bassam
Date: Fri, 26 Apr 2024 01:50:40 -0400
Subject: [PATCH 12/12] feat(agent): verification API integration test +
documentation ATL-6775 (#986)
Signed-off-by: Bassam Riman
---
.../controller/VcVerificationEndpoints.scala | 2 +-
.../http/VcVerificationRequest.scala | 40 +++++----
.../http/VcVerificationResponse.scala | 89 ++++---------------
.../VcVerificationControllerImplSpec.scala | 2 +-
.../test/kotlin/common/CredentialSchema.kt | 4 +-
.../src/test/kotlin/common/TestConstants.kt | 3 -
.../src/test/kotlin/config/VaultAuthType.kt | 2 +-
.../kotlin/config/services/ServiceBase.kt | 1 -
.../src/test/kotlin/config/services/Vault.kt | 2 +-
.../src/test/kotlin/steps/Setup.kt | 1 +
.../test/kotlin/steps/common/CommonSteps.kt | 6 +-
.../credentials/IssueCredentialsSteps.kt | 26 +++---
.../test/kotlin/steps/did/PublishDidSteps.kt | 10 ++-
.../proofs/AnoncredsPresentProofSteps.kt | 36 ++++----
.../steps/schemas/CredentialSchemasSteps.kt | 6 +-
.../steps/verification/VcVerificationSteps.kt | 74 +++++++++++++++
.../VerificationPoliciesSteps.kt | 2 +-
17 files changed, 165 insertions(+), 141 deletions(-)
create mode 100644 tests/integration-tests/src/test/kotlin/steps/verification/VcVerificationSteps.kt
diff --git a/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationEndpoints.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationEndpoints.scala
index e32d445485..cff7629230 100644
--- a/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationEndpoints.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/VcVerificationEndpoints.scala
@@ -18,7 +18,7 @@ object VcVerificationEndpoints {
List[http.VcVerificationResponse],
Any
] =
- endpoint.get
+ endpoint.post
.tag("Verifiable Credentials Verification")
.name("verify")
.summary("As a Verifier, verify a set of credentials")
diff --git a/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationRequest.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationRequest.scala
index 2fbbfa57ec..fb5b30bbfb 100644
--- a/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationRequest.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationRequest.scala
@@ -7,12 +7,14 @@ import sttp.tapir.Schema.annotations.{description, encodedExample}
import zio.json.{DeriveJsonDecoder, DeriveJsonEncoder, JsonDecoder, JsonEncoder}
import zio.{IO, *}
+import java.time.OffsetDateTime
+
final case class VcVerificationRequest(
@description(VcVerificationRequest.annotations.credential.description)
@encodedExample(VcVerificationRequest.annotations.credential.example)
credential: String,
- @description(VcVerificationRequest.annotations.vcVerification.description)
- @encodedExample(VcVerificationRequest.annotations.vcVerification.example)
+ @description(VcVerificationRequest.annotations.parameterizableVcVerifications.description)
+ @encodedExample(VcVerificationRequest.annotations.parameterizableVcVerifications.example)
verifications: List[ParameterizableVcVerification]
)
@@ -26,22 +28,28 @@ object VcVerificationRequest {
"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c"
)
- object vcVerification
- extends Annotation[List[VcVerification]](
+ object parameterizableVcVerifications
+ extends Annotation[List[ParameterizableVcVerification]](
description = "The list of Verifications to verify. All verifications run if Verifications left empty",
example = List(
- VcVerification.SignatureVerification,
- VcVerification.IssuerIdentification,
- VcVerification.ExpirationCheck,
- VcVerification.NotBeforeCheck,
- VcVerification.AudienceCheck,
- VcVerification.SubjectVerification,
- VcVerification.IntegrityOfClaims,
- VcVerification.ComplianceWithStandards,
- VcVerification.RevocationCheck,
- VcVerification.AlgorithmVerification,
- VcVerification.SchemaCheck,
- VcVerification.SemanticCheckOfClaims,
+ ParameterizableVcVerification(VcVerification.SignatureVerification, None),
+ ParameterizableVcVerification(VcVerification.IssuerIdentification, Some(DidParameter("did:prism:issuer"))),
+ ParameterizableVcVerification(
+ VcVerification.ExpirationCheck,
+ Some(DateTimeParameter(OffsetDateTime.parse("2022-03-10T12:00:00Z")))
+ ),
+ ParameterizableVcVerification(
+ VcVerification.NotBeforeCheck,
+ Some(DateTimeParameter(OffsetDateTime.parse("2022-03-10T12:00:00Z")))
+ ),
+ ParameterizableVcVerification(VcVerification.AudienceCheck, Some(DidParameter("did:prism:holder"))),
+ ParameterizableVcVerification(VcVerification.SubjectVerification, None),
+ ParameterizableVcVerification(VcVerification.IntegrityOfClaims, None),
+ ParameterizableVcVerification(VcVerification.ComplianceWithStandards, None),
+ ParameterizableVcVerification(VcVerification.RevocationCheck, None),
+ ParameterizableVcVerification(VcVerification.AlgorithmVerification, None),
+ ParameterizableVcVerification(VcVerification.SchemaCheck, None),
+ ParameterizableVcVerification(VcVerification.SemanticCheckOfClaims, None)
)
)
}
diff --git a/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResponse.scala b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResponse.scala
index 99b25d7170..f8c71f335e 100644
--- a/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResponse.scala
+++ b/cloud-agent/service/server/src/main/scala/org/hyperledger/identus/verification/controller/http/VcVerificationResponse.scala
@@ -9,8 +9,8 @@ final case class VcVerificationResponse(
@description(VcVerificationResponse.annotations.credential.description)
@encodedExample(VcVerificationResponse.annotations.credential.example)
credential: String,
- @description(VcVerificationResponse.annotations.checks.description)
- @encodedExample(VcVerificationResponse.annotations.checks.example)
+ @description(VcVerificationResponse.annotations.vcVerificationResults.description)
+ @encodedExample(VcVerificationResponse.annotations.vcVerificationResults.example)
result: List[VcVerificationResult],
)
@@ -25,79 +25,22 @@ object VcVerificationResponse {
"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c"
)
- object checks
- extends Annotation[List[VcVerification]](
+ object vcVerificationResults
+ extends Annotation[List[VcVerificationResult]](
description = "The list executed Verifications",
example = List(
- VcVerification.SignatureVerification,
- VcVerification.IssuerIdentification,
- VcVerification.ExpirationCheck,
- VcVerification.NotBeforeCheck,
- VcVerification.AudienceCheck,
- VcVerification.SubjectVerification,
- VcVerification.IntegrityOfClaims,
- VcVerification.ComplianceWithStandards,
- VcVerification.RevocationCheck,
- VcVerification.AlgorithmVerification,
- VcVerification.SchemaCheck,
- VcVerification.SemanticCheckOfClaims,
- )
- )
-
- object successfulChecks
- extends Annotation[List[VcVerification]](
- description = "The list of successful Verifications",
- example = List(
- VcVerification.SignatureVerification,
- VcVerification.IssuerIdentification,
- VcVerification.ExpirationCheck,
- VcVerification.NotBeforeCheck,
- VcVerification.AudienceCheck,
- VcVerification.SubjectVerification,
- VcVerification.IntegrityOfClaims,
- VcVerification.ComplianceWithStandards,
- VcVerification.RevocationCheck,
- VcVerification.AlgorithmVerification,
- VcVerification.SchemaCheck,
- VcVerification.SemanticCheckOfClaims,
- )
- )
-
- object failedChecks
- extends Annotation[List[VcVerification]](
- description = "The list of failed Verifications.",
- example = List(
- VcVerification.SignatureVerification,
- VcVerification.IssuerIdentification,
- VcVerification.ExpirationCheck,
- VcVerification.NotBeforeCheck,
- VcVerification.AudienceCheck,
- VcVerification.SubjectVerification,
- VcVerification.IntegrityOfClaims,
- VcVerification.ComplianceWithStandards,
- VcVerification.RevocationCheck,
- VcVerification.AlgorithmVerification,
- VcVerification.SchemaCheck,
- VcVerification.SemanticCheckOfClaims,
- )
- )
-
- object failedAsWarningChecks
- extends Annotation[List[VcVerification]](
- description = "The list of failed Verifications as warning",
- example = List(
- VcVerification.SignatureVerification,
- VcVerification.IssuerIdentification,
- VcVerification.ExpirationCheck,
- VcVerification.NotBeforeCheck,
- VcVerification.AudienceCheck,
- VcVerification.SubjectVerification,
- VcVerification.IntegrityOfClaims,
- VcVerification.ComplianceWithStandards,
- VcVerification.RevocationCheck,
- VcVerification.AlgorithmVerification,
- VcVerification.SchemaCheck,
- VcVerification.SemanticCheckOfClaims,
+ VcVerificationResult(VcVerification.SignatureVerification, true),
+ VcVerificationResult(VcVerification.IssuerIdentification, true),
+ VcVerificationResult(VcVerification.ExpirationCheck, true),
+ VcVerificationResult(VcVerification.NotBeforeCheck, true),
+ VcVerificationResult(VcVerification.AudienceCheck, true),
+ VcVerificationResult(VcVerification.SubjectVerification, true),
+ VcVerificationResult(VcVerification.IntegrityOfClaims, true),
+ VcVerificationResult(VcVerification.ComplianceWithStandards, true),
+ VcVerificationResult(VcVerification.RevocationCheck, true),
+ VcVerificationResult(VcVerification.AlgorithmVerification, true),
+ VcVerificationResult(VcVerification.SchemaCheck, true),
+ VcVerificationResult(VcVerification.SemanticCheckOfClaims, true),
)
)
}
diff --git a/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImplSpec.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImplSpec.scala
index 1efbe9e153..1bbb9282ab 100644
--- a/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImplSpec.scala
+++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/verification/controller/VcVerificationControllerImplSpec.scala
@@ -74,7 +74,7 @@ object VcVerificationControllerImplSpec extends ZIOSpecDefault with VcVerificati
backend = httpBackend(vcVerificationController, authenticator)
response: Response[Either[DeserializationException[String], List[VcVerificationResponse]]] <-
basicRequest
- .get(uri"${vcVerificationUriBase}")
+ .post(uri"${vcVerificationUriBase}")
.body(
List(
VcVerificationRequest(
diff --git a/tests/integration-tests/src/test/kotlin/common/CredentialSchema.kt b/tests/integration-tests/src/test/kotlin/common/CredentialSchema.kt
index 926027faab..d635b71f80 100644
--- a/tests/integration-tests/src/test/kotlin/common/CredentialSchema.kt
+++ b/tests/integration-tests/src/test/kotlin/common/CredentialSchema.kt
@@ -19,7 +19,7 @@ enum class CredentialSchema {
"name" to JsonSchemaProperty(type = "string"),
"age" to JsonSchemaProperty(type = "integer"),
),
- required = listOf("name", "age")
+ required = listOf("name", "age"),
)
override val credentialSchema: CredentialSchemaInput = CredentialSchemaInput(
author = "did:prism:agent",
@@ -30,7 +30,7 @@ enum class CredentialSchema {
tags = listOf("school", "students"),
version = "1.0.0",
)
- };
+ }, ;
abstract val credentialSchema: CredentialSchemaInput
abstract val schema: JsonSchema
diff --git a/tests/integration-tests/src/test/kotlin/common/TestConstants.kt b/tests/integration-tests/src/test/kotlin/common/TestConstants.kt
index 91b028d64c..9c3b1901f1 100644
--- a/tests/integration-tests/src/test/kotlin/common/TestConstants.kt
+++ b/tests/integration-tests/src/test/kotlin/common/TestConstants.kt
@@ -1,10 +1,7 @@
package common
import io.iohk.atala.prism.models.*
-import models.JsonSchema
-import models.JsonSchemaProperty
import java.time.Duration
-import java.util.UUID
object TestConstants {
val TESTS_CONFIG = System.getProperty("TESTS_CONFIG") ?: "/configs/basic.conf"
diff --git a/tests/integration-tests/src/test/kotlin/config/VaultAuthType.kt b/tests/integration-tests/src/test/kotlin/config/VaultAuthType.kt
index 0bda8e5904..d19428ae07 100644
--- a/tests/integration-tests/src/test/kotlin/config/VaultAuthType.kt
+++ b/tests/integration-tests/src/test/kotlin/config/VaultAuthType.kt
@@ -2,5 +2,5 @@ package config
enum class VaultAuthType {
APP_ROLE,
- TOKEN
+ TOKEN,
}
diff --git a/tests/integration-tests/src/test/kotlin/config/services/ServiceBase.kt b/tests/integration-tests/src/test/kotlin/config/services/ServiceBase.kt
index 8b3bbf97ca..af1b7b0b0d 100644
--- a/tests/integration-tests/src/test/kotlin/config/services/ServiceBase.kt
+++ b/tests/integration-tests/src/test/kotlin/config/services/ServiceBase.kt
@@ -17,7 +17,6 @@ interface ServiceBase : Startable {
}
fun postStart() {
-
}
override fun stop() {
diff --git a/tests/integration-tests/src/test/kotlin/config/services/Vault.kt b/tests/integration-tests/src/test/kotlin/config/services/Vault.kt
index 2053e82c91..ebd7234de6 100644
--- a/tests/integration-tests/src/test/kotlin/config/services/Vault.kt
+++ b/tests/integration-tests/src/test/kotlin/config/services/Vault.kt
@@ -22,7 +22,7 @@ data class Vault(
mapOf(
"VAULT_PORT" to httpPort.toString(),
- ),
+ ),
).waitingFor(
"vault",
Wait.forHealthcheck(),
diff --git a/tests/integration-tests/src/test/kotlin/steps/Setup.kt b/tests/integration-tests/src/test/kotlin/steps/Setup.kt
index 35811e293b..22c867ae05 100644
--- a/tests/integration-tests/src/test/kotlin/steps/Setup.kt
+++ b/tests/integration-tests/src/test/kotlin/steps/Setup.kt
@@ -167,6 +167,7 @@ object Setup {
config.services?.vault?.stop()
}
}
+
@BeforeAll
fun init() {
Setup.initServices()
diff --git a/tests/integration-tests/src/test/kotlin/steps/common/CommonSteps.kt b/tests/integration-tests/src/test/kotlin/steps/common/CommonSteps.kt
index a65e9f052f..93824e027d 100644
--- a/tests/integration-tests/src/test/kotlin/steps/common/CommonSteps.kt
+++ b/tests/integration-tests/src/test/kotlin/steps/common/CommonSteps.kt
@@ -1,8 +1,5 @@
package steps.common
-import steps.connection.ConnectionSteps
-import steps.credentials.IssueCredentialsSteps
-import steps.did.PublishDidSteps
import interactions.Get
import io.cucumber.java.ParameterType
import io.cucumber.java.en.Given
@@ -16,6 +13,9 @@ import net.serenitybdd.rest.SerenityRest
import net.serenitybdd.screenplay.Actor
import net.serenitybdd.screenplay.actors.OnStage
import org.apache.http.HttpStatus
+import steps.connection.ConnectionSteps
+import steps.credentials.IssueCredentialsSteps
+import steps.did.PublishDidSteps
class CommonSteps {
@ParameterType(".*")
diff --git a/tests/integration-tests/src/test/kotlin/steps/credentials/IssueCredentialsSteps.kt b/tests/integration-tests/src/test/kotlin/steps/credentials/IssueCredentialsSteps.kt
index cdcb7af3d5..cc69b8f247 100644
--- a/tests/integration-tests/src/test/kotlin/steps/credentials/IssueCredentialsSteps.kt
+++ b/tests/integration-tests/src/test/kotlin/steps/credentials/IssueCredentialsSteps.kt
@@ -26,7 +26,7 @@ class IssueCredentialsSteps {
holder: Actor,
didForm: String,
schemaGuid: String?,
- claims: Map
+ claims: Map,
) {
val did: String = if (didForm == "short") {
issuer.recall("shortFormDid")
@@ -85,12 +85,12 @@ class IssueCredentialsSteps {
issuer: Actor,
holder: Actor,
format: String,
- schema: CredentialSchema
+ schema: CredentialSchema,
) {
val schemaGuid = issuer.recall(schema.name)!!
val claims = linkedMapOf(
"name" to "Name",
- "age" to 18
+ "age" to 18,
)
sendCredentialOffer(issuer, holder, format, schemaGuid, claims)
saveCredentialOffer(issuer, holder)
@@ -101,12 +101,12 @@ class IssueCredentialsSteps {
issuer: Actor,
holder: Actor,
format: String,
- schema: CredentialSchema
+ schema: CredentialSchema,
) {
val schemaGuid = issuer.recall(schema.name)!!
val claims = linkedMapOf(
"name" to "Name",
- "surname" to "Surname"
+ "surname" to "Surname",
)
sendCredentialOffer(issuer, holder, "short", schemaGuid, claims)
}
@@ -210,10 +210,10 @@ class IssueCredentialsSteps {
it.data.thid == holder.recall("thid")
}
credentialEvent != null &&
- credentialEvent!!.data.protocolState == IssueCredentialRecord.ProtocolState.OFFER_RECEIVED
+ credentialEvent!!.data.protocolState == IssueCredentialRecord.ProtocolState.OFFER_RECEIVED
},
"Holder was unable to receive the credential offer from Issuer! " +
- "Protocol state did not achieve ${IssueCredentialRecord.ProtocolState.OFFER_RECEIVED} state.",
+ "Protocol state did not achieve ${IssueCredentialRecord.ProtocolState.OFFER_RECEIVED} state.",
)
val recordId = ListenToEvents.`as`(holder).credentialEvents.last().data.recordId
@@ -258,7 +258,7 @@ class IssueCredentialsSteps {
it.data.thid == issuer.recall("thid")
}
credentialEvent != null &&
- credentialEvent!!.data.protocolState == IssueCredentialRecord.ProtocolState.REQUEST_RECEIVED
+ credentialEvent!!.data.protocolState == IssueCredentialRecord.ProtocolState.REQUEST_RECEIVED
},
"Issuer was unable to receive the credential request from Holder! Protocol state did not achieve RequestReceived state.",
)
@@ -276,10 +276,10 @@ class IssueCredentialsSteps {
it.data.thid == issuer.recall("thid")
}
credentialEvent != null &&
- credentialEvent!!.data.protocolState == IssueCredentialRecord.ProtocolState.CREDENTIAL_SENT
+ credentialEvent!!.data.protocolState == IssueCredentialRecord.ProtocolState.CREDENTIAL_SENT
},
"Issuer was unable to issue the credential! " +
- "Protocol state did not achieve ${IssueCredentialRecord.ProtocolState.CREDENTIAL_SENT} state.",
+ "Protocol state did not achieve ${IssueCredentialRecord.ProtocolState.CREDENTIAL_SENT} state.",
)
}
@@ -291,10 +291,10 @@ class IssueCredentialsSteps {
it.data.thid == holder.recall("thid")
}
credentialEvent != null &&
- credentialEvent!!.data.protocolState == IssueCredentialRecord.ProtocolState.CREDENTIAL_RECEIVED
+ credentialEvent!!.data.protocolState == IssueCredentialRecord.ProtocolState.CREDENTIAL_RECEIVED
},
"Holder was unable to receive the credential from Issuer! " +
- "Protocol state did not achieve ${IssueCredentialRecord.ProtocolState.CREDENTIAL_RECEIVED} state.",
+ "Protocol state did not achieve ${IssueCredentialRecord.ProtocolState.CREDENTIAL_RECEIVED} state.",
)
holder.remember("issuedCredential", ListenToEvents.`as`(holder).credentialEvents.last().data)
}
@@ -302,7 +302,7 @@ class IssueCredentialsSteps {
@Then("{actor} should see that credential issuance has failed")
fun issuerShouldSeeThatCredentialIssuanceHasFailed(issuer: Actor) {
issuer.attemptsTo(
- Ensure.thatTheLastResponse().statusCode().isEqualTo(SC_BAD_REQUEST)
+ Ensure.thatTheLastResponse().statusCode().isEqualTo(SC_BAD_REQUEST),
)
}
}
diff --git a/tests/integration-tests/src/test/kotlin/steps/did/PublishDidSteps.kt b/tests/integration-tests/src/test/kotlin/steps/did/PublishDidSteps.kt
index 094dd8817c..5abb2cab40 100644
--- a/tests/integration-tests/src/test/kotlin/steps/did/PublishDidSteps.kt
+++ b/tests/integration-tests/src/test/kotlin/steps/did/PublishDidSteps.kt
@@ -94,8 +94,9 @@ class PublishDidSteps {
if (agent.recallAll().containsKey("hasPublishedDid")) {
return
}
- if (!agent.recallAll().containsKey("shortFormDid")
- && !agent.recallAll().containsKey("longFormDid")) {
+ if (!agent.recallAll().containsKey("shortFormDid") &&
+ !agent.recallAll().containsKey("longFormDid")
+ ) {
createsUnpublishedDid(agent)
}
hePublishesDidToLedger(agent)
@@ -103,8 +104,9 @@ class PublishDidSteps {
@Given("{actor} has an unpublished DID")
fun agentHasAnUnpublishedDID(agent: Actor) {
- if (agent.recallAll().containsKey("shortFormDid")
- || agent.recallAll().containsKey("longFormDid")) {
+ if (agent.recallAll().containsKey("shortFormDid") ||
+ agent.recallAll().containsKey("longFormDid")
+ ) {
// is not published
if (!agent.recallAll().containsKey("hasPublishedDid")) {
return
diff --git a/tests/integration-tests/src/test/kotlin/steps/proofs/AnoncredsPresentProofSteps.kt b/tests/integration-tests/src/test/kotlin/steps/proofs/AnoncredsPresentProofSteps.kt
index 148d80aab8..3bdc9fd0b0 100644
--- a/tests/integration-tests/src/test/kotlin/steps/proofs/AnoncredsPresentProofSteps.kt
+++ b/tests/integration-tests/src/test/kotlin/steps/proofs/AnoncredsPresentProofSteps.kt
@@ -35,39 +35,39 @@ class AnoncredsPresentProofSteps {
restrictions = listOf(
mapOf(
("attr::sex::value" to "M"),
- ("cred_def_id" to credentialDefinitionId)
- )
- )
- )
+ ("cred_def_id" to credentialDefinitionId),
+ ),
+ ),
+ ),
),
requestedPredicates = mapOf(
"age" to AnoncredRequestedPredicateV1(
name = "age",
pType = ">=",
pValue = 18,
- restrictions = emptyList()
- )
+ restrictions = emptyList(),
+ ),
),
name = "proof_req_1",
nonce = "1103253414365527824079144",
- version = "0.1"
+ version = "0.1",
)
val presentationRequest = RequestPresentationInput(
connectionId = faber.recall("connection-with-${bob.name}").connectionId,
credentialFormat = "AnonCreds",
anoncredPresentationRequest = anoncredsPresentationRequestV1,
- proofs = emptyList()
+ proofs = emptyList(),
)
faber.attemptsTo(
Post.to("/present-proof/presentations")
.with {
it.body(
- presentationRequest
+ presentationRequest,
)
- }
+ },
)
faber.attemptsTo(
- Ensure.thatTheLastResponse().apply { println(this.contentType()) }.statusCode().isEqualTo(SC_CREATED)
+ Ensure.thatTheLastResponse().apply { println(this.contentType()) }.statusCode().isEqualTo(SC_CREATED),
)
val presentationStatus = SerenityRest.lastResponse().get()
faber.remember("thid", presentationStatus.thid)
@@ -84,7 +84,7 @@ class AnoncredsPresentProofSteps {
proofEvent != null &&
proofEvent!!.data.status == PresentationStatus.Status.REQUEST_RECEIVED
},
- "ERROR: Bob did not achieve any presentation request!"
+ "ERROR: Bob did not achieve any presentation request!",
)
bob.remember("presentationId", proofEvent!!.data.presentationId)
}
@@ -98,19 +98,19 @@ class AnoncredsPresentProofSteps {
AnoncredCredentialProofV1(
bob.recall("issuedCredential").recordId,
listOf("sex"),
- listOf("age")
- )
- )
+ listOf("age"),
+ ),
+ ),
),
- action = RequestPresentationAction.Action.REQUEST_MINUS_ACCEPT
+ action = RequestPresentationAction.Action.REQUEST_MINUS_ACCEPT,
)
bob.attemptsTo(
Patch.to("/present-proof/presentations/${bob.recall("presentationId")}").with {
it.body(
- requestPresentationAction
+ requestPresentationAction,
)
- }
+ },
)
}
}
diff --git a/tests/integration-tests/src/test/kotlin/steps/schemas/CredentialSchemasSteps.kt b/tests/integration-tests/src/test/kotlin/steps/schemas/CredentialSchemasSteps.kt
index ec3d2d9ce4..f9b77328d4 100644
--- a/tests/integration-tests/src/test/kotlin/steps/schemas/CredentialSchemasSteps.kt
+++ b/tests/integration-tests/src/test/kotlin/steps/schemas/CredentialSchemasSteps.kt
@@ -114,7 +114,7 @@ class CredentialSchemasSteps {
@Then("{actor} should see the schema creation failed")
fun schemaCreationShouldFail(agent: Actor) {
agent.attemptsTo(
- Ensure.thatTheLastResponse().statusCode().isEqualTo(SC_BAD_REQUEST)
+ Ensure.thatTheLastResponse().statusCode().isEqualTo(SC_BAD_REQUEST),
)
}
}
@@ -135,7 +135,7 @@ enum class SchemaErrorTemplate {
},
"required": ["name"]
}
- """.trimIndent()
+ """.trimIndent()
}
},
CUSTOM_WORDS_NOT_DEFINED {
@@ -174,7 +174,7 @@ enum class SchemaErrorTemplate {
}
"""
}
- };
+ }, ;
abstract fun inner_schema(): String
diff --git a/tests/integration-tests/src/test/kotlin/steps/verification/VcVerificationSteps.kt b/tests/integration-tests/src/test/kotlin/steps/verification/VcVerificationSteps.kt
new file mode 100644
index 0000000000..02902c2835
--- /dev/null
+++ b/tests/integration-tests/src/test/kotlin/steps/verification/VcVerificationSteps.kt
@@ -0,0 +1,74 @@
+package steps.verification
+
+import interactions.Post
+import io.cucumber.java.en.When
+import io.iohk.atala.automation.extensions.get
+import io.iohk.atala.automation.serenity.ensure.Ensure
+import io.iohk.atala.prism.models.*
+import net.serenitybdd.rest.SerenityRest
+import net.serenitybdd.screenplay.Actor
+import org.apache.http.HttpStatus.SC_OK
+import java.time.OffsetDateTime
+
+class VcVerificationSteps {
+
+ @When("{actor} verifies VcVerificationRequest")
+ fun agentVerifiesVerifiableCredential(actor: Actor) {
+ val signedJwtCredential =
+ "eyJhbGciOiJFUzI1NksifQ.eyJhdWQiOiJkaWQ6cHJpc206dmVyaWZpZXIiLCJuYmYiOjEyNjIzMDQwMDAsImlzcyI6ImRpZDpwcmlzbTo3NzYxMjBlZWIxMjhjZTdkZmQ5NDUwZmZhMTg4MWU5OTYxOWFhMGM5MDRiMDBjODJiYjE3YjU2ODE3Y2IwMmFlIiwiZXhwIjoxMjYzMjU0NDAwLCJ2YyI6eyJAY29udGV4dCI6WyJodHRwczovL3d3dy53My5vcmcvMjAxOC9jcmVkZW50aWFscy92MSIsImh0dHBzOi8vd3d3LnczLm9yZy8yMDE4L2NyZWRlbnRpYWxzL2V4YW1wbGVzL3YxIl0sInR5cGUiOlsiVmVyaWZpYWJsZUNyZWRlbnRpYWwiLCJVbml2ZXJzaXR5RGVncmVlQ3JlZGVudGlhbCJdLCJjcmVkZW50aWFsU2NoZW1hIjp7ImlkIjoiZGlkOndvcms6TURQOEFzRmhIemh3VXZHTnVZa1g3VDtpZD0wNmUxMjZkMS1mYTQ0LTQ4ODItYTI0My0xZTMyNmZiZTIxZGI7dmVyc2lvbj0xLjAiLCJ0eXBlIjoiSnNvblNjaGVtYVZhbGlkYXRvcjIwMTgifSwiY3JlZGVudGlhbFN1YmplY3QiOnsidXNlck5hbWUiOiJCb2IiLCJhZ2UiOjQyLCJlbWFpbCI6ImVtYWlsIn0sImNyZWRlbnRpYWxTdGF0dXMiOnsiaWQiOiJkaWQ6d29yazpNRFA4QXNGaEh6aHdVdkdOdVlrWDdUO2lkPTA2ZTEyNmQxLWZhNDQtNDg4Mi1hMjQzLTFlMzI2ZmJlMjFkYjt2ZXJzaW9uPTEuMCIsInR5cGUiOiJTdGF0dXNMaXN0MjAyMUVudHJ5Iiwic3RhdHVzUHVycG9zZSI6IlJldm9jYXRpb24iLCJzdGF0dXNMaXN0SW5kZXgiOjAsInN0YXR1c0xpc3RDcmVkZW50aWFsIjoiaHR0cHM6Ly9leGFtcGxlLmNvbS9jcmVkZW50aWFscy9zdGF0dXMvMyJ9LCJyZWZyZXNoU2VydmljZSI6eyJpZCI6Imh0dHBzOi8vZXhhbXBsZS5lZHUvcmVmcmVzaC8zNzMyIiwidHlwZSI6Ik1hbnVhbFJlZnJlc2hTZXJ2aWNlMjAxOCJ9fSwianRpIjoiaHR0cDovL2V4YW1wbGUuZWR1L2NyZWRlbnRpYWxzLzM3MzIifQ.JCHIAQdjmOxOdZ1SIf5Nd8FObiARXT6cDcGM3UyQ961Kv4Rb3ZtgpNM-cf2aj5ZFyFko-t7uCsSvrVrYKUYcWg"
+ val request =
+ listOf(
+ VcVerificationRequest(
+ signedJwtCredential,
+ listOf(
+ ParameterizableVcVerification(VcVerification.SIGNATURE_VERIFICATION),
+ ParameterizableVcVerification(
+ VcVerification.NOT_BEFORE_CHECK,
+ DateTimeParameter(OffsetDateTime.now()) as VcVerificationParameter,
+ ),
+ ParameterizableVcVerification(
+ VcVerification.EXPIRATION_CHECK,
+ DateTimeParameter(OffsetDateTime.now()) as VcVerificationParameter,
+ ),
+ ),
+ ),
+ VcVerificationRequest(
+ signedJwtCredential,
+ listOf(
+ ParameterizableVcVerification(
+ VcVerification.AUDIENCE_CHECK,
+ DidParameter("did:prism:verifier") as VcVerificationParameter,
+ ),
+ ),
+ ),
+ )
+ actor.attemptsTo(
+ Post.to("/verification/credential").with {
+ it.body(request)
+ },
+ )
+ val vcVerificationResponses = SerenityRest.lastResponse().get>()
+
+ actor.attemptsTo(
+ Ensure.thatTheLastResponse().statusCode().isEqualTo(SC_OK),
+ Ensure.that(vcVerificationResponses).containsExactlyInAnyOrderElementsFrom(
+ listOf(
+ VcVerificationResponse(
+ signedJwtCredential,
+ listOf(
+ VcVerificationResult(VcVerification.SIGNATURE_VERIFICATION, false),
+ VcVerificationResult(VcVerification.NOT_BEFORE_CHECK, true),
+ VcVerificationResult(VcVerification.EXPIRATION_CHECK, true),
+ ),
+ ),
+ VcVerificationResponse(
+ signedJwtCredential,
+ listOf(
+ VcVerificationResult(VcVerification.AUDIENCE_CHECK, true),
+ ),
+ ),
+ ),
+ ),
+ )
+ }
+}
diff --git a/tests/integration-tests/src/test/kotlin/steps/verificationpolicies/VerificationPoliciesSteps.kt b/tests/integration-tests/src/test/kotlin/steps/verificationpolicies/VerificationPoliciesSteps.kt
index ab891702a5..0c3c0e1e5a 100644
--- a/tests/integration-tests/src/test/kotlin/steps/verificationpolicies/VerificationPoliciesSteps.kt
+++ b/tests/integration-tests/src/test/kotlin/steps/verificationpolicies/VerificationPoliciesSteps.kt
@@ -8,8 +8,8 @@ import io.cucumber.java.en.Then
import io.cucumber.java.en.When
import io.iohk.atala.automation.extensions.get
import io.iohk.atala.automation.serenity.ensure.Ensure
-import io.iohk.atala.prism.models.VerificationPolicyResponse
import io.iohk.atala.prism.models.VerificationPolicyInput
+import io.iohk.atala.prism.models.VerificationPolicyResponse
import net.serenitybdd.rest.SerenityRest
import net.serenitybdd.screenplay.Actor
import org.apache.http.HttpStatus