diff --git a/.github/ISSUE_TEMPLATE/1-bug-report.yaml b/.github/ISSUE_TEMPLATE/1-bug-report.yaml index 3e62bb5cf5..4d9d190350 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 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/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 }}" 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/.github/workflows/release.yml b/.github/workflows/release.yml index ddcca98eb5..30e41094c1 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: ${{ 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: write + 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: github.actor + password: ${{ secrets.GITHUB_TOKEN }} - name: Set up QEMU uses: docker/setup-qemu-action@v2 - name: Set up Docker Buildx diff --git a/.mega-linter.yml b/.mega-linter.yml index 67433327e0..b3bb59519f 100644 --- a/.mega-linter.yml +++ b/.mega-linter.yml @@ -50,4 +50,4 @@ SQL_SQL_LINT_ARGUMENTS: -d postgres --ignore-errors=postgres-invalid-alter-optio YAML_YAMLLINT_FILTER_REGEX_EXCLUDE: "infrastructure/charts/agent/*" YAML_PRETTIER_FILTER_REGEX_EXCLUDE: "infrastructure/charts/agent/*" 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 2387fa44a4..b86d7c505d 100644 --- a/README.md +++ b/README.md @@ -3,21 +3,21 @@ atala-prism-logo
- Open Enterprise Cloud Agent + Identus Cloud Agent

Coverage Status - Unit tests - End-to-end tests - Performance tests + Unit tests + End-to-end tests + Performance tests


## 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 065c03df64..63d0843fd5 100644 --- a/build.sbt +++ b/build.sbt @@ -5,14 +5,14 @@ import sbtbuildinfo.BuildInfoPlugin.autoImport.* inThisBuild( Seq( - organization := "io.iohk.atala", - scalaVersion := "3.3.1", + organization := "org.hyperledger", + scalaVersion := "3.3.3", 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", ) @@ -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 @@ -350,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 @@ -465,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 @@ -475,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 @@ -486,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 @@ -503,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), @@ -529,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)) @@ -537,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)) @@ -545,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( @@ -567,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) @@ -582,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)) @@ -602,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)) @@ -610,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)) @@ -618,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)) @@ -636,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( @@ -655,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( @@ -677,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) @@ -686,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")) @@ -713,7 +709,7 @@ val prismNodeClient = project // ##################### lazy val castorCore = project - .in(file("castor/lib/core")) + .in(file("castor")) .settings(commonSetttings) .settings( name := "castor-core", @@ -727,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", @@ -736,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", @@ -763,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( @@ -772,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") @@ -786,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", @@ -797,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", @@ -820,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( @@ -842,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 := "prism-agent", + 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("input-output-hk"), + 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, @@ -890,7 +885,7 @@ releaseProcess := Seq[ReleaseStep]( runClean, runTest, setReleaseVersion, - ReleaseStep(releaseStepTask(prismAgentServer / Docker / stage)), + ReleaseStep(releaseStepTask(cloudAgentServer / Docker / stage)), setNextVersion ) @@ -923,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/model/did/PublicKey.scala b/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PublicKey.scala deleted file mode 100644 index 55867ce39f..0000000000 --- a/castor/lib/core/src/main/scala/io/iohk/atala/castor/core/model/did/PublicKey.scala +++ /dev/null @@ -1,52 +0,0 @@ -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, - purpose: VerificationRelationship, - publicKeyData: PublicKeyData -) - -enum InternalKeyPurpose { - case Master extends InternalKeyPurpose - case Revocation extends InternalKeyPurpose -} - -final case class InternalPublicKey( - id: String, - purpose: InternalKeyPurpose, - publicKeyData: PublicKeyData -) - -sealed trait PublicKeyData - -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 - } - } - } -} 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/src/main/scala/org/hyperledger/identus/castor/core/model/did/PublicKey.scala b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PublicKey.scala new file mode 100644 index 0000000000..496b71abb3 --- /dev/null +++ b/castor/src/main/scala/org/hyperledger/identus/castor/core/model/did/PublicKey.scala @@ -0,0 +1,29 @@ +package org.hyperledger.identus.castor.core.model.did + +import org.hyperledger.identus.shared.models.Base64UrlString + +final case class PublicKey( + id: String, + purpose: VerificationRelationship, + publicKeyData: PublicKeyData +) + +enum InternalKeyPurpose { + case Master extends InternalKeyPurpose + case Revocation extends InternalKeyPurpose +} + +final case class InternalPublicKey( + id: String, + purpose: InternalKeyPurpose, + publicKeyData: 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 +} 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 81% 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 6b74060b4f..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,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 +package org.hyperledger.identus.castor.core.model.did.w3c + import io.circe.Json -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.EllipticCurve -import java.time.format.DateTimeFormatter -import java.time.ZoneOffset +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 +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/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 81% 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 bdf1ddfb64..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 { @@ -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/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 78% 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 14fc883494..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,18 +1,15 @@ -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, 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/src/main/scala/org/hyperledger/identus/castor/core/util/DIDOperationValidator.scala similarity index 76% 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 ef496100ac..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,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.error.OperationValidationError -import io.iohk.atala.castor.core.util.DIDOperationValidator.Config -import io.iohk.atala.castor.core.util.Prelude.* -import scala.collection.immutable.ArraySeq +package org.hyperledger.identus.castor.core.util + +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 +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 @@ -313,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(()) @@ -328,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(()) @@ -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/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 87% 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 c44be521be..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,28 +1,16 @@ -package io.iohk.atala.castor.core.util +package org.hyperledger.identus.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.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 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.* +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/src/test/scala/org/hyperledger/identus/castor/core/util/GenUtils.scala similarity index 83% 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 dcdb7adc35..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,13 +1,14 @@ -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.prism.crypto.EC -import io.iohk.atala.shared.models.Base64UrlString +import io.circe.Json +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 -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/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/prism-agent/client/generator/generate-clients.sh b/cloud-agent/client/generator/generate-clients.sh similarity index 100% rename from prism-agent/client/generator/generate-clients.sh rename to cloud-agent/client/generator/generate-clients.sh 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 100% rename from prism-agent/client/generator/package.json rename to cloud-agent/client/generator/package.json diff --git a/prism-agent/client/generator/publish-clients.sh b/cloud-agent/client/generator/publish-clients.sh similarity index 100% rename from prism-agent/client/generator/publish-clients.sh rename to cloud-agent/client/generator/publish-clients.sh 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/prism-agent-openapi-spec.yaml similarity index 100% rename from prism-agent/service/api/http/prism-agent-openapi-spec.yaml rename to cloud-agent/service/api/http/prism-agent-openapi-spec.yaml 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 78% 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 54b087d55f..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,46 +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.memory.{ - DIDSecretStorageInMemory, - GenericSecretStorageInMemory, - WalletSecretStorageInMemory +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 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.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 @@ -256,14 +255,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/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 5ba7582211..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.* @@ -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/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 80% 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 253e75ebfe..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,14 +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.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} @@ -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/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 97% 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 76284066a9..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.* @@ -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/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/prism-agent/service/server/src/test/scala/io/iohk/atala/container/util/MigrationAspect.scala b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/container/util/MigrationAspect.scala similarity index 96% rename from prism-agent/service/server/src/test/scala/io/iohk/atala/container/util/MigrationAspect.scala rename to cloud-agent/service/server/src/test/scala/org/hyperledger/identus/container/util/MigrationAspect.scala index 34f2fcfd00..fe5bf1cbc7 100644 --- a/prism-agent/service/server/src/test/scala/io/iohk/atala/container/util/MigrationAspect.scala +++ b/cloud-agent/service/server/src/test/scala/org/hyperledger/identus/container/util/MigrationAspect.scala @@ -1,4 +1,4 @@ -package io.iohk.atala.container.util +package org.hyperledger.identus.container.util import com.dimafeng.testcontainers.PostgreSQLContainer import org.flywaydb.core.Flyway 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/cloud-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 new file mode 100644 index 0000000000..da5be56e62 --- /dev/null +++ b/cloud-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/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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/memory/DIDSecretStorageInMemory.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/memory/DIDSecretStorageInMemory.scala new file mode 100644 index 0000000000..e69de29bb2 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 71% 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 4fce80980f..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,9 +1,12 @@ -package io.iohk.atala.agent.walletapi.model +package org.hyperledger.identus.agent.walletapi.model -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, Secp256k1KeyPair as ECKeyPair} +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 @@ -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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/ManagedDID.scala similarity index 80% 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 f241424c72..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 @@ -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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/model/ManagedDIDTemplate.scala similarity index 77% 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 44d1604523..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,7 +1,12 @@ -package io.iohk.atala.agent.walletapi.model +package org.hyperledger.identus.agent.walletapi.model -import io.iohk.atala.castor.core.model.did.ServiceEndpoint -import io.iohk.atala.castor.core.model.did.{Service, VerificationRelationship, ServiceType} +import org.hyperledger.identus.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/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 69% 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 6b9b1f5192..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,12 +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.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} @@ -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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceImpl.scala similarity index 88% 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 0e4b2f7b18..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,19 +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.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} @@ -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/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 80% 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 d795318eab..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,17 +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.Secp256k1KeyPair +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, *} @@ -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/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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDCreateHandler.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDCreateHandler.scala new file mode 100644 index 0000000000..360377f8e8 --- /dev/null +++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDCreateHandler.scala @@ -0,0 +1,76 @@ +package org.hyperledger.identus.agent.walletapi.service.handler + +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( + apollo: Apollo, + nonSecretStorage: DIDNonSecretStorage, + secretStorage: DIDSecretStorage, + walletSecretStorage: WalletSecretStorage, +)( + masterKeyId: String +) { + def materialize( + didTemplate: ManagedDIDTemplate + ): ZIO[WalletAccessContext, CreateManagedDIDError, DIDCreateMaterial] = { + val operationFactory = OperationFactory(apollo) + for { + walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId) + seed <- walletSecretStorage.getWalletSeed + .someOrElseZIO(ZIO.dieMessage(s"Wallet seed for wallet $walletId does not exist")) + .mapError(CreateManagedDIDError.WalletStorageError.apply) + didIndex <- nonSecretStorage + .getMaxDIDIndex() + .mapBoth( + CreateManagedDIDError.WalletStorageError.apply, + maybeIdx => maybeIdx.map(_ + 1).getOrElse(0) + ) + generated <- operationFactory.makeCreateOperation(masterKeyId, seed.toByteArray)(didIndex, didTemplate) + (createOperation, keys) = generated + state = ManagedDIDState(createOperation, didIndex, PublicationState.Created()) + } yield DIDCreateMaterialImpl(nonSecretStorage, secretStorage)(createOperation, state, keys) + } +} + +private[walletapi] trait DIDCreateMaterial { + def operation: PrismDIDOperation.Create + def state: ManagedDIDState + def persist: RIO[WalletAccessContext, Unit] +} + +private[walletapi] class DIDCreateMaterialImpl(nonSecretStorage: DIDNonSecretStorage, secretStorage: DIDSecretStorage)( + val operation: PrismDIDOperation.Create, + val state: ManagedDIDState, + keys: CreateDIDKey +) extends DIDCreateMaterial { + def persist: RIO[WalletAccessContext, Unit] = { + val did = operation.did + val operationHash = operation.toAtalaOperationHash + for { + _ <- nonSecretStorage + .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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDUpdateHandler.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDUpdateHandler.scala new file mode 100644 index 0000000000..c55bae5116 --- /dev/null +++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/DIDUpdateHandler.scala @@ -0,0 +1,128 @@ +package org.hyperledger.identus.agent.walletapi.service.handler + +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.* + +private[walletapi] class DIDUpdateHandler( + apollo: Apollo, + nonSecretStorage: DIDNonSecretStorage, + secretStorage: DIDSecretStorage, + walletSecretStorage: WalletSecretStorage, + publicationHandler: PublicationHandler +) { + def materialize( + state: ManagedDIDState, + previousOperationHash: Array[Byte], + actions: Seq[UpdateManagedDIDAction] + ): ZIO[WalletAccessContext, UpdateManagedDIDError, DIDUpdateMaterial] = { + val operationFactory = OperationFactory(apollo) + val did = state.createOperation.did + 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) + } +} + +private[walletapi] trait DIDUpdateMaterial { + + def operation: PrismDIDOperation.Update + + def signedOperation: SignedPrismDIDOperation + + def state: ManagedDIDState + + def persist: RIO[WalletAccessContext, Unit] + + protected final def persistUpdateLineage(nonSecretStorage: DIDNonSecretStorage): RIO[WalletAccessContext, Unit] = { + val did = operation.did + for { + updateLineage <- Clock.instant.map { now => + DIDUpdateLineage( + operationId = ArraySeq.from(signedOperation.toAtalaOperationId), + operationHash = ArraySeq.from(operation.toAtalaOperationHash), + previousOperationHash = operation.previousOperationHash, + status = ScheduledDIDOperationStatus.Pending, + createdAt = now, + updatedAt = now + ) + } + _ <- nonSecretStorage.insertDIDUpdateLineage(did, updateLineage) + } yield () + } + +} + +private class HdKeyUpdateMaterial(nonSecretStorage: DIDNonSecretStorage, secretStorage: DIDSecretStorage)( + val operation: PrismDIDOperation.Update, + val signedOperation: SignedPrismDIDOperation, + val state: ManagedDIDState, + keys: UpdateDIDKey +) extends DIDUpdateMaterial { + + private def persistKeyMaterial: RIO[WalletAccessContext, Unit] = { + val did = operation.did + val operationHash = operation.toAtalaOperationHash + // 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] = + for { + _ <- persistKeyMaterial + _ <- persistUpdateLineage(nonSecretStorage) + } yield () + +} diff --git a/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/PublicationHandler.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/PublicationHandler.scala new file mode 100644 index 0000000000..8eb17c65c0 --- /dev/null +++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/service/handler/PublicationHandler.scala @@ -0,0 +1,46 @@ +package org.hyperledger.identus.agent.walletapi.service.handler + +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.* + +class PublicationHandler(didService: DIDService, keyResolver: KeyResolver)(masterKeyId: String) { + def signOperationWithMasterKey[E](state: ManagedDIDState, operation: PrismDIDOperation)(using + c1: Conversion[CommonWalletStorageError, E], + c2: Conversion[CommonCryptographyError, E] + ): ZIO[WalletAccessContext, E, SignedPrismDIDOperation] = { + for { + masterKeyPair <- + keyResolver + .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 => + SignedPrismDIDOperation( + operation = operation, + signature = ArraySeq.from(signature), + signedWithKey = masterKeyId + ) + ) + } yield signedOperation + } + + def submitSignedOperation[E]( + signedOperation: SignedPrismDIDOperation + )(using c1: Conversion[DIDOperationError, E]): IO[E, ScheduleDIDOperationOutcome] = + didService.scheduleOperation(signedOperation).mapError[E](e => e) +} 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 78% 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 eb14c8cf4f..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,20 +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.* @@ -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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcDIDSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcDIDSecretStorage.scala new file mode 100644 index 0000000000..75a3ff77d3 --- /dev/null +++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/sql/JdbcDIDSecretStorage.scala @@ -0,0 +1,127 @@ +package org.hyperledger.identus.agent.walletapi.sql + +import com.nimbusds.jose.jwk.OctetKeyPair +import doobie.* +import doobie.implicits.* +import doobie.postgres.implicits.* +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 +import scala.language.implicitConversions + +class JdbcDIDSecretStorage(xa: Transactor[ContextAwareTask]) extends DIDSecretStorage { + + case class InstantAsBigInt(value: Instant) + + given instantGet: Get[InstantAsBigInt] = Get[Long].map(Instant.ofEpochSecond).map(InstantAsBigInt.apply) + + given instantPut: Put[InstantAsBigInt] = Put[Long].contramap(_.value.getEpochSecond()) + + given didIdGet: Get[DidId] = Get[String].map(DidId(_)) + + given didIdPut: Put[DidId] = Put[String].contramap(_.value) + + override def getKey(did: DidId, keyId: String): RIO[WalletAccessContext, Option[OctetKeyPair]] = { + val cxnIO = sql""" + | SELECT key_pair + | FROM public.peer_did_rand_key + | WHERE + | did = $did + | AND key_id = $keyId + """.stripMargin + .query[OctetKeyPair] + .option + + cxnIO.transactWallet(xa) + } + + override def insertKey(did: DidId, keyId: String, keyPair: OctetKeyPair): RIO[WalletAccessContext, Int] = { + val cxnIO = (now: InstantAsBigInt) => sql""" + | INSERT INTO public.peer_did_rand_key( + | did, + | created_at, + | key_id, + | key_pair + | ) values ( + | ${did}, + | ${now}, + | ${keyId}, + | ${keyPair} + | ) + """.stripMargin.update + + for { + now <- Clock.instant + result <- cxnIO(InstantAsBigInt(now)).run.transactWallet(xa) + } 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 { + val layer: URLayer[Transactor[ContextAwareTask], DIDSecretStorage] = + ZLayer.fromFunction(new JdbcDIDSecretStorage(_)) +} 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 87% 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 105699c31f..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,15 +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.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.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.* @@ -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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDNonSecretStorage.scala similarity index 72% 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 fa4311a512..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 @@ -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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDSecretStorage.scala new file mode 100644 index 0000000000..f9835c0d04 --- /dev/null +++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/storage/DIDSecretStorage.scala @@ -0,0 +1,26 @@ +package org.hyperledger.identus.agent.walletapi.storage + +import com.nimbusds.jose.jwk.OctetKeyPair +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 */ +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/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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/KeyResolver.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/KeyResolver.scala new file mode 100644 index 0000000000..a8a033db8c --- /dev/null +++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/KeyResolver.scala @@ -0,0 +1,56 @@ +package org.hyperledger.identus.agent.walletapi.util + +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( + apollo: Apollo, + nonSecretStorage: DIDNonSecretStorage, + secretStorage: DIDSecretStorage, + walletSecretStorage: WalletSecretStorage +) { + def getKey( + did: PrismDID, + keyId: String + ): 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 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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/ManagedDIDTemplateValidator.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/ManagedDIDTemplateValidator.scala new file mode 100644 index 0000000000..daa24fd415 --- /dev/null +++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/ManagedDIDTemplateValidator.scala @@ -0,0 +1,46 @@ +package org.hyperledger.identus.agent.walletapi.util + +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 { + + 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) + val reservedKeyIds = keyIds.filter(id => ManagedDIDService.reservedKeyIds.contains(id)) + if (reservedKeyIds.nonEmpty) + Left(s"DID template cannot contain reserved key name: ${reservedKeyIds.mkString("[", ", ", "]")}") + 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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactory.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactory.scala new file mode 100644 index 0000000000..2973014bf3 --- /dev/null +++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactory.scala @@ -0,0 +1,220 @@ +package org.hyperledger.identus.agent.walletapi.util + +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, + Secp256k1KeyPair, + Secp256k1PublicKey, + X25519KeyPair, + X25519PublicKey +} +import org.hyperledger.identus.shared.models.Base64UrlString +import zio.* + +import scala.collection.immutable.ArraySeq +import scala.language.implicitConversions + +private[util] final case class KeyDerivationOutcome[PK]( + publicKey: PK, + path: ManagedDIDHdKeyPath, + 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 + * + * @param masterKeyId + * The key id of the master key + * @param seed + * The seed to use for the key generation + * @param didTemplate + * The DID template + * @param didIndex + * The index of the DID to be used for the key derivation + */ + def makeCreateOperation( + masterKeyId: String, + seed: Array[Byte] + )( + didIndex: Int, + didTemplate: ManagedDIDTemplate + ): IO[CreateManagedDIDError, (PrismDIDOperation.Create, CreateDIDKey)] = { + val initKeysWithCounter = (Vector.empty[KeyDerivationOutcome[PublicKey]], HdKeyIndexCounter.zero(didIndex)) + val (hdKeysTemplate, randKeysTemplate) = didTemplate.publicKeys.partition(_.curve == EllipticCurve.SECP256K1) + for { + 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, + hdKeysWithCounter._2 + ) + operation = PrismDIDOperation.Create( + publicKeys = hdKeysWithCounter._1.map(_._1) ++ randKeys.map(_.publicKey) ++ Seq(masterKeyOutcome.publicKey), + services = didTemplate.services, + context = didTemplate.contexts + ) + 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 -> keys + } + + def makeUpdateOperation(seed: Array[Byte])( + did: CanonicalPrismDID, + previousOperationHash: Array[Byte], + actions: Seq[UpdateManagedDIDAction], + fromKeyCounter: HdKeyIndexCounter + ): IO[UpdateManagedDIDError, (PrismDIDOperation.Update, UpdateDIDKey)] = { + val initKeysWithCounter = + ( + Vector.empty[(UpdateManagedDIDAction, Option[(PublicKey, ManagedDIDHdKeyPath | ManagedDIDRandKeyPair)])], + fromKeyCounter + ) + val actionsWithKeyMaterial = ZIO.foldLeft(actions)(initKeysWithCounter) { case ((acc, keyCounter), action) => + 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 + } + 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 + (actionWithKey, keyCounter) = actionsWithKeyMaterial + transformedActions <- ZIO.foreach(actionWithKey) { case (action, keyMaterial) => + transformUpdateAction(action, keyMaterial.map(_._1)) + } + 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 + ) + 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) + hdKeys = hdKeys.toMap, + randKeys = randKeys.toMap, + counter = keyCounter + ) + } yield operation -> updateKey + } + + private def transformUpdateAction( + updateAction: UpdateManagedDIDAction, + publicKey: Option[PublicKey] + ): UIO[UpdateDIDAction] = { + updateAction match { + case UpdateManagedDIDAction.AddKey(_) => + publicKey match { + case Some(publicKey) => ZIO.succeed(UpdateDIDAction.AddKey(publicKey)) + case None => + // should be impossible otherwise it's a defect + ZIO.dieMessage("addKey update DID action must have a generated a key-pair") + } + case UpdateManagedDIDAction.RemoveKey(id) => ZIO.succeed(UpdateDIDAction.RemoveKey(id)) + case UpdateManagedDIDAction.AddService(service) => ZIO.succeed(UpdateDIDAction.AddService(service)) + case UpdateManagedDIDAction.RemoveService(id) => ZIO.succeed(UpdateDIDAction.RemoveService(id)) + case UpdateManagedDIDAction.UpdateService(patch) => + ZIO.succeed(UpdateDIDAction.UpdateService(patch.id, patch.serviceType, patch.serviceEndpoints)) + case UpdateManagedDIDAction.PatchContext(context) => ZIO.succeed(UpdateDIDAction.PatchContext(context)) + } + } + + 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 + ): UIO[KeyDerivationOutcome[PublicKey]] = { + val purpose = template.purpose + val keyPath = keyCounter.path(purpose) + for { + keyPair <- deriveSecp256k1KeyPair(seed, keyPath) + publicKey = PublicKey(template.id, purpose, toPublicKeyData(keyPair.publicKey)) + } yield KeyDerivationOutcome(publicKey, keyPath, keyCounter.next(purpose)) + } + + private def deriveInternalPublicKey(seed: Array[Byte])( + id: String, + purpose: InternalKeyPurpose, + keyCounter: HdKeyIndexCounter + ): UIO[KeyDerivationOutcome[InternalPublicKey]] = { + val keyPath = keyCounter.path(purpose) + for { + keyPair <- deriveSecp256k1KeyPair(seed, keyPath) + internalPublicKey = InternalPublicKey(id, purpose, toPublicKeyData(keyPair.publicKey)) + } yield KeyDerivationOutcome(internalPublicKey, keyPath, keyCounter.next(purpose)) + } + + private def deriveSecp256k1KeyPair(seed: Array[Byte], path: ManagedDIDHdKeyPath): UIO[Secp256k1KeyPair] = + apollo.secp256k1.deriveKeyPair(seed)(path.derivationPath: _*) + + 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/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/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultDIDSecretStorage.scala b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultDIDSecretStorage.scala new file mode 100644 index 0000000000..a334f0ac34 --- /dev/null +++ b/cloud-agent/service/wallet-api/src/main/scala/org/hyperledger/identus/agent/walletapi/vault/VaultDIDSecretStorage.scala @@ -0,0 +1,100 @@ +package org.hyperledger.identus.agent.walletapi.vault + +import com.nimbusds.jose.jwk.OctetKeyPair +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 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 + +class VaultDIDSecretStorage(vaultKV: VaultKVClient, useSemanticPath: Boolean) extends DIDSecretStorage { + + override def insertKey(did: DidId, keyId: String, keyPair: OctetKeyPair): RIO[WalletAccessContext, Int] = { + for { + walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId) + (path, metadata) = peerDidKeyPath(walletId)(did, keyId) + alreadyExist <- vaultKV.get[OctetKeyPair](path).map(_.isDefined) + _ <- vaultKV + .set[OctetKeyPair](path, keyPair, metadata) + .when(!alreadyExist) + .someOrFail(Exception(s"Secret on path $path already exists.")) + } yield 1 + } + + override def getKey(did: DidId, keyId: String): RIO[WalletAccessContext, Option[OctetKeyPair]] = { + for { + walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId) + (path, _) = peerDidKeyPath(walletId)(did, keyId) + keyPair <- vaultKV.get[OctetKeyPair](path) + } 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" + val relativePath = s"${did.value}/keys/$keyId" + 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) + } + } + + /** @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 { + def layer(useSemanticPath: Boolean): URLayer[VaultKVClient, DIDSecretStorage] = + ZLayer.fromFunction(VaultDIDSecretStorage(_, useSemanticPath)) +} 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 75% 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 2576b73a6b..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,9 +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.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.* @@ -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/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 88% 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 dede81bd06..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.* @@ -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/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/service/ManagedDIDServiceSpec.scala similarity index 93% 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 b7474f4d94..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.* @@ -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/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 84% 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 3822e6f195..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,22 +1,20 @@ -package io.iohk.atala.agent.walletapi.storage +package org.hyperledger.identus.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.{ +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.* @@ -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/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 51% 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 e8ba0ffad5..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,20 +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.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.* @@ -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/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 62% 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 cae3258cd1..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,16 +1,18 @@ -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.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 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.* +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/cloud-agent/service/wallet-api/src/test/scala/org/hyperledger/identus/agent/walletapi/util/OperationFactorySpec.scala similarity index 63% 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 c68e1076f2..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.* @@ -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/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/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 index 660755415e..a13c64e2d1 100644 --- a/infrastructure/ci/docker-compose-multiple-actors.yml +++ b/infrastructure/ci/docker-compose-multiple-actors.yml @@ -82,7 +82,7 @@ services: ##########################c prism-agent-issuer: - image: ghcr.io/input-output-hk/prism-agent:0.5.0 + image: ghcr.io/hyperledger/prism-agent:0.5.0 environment: REST_SERVICE_PORT: 8080 DIDCOMM_SERVICE_PORT: 8081 @@ -115,7 +115,7 @@ services: retries: 5 prism-agent-holder: - image: ghcr.io/input-output-hk/prism-agent:0.5.0 + image: ghcr.io/hyperledger/prism-agent:0.5.0 environment: REST_SERVICE_PORT: 8090 DIDCOMM_SERVICE_PORT: 8091 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 aae1127117..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/input-output-hk/prism-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 aa15f60155..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/input-output-hk/prism-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 01bcd0dd58..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/input-output-hk/prism-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 d153375e02..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/input-output-hk/prism-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/input-output-hk/prism-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/input-output-hk/prism-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/dif/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/dif/ProposeCredential.scala rename to mercury/vc/src/main/scala/io/iohk/atala/mercury/vc/dif/ProposeCredential.scala index df53ca6dc1..0e832e405e 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/dif/ProposeCredential.scala @@ -1,4 +1,4 @@ -package io.iohk.atala.mercury.vc.dif +package org.hyperledger.identus.vc.dif type DID = String 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/jwt/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/jwt/ProposeCredential.scala index 01caa50161..27996720b3 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/jwt/ProposeCredential.scala @@ -1,4 +1,4 @@ -package io.iohk.atala.mercury.vc.jwt +package org.hyperledger.identus.vc.jwt type DID = String diff --git a/package.json b/package.json index 13262facb7..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}\"" } ], [ @@ -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} ./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/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container/MigrationAspect.scala b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/test/container/MigrationAspect.scala similarity index 96% rename from pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container/MigrationAspect.scala rename to pollux/sql-doobie/src/test/scala/org/hyperledger/identus/test/container/MigrationAspect.scala index b12338d17f..881afaccff 100644 --- a/pollux/lib/sql-doobie/src/test/scala/io/iohk/atala/test/container/MigrationAspect.scala +++ b/pollux/sql-doobie/src/test/scala/org/hyperledger/identus/test/container/MigrationAspect.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/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/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/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/service/handler/DIDCreateHandler.scala b/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDCreateHandler.scala deleted file mode 100644 index e21f2e02ad..0000000000 --- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDCreateHandler.scala +++ /dev/null @@ -1,65 +0,0 @@ -package io.iohk.atala.agent.walletapi.service.handler - -import io.iohk.atala.agent.walletapi.model.CreateDIDHdKey -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.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.models.WalletAccessContext -import zio.* - -private[walletapi] class DIDCreateHandler( - apollo: Apollo, - nonSecretStorage: DIDNonSecretStorage, - walletSecretStorage: WalletSecretStorage, -)( - masterKeyId: String -) { - def materialize( - didTemplate: ManagedDIDTemplate - ): ZIO[WalletAccessContext, CreateManagedDIDError, DIDCreateMaterial] = { - val operationFactory = OperationFactory(apollo) - for { - walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId) - seed <- walletSecretStorage.getWalletSeed - .someOrElseZIO(ZIO.dieMessage(s"Wallet seed for wallet $walletId does not exist")) - .mapError(CreateManagedDIDError.WalletStorageError.apply) - didIndex <- nonSecretStorage - .getMaxDIDIndex() - .mapBoth( - CreateManagedDIDError.WalletStorageError.apply, - maybeIdx => maybeIdx.map(_ + 1).getOrElse(0) - ) - generated <- operationFactory.makeCreateOperationHdKey(masterKeyId, seed.toByteArray)(didIndex, didTemplate) - (createOperation, hdKey) = generated - state = ManagedDIDState(createOperation, didIndex, PublicationState.Created()) - } yield DIDCreateMaterialImpl(nonSecretStorage)(createOperation, state, hdKey) - } -} - -private[walletapi] trait DIDCreateMaterial { - def operation: PrismDIDOperation.Create - def state: ManagedDIDState - def persist: RIO[WalletAccessContext, Unit] -} - -private[walletapi] class DIDCreateMaterialImpl(nonSecretStorage: DIDNonSecretStorage)( - val operation: PrismDIDOperation.Create, - val state: ManagedDIDState, - hdKey: CreateDIDHdKey -) extends DIDCreateMaterial { - def persist: RIO[WalletAccessContext, Unit] = { - val did = operation.did - for { - _ <- nonSecretStorage - .insertManagedDID(did, state, hdKey.keyPaths ++ hdKey.internalKeyPaths) - .mapError(CreateManagedDIDError.WalletStorageError.apply) - } 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 deleted file mode 100644 index 93670fd857..0000000000 --- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/DIDUpdateHandler.scala +++ /dev/null @@ -1,112 +0,0 @@ -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.ManagedDIDState -import io.iohk.atala.agent.walletapi.model.UpdateDIDHdKey -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.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.models.WalletAccessContext -import scala.collection.immutable.ArraySeq -import zio.* - -private[walletapi] class DIDUpdateHandler( - apollo: Apollo, - nonSecretStorage: DIDNonSecretStorage, - walletSecretStorage: WalletSecretStorage, - publicationHandler: PublicationHandler -) { - def materialize( - state: ManagedDIDState, - previousOperationHash: Array[Byte], - actions: Seq[UpdateManagedDIDAction] - ): 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) - } - } -} - -private[walletapi] trait DIDUpdateMaterial { - - def operation: PrismDIDOperation.Update - - def signedOperation: SignedPrismDIDOperation - - def state: ManagedDIDState - - def persist: RIO[WalletAccessContext, Unit] - - protected final def persistUpdateLineage(nonSecretStorage: DIDNonSecretStorage): RIO[WalletAccessContext, Unit] = { - val did = operation.did - for { - updateLineage <- Clock.instant.map { now => - DIDUpdateLineage( - operationId = ArraySeq.from(signedOperation.toAtalaOperationId), - operationHash = ArraySeq.from(operation.toAtalaOperationHash), - previousOperationHash = operation.previousOperationHash, - status = ScheduledDIDOperationStatus.Pending, - createdAt = now, - updatedAt = now - ) - } - _ <- nonSecretStorage.insertDIDUpdateLineage(did, updateLineage) - } yield () - } - -} - -private class HdKeyUpdateMaterial(nonSecretStorage: DIDNonSecretStorage)( - val operation: PrismDIDOperation.Update, - val signedOperation: SignedPrismDIDOperation, - val state: ManagedDIDState, - hdKey: UpdateDIDHdKey -) 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) - } - } - - override def persist: RIO[WalletAccessContext, Unit] = - for { - _ <- persistKeyMaterial - _ <- persistUpdateLineage(nonSecretStorage) - } yield () - -} 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 deleted file mode 100644 index debc2ff156..0000000000 --- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/service/handler/PublicationHandler.scala +++ /dev/null @@ -1,46 +0,0 @@ -package io.iohk.atala.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.models.WalletAccessContext -import scala.collection.immutable.ArraySeq -import scala.language.implicitConversions -import zio.* - -class PublicationHandler(didService: DIDService, keyResolver: KeyResolver)(masterKeyId: String) { - def signOperationWithMasterKey[E](state: ManagedDIDState, operation: PrismDIDOperation)(using - c1: Conversion[CommonWalletStorageError, E], - c2: Conversion[CommonCryptographyError, E] - ): ZIO[WalletAccessContext, E, SignedPrismDIDOperation] = { - 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")) - ) - signedOperation <- ZIO - .succeed(masterKeyPair.privateKey.sign(operation.toAtalaOperation.toByteArray)) - .map(signature => - SignedPrismDIDOperation( - operation = operation, - signature = ArraySeq.from(signature), - signedWithKey = masterKeyId - ) - ) - } yield signedOperation - } - - def submitSignedOperation[E]( - signedOperation: SignedPrismDIDOperation - )(using c1: Conversion[DIDOperationError, E]): IO[E, ScheduleDIDOperationOutcome] = - didService.scheduleOperation(signedOperation).mapError[E](e => e) -} 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 deleted file mode 100644 index 134d614c2d..0000000000 --- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/sql/JdbcDIDSecretStorage.scala +++ /dev/null @@ -1,72 +0,0 @@ -package io.iohk.atala.agent.walletapi.sql - -import com.nimbusds.jose.jwk.OctetKeyPair -import doobie.* -import doobie.implicits.* -import io.iohk.atala.agent.walletapi.storage.DIDSecretStorage -import io.iohk.atala.mercury.model.DidId -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 - -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()) - - given didIdGet: Get[DidId] = Get[String].map(DidId(_)) - - given didIdPut: Put[DidId] = Put[String].contramap(_.value) - - override def getKey(did: DidId, keyId: String): RIO[WalletAccessContext, Option[OctetKeyPair]] = { - val cxnIO = sql""" - | SELECT key_pair - | FROM public.peer_did_rand_key - | WHERE - | did = $did - | AND key_id = $keyId - """.stripMargin - .query[OctetKeyPair] - .option - - cxnIO.transactWallet(xa) - } - - override def insertKey(did: DidId, keyId: String, keyPair: OctetKeyPair): RIO[WalletAccessContext, Int] = { - val cxnIO = (now: InstantAsBigInt) => sql""" - | INSERT INTO public.peer_did_rand_key( - | did, - | created_at, - | key_id, - | key_pair - | ) values ( - | ${did}, - | ${now}, - | ${keyId}, - | ${keyPair} - | ) - """.stripMargin.update - - for { - now <- Clock.instant - result <- cxnIO(InstantAsBigInt(now)).run.transactWallet(xa) - } yield result - } - -} - -object JdbcDIDSecretStorage { - val layer: URLayer[Transactor[ContextAwareTask], DIDSecretStorage] = - ZLayer.fromFunction(new JdbcDIDSecretStorage(_)) -} 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 deleted file mode 100644 index 1f1e2f3f1c..0000000000 --- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/storage/DIDSecretStorage.scala +++ /dev/null @@ -1,12 +0,0 @@ -package io.iohk.atala.agent.walletapi.storage - -import com.nimbusds.jose.jwk.OctetKeyPair -import io.iohk.atala.mercury.model.DidId -import io.iohk.atala.shared.models.WalletAccessContext -import zio.* - -/** A simple single-user DID key storage */ -trait DIDSecretStorage { - def insertKey(did: DidId, keyId: String, keyPair: OctetKeyPair): RIO[WalletAccessContext, Int] - def getKey(did: DidId, keyId: String): RIO[WalletAccessContext, Option[OctetKeyPair]] -} 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/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 deleted file mode 100644 index d5c02f9216..0000000000 --- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/KeyResolver.scala +++ /dev/null @@ -1,46 +0,0 @@ -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.WalletSeed -import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage -import io.iohk.atala.agent.walletapi.storage.WalletSecretStorage -import io.iohk.atala.castor.core.model.did.PrismDID -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) - } - - def getKey( - did: PrismDID, - keyMode: KeyManagementMode, - keyId: String - ): RIO[WalletAccessContext, Option[Secp256k1KeyPair]] = { - keyMode match { - case KeyManagementMode.HD => resolveHdKey(did, keyId) - } - } - - 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 - } -} 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 deleted file mode 100644 index 2734901a42..0000000000 --- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/ManagedDIDTemplateValidator.scala +++ /dev/null @@ -1,18 +0,0 @@ -package io.iohk.atala.agent.walletapi.util - -import io.iohk.atala.agent.walletapi.model.ManagedDIDTemplate -import io.iohk.atala.agent.walletapi.service.ManagedDIDService - -object ManagedDIDTemplateValidator { - - def validate(template: ManagedDIDTemplate): Either[String, Unit] = validateReservedKeyId(template) - - private def validateReservedKeyId(template: ManagedDIDTemplate): Either[String, Unit] = { - val keyIds = template.publicKeys.map(_.id) - val reservedKeyIds = keyIds.filter(id => ManagedDIDService.reservedKeyIds.contains(id)) - if (reservedKeyIds.nonEmpty) - Left(s"DID template cannot contain reserved key name: ${reservedKeyIds.mkString("[", ", ", "]")}") - else Right(()) - } - -} 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 deleted file mode 100644 index 883ea4b9a0..0000000000 --- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/util/OperationFactory.scala +++ /dev/null @@ -1,218 +0,0 @@ -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.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.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 - -private[util] final case class KeyDerivationOutcome[PK]( - publicKey: PK, - path: ManagedDIDHdKeyPath, - nextCounter: HdKeyIndexCounter -) - -class OperationFactory(apollo: Apollo) { - - /** Generates a key pair and a public key from a DID template - * - * @param masterKeyId - * The key id of the master key - * @param seed - * The seed to use for the key generation - * @param didTemplate - * The DID template - * @param didIndex - * The index of the DID to be used for the key derivation - */ - def makeCreateOperationHdKey( - masterKeyId: String, - seed: Array[Byte] - )( - didIndex: Int, - didTemplate: ManagedDIDTemplate - ): IO[CreateManagedDIDError, (PrismDIDOperation.Create, CreateDIDHdKey)] = { - val initKeysWithCounter = (Vector.empty[(PublicKey, ManagedDIDHdKeyPath)], HdKeyIndexCounter.zero(didIndex)) - 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) - } - } - masterKeyOutcome <- deriveInternalPublicKey(seed)( - masterKeyId, - InternalKeyPurpose.Master, - keysWithCounter._2 - ) - operation = PrismDIDOperation.Create( - publicKeys = keysWithCounter._1.map(_._1) ++ 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), - ) - } yield operation -> hdKeys - } - - 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])( - did: CanonicalPrismDID, - previousOperationHash: Array[Byte], - actions: Seq[UpdateManagedDIDAction], - fromKeyCounter: HdKeyIndexCounter - ): IO[UpdateManagedDIDError, (PrismDIDOperation.Update, UpdateDIDHdKey)] = { - val initKeysWithCounter = - (Vector.empty[(UpdateManagedDIDAction, Option[(PublicKey, ManagedDIDHdKeyPath)])], 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 - } - derivation.map { - case Some(outcome) => (acc :+ (action -> Some((outcome.publicKey, outcome.path))), outcome.nextCounter) - case None => (acc :+ (action -> None), keyCounter) - } - } - - for { - actionsWithKeyMaterial <- actionsWithKeyMaterial - (actionWithHdKey, keyCounter) = actionsWithKeyMaterial - transformedActions <- ZIO.foreach(actionWithHdKey) { case (action, keyMaterial) => - transformUpdateAction(action, keyMaterial.map(_._1)) - } - keys = actionWithHdKey.collect { case (UpdateManagedDIDAction.AddKey(_), Some(secret)) => secret } - operation = PrismDIDOperation.Update( - did = did, - previousOperationHash = ArraySeq.from(previousOperationHash), - actions = transformedActions - ) - hdKeys = UpdateDIDHdKey( - // 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, - 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) - } - - private def transformUpdateAction( - updateAction: UpdateManagedDIDAction, - publicKey: Option[PublicKey] - ): UIO[UpdateDIDAction] = { - updateAction match { - case UpdateManagedDIDAction.AddKey(_) => - publicKey match { - case Some(publicKey) => ZIO.succeed(UpdateDIDAction.AddKey(publicKey)) - case None => - // should be impossible otherwise it's a defect - ZIO.dieMessage("addKey update DID action must have a generated a key-pair") - } - case UpdateManagedDIDAction.RemoveKey(id) => ZIO.succeed(UpdateDIDAction.RemoveKey(id)) - case UpdateManagedDIDAction.AddService(service) => ZIO.succeed(UpdateDIDAction.AddService(service)) - case UpdateManagedDIDAction.RemoveService(id) => ZIO.succeed(UpdateDIDAction.RemoveService(id)) - case UpdateManagedDIDAction.UpdateService(patch) => - ZIO.succeed(UpdateDIDAction.UpdateService(patch.id, patch.serviceType, patch.serviceEndpoints)) - case UpdateManagedDIDAction.PatchContext(context) => ZIO.succeed(UpdateDIDAction.PatchContext(context)) - } - } - - private def derivePublicKey(seed: Array[Byte])( - template: DIDPublicKeyTemplate, - keyCounter: HdKeyIndexCounter - ): UIO[KeyDerivationOutcome[PublicKey]] = { - val purpose = template.purpose - val keyPath = keyCounter.path(purpose) - for { - keyPair <- deriveSecp256k1KeyPair(seed, keyPath) - publicKey = PublicKey(template.id, purpose, toPublicKeyData(keyPair.publicKey)) - } yield KeyDerivationOutcome(publicKey, keyPath, keyCounter.next(purpose)) - } - - private def deriveInternalPublicKey(seed: Array[Byte])( - id: String, - purpose: InternalKeyPurpose, - keyCounter: HdKeyIndexCounter - ): UIO[KeyDerivationOutcome[InternalPublicKey]] = { - val keyPath = keyCounter.path(purpose) - for { - keyPair <- deriveSecp256k1KeyPair(seed, keyPath) - internalPublicKey = InternalPublicKey(id, purpose, toPublicKeyData(keyPair.publicKey)) - } yield KeyDerivationOutcome(internalPublicKey, keyPath, keyCounter.next(purpose)) - } - - private def deriveSecp256k1KeyPair(seed: Array[Byte], path: ManagedDIDHdKeyPath): UIO[ECKeyPair] = - apollo.secp256k1.deriveKeyPair(seed)(path.derivationPath: _*) - - private def toPublicKeyData(publicKey: ECPublicKey): PublicKeyData = PublicKeyData.ECCompressedKeyData( - crv = EllipticCurve.SECP256K1, - data = Base64UrlString.fromByteArray(publicKey.getEncodedCompressed), - ) - -} 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 deleted file mode 100644 index 133572740c..0000000000 --- a/prism-agent/service/wallet-api/src/main/scala/io/iohk/atala/agent/walletapi/vault/VaultDIDSecretStorage.scala +++ /dev/null @@ -1,51 +0,0 @@ -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.mercury.model.DidId -import io.iohk.atala.prism.crypto.Sha256 -import io.iohk.atala.shared.models.WalletAccessContext -import io.iohk.atala.shared.models.WalletId -import zio.* - -import java.nio.charset.StandardCharsets - -class VaultDIDSecretStorage(vaultKV: VaultKVClient, useSemanticPath: Boolean) extends DIDSecretStorage { - - override def insertKey(did: DidId, keyId: String, keyPair: OctetKeyPair): RIO[WalletAccessContext, Int] = { - for { - walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId) - (path, metadata) = peerDidKeyPath(walletId)(did, keyId) - alreadyExist <- vaultKV.get[OctetKeyPair](path).map(_.isDefined) - _ <- vaultKV - .set[OctetKeyPair](path, keyPair, metadata) - .when(!alreadyExist) - .someOrFail(Exception(s"Secret on path $path already exists.")) - } yield 1 - } - - override def getKey(did: DidId, keyId: String): RIO[WalletAccessContext, Option[OctetKeyPair]] = { - for { - walletId <- ZIO.serviceWith[WalletAccessContext](_.walletId) - (path, _) = peerDidKeyPath(walletId)(did, keyId) - keyPair <- vaultKV.get[OctetKeyPair](path) - } yield keyPair - } - - /** @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" - val relativePath = s"${did.value}/keys/$keyId" - 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 { - def layer(useSemanticPath: Boolean): URLayer[VaultKVClient, DIDSecretStorage] = - ZLayer.fromFunction(VaultDIDSecretStorage(_, useSemanticPath)) -} 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 1762405ae2..0000000000 --- a/prism-agent/service/wallet-api/src/test/scala/io/iohk/atala/agent/walletapi/storage/JdbcDIDNonSecretStorageSpec.scala +++ /dev/null @@ -1,285 +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 - ) - _ <- 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")).map(_._1) - createOperation2 <- generateCreateOperation(Seq("key-1")).map(_._1) - _ <- storage.insertManagedDID( - did1, - ManagedDIDState(createOperation1, 0, PublicationState.Created()), - Map.empty - ) - _ <- storage.insertManagedDID( - did2, - ManagedDIDState(createOperation2, 1, PublicationState.Created()), - 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)(_ => generateCreateOperation(Seq("key-1")).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)(_ => generateCreateOperation(Seq("key-1")).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)(_ => generateCreateOperation(Seq("key-1")).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)(_ => generateCreateOperation(Seq("key-1")).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)(_ => generateCreateOperation(Seq("key-1")).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)(_ => generateCreateOperation(Seq("key-1")).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 = generateCreateOperationHdKey(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) - 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/KmpApollo.scala b/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/KmpApollo.scala deleted file mode 100644 index a5410add2f..0000000000 --- a/shared/crypto/src/main/scala/io/iohk/atala/shared/crypto/KmpApollo.scala +++ /dev/null @@ -1,97 +0,0 @@ -package io.iohk.atala.shared.crypto - -import io.iohk.atala.prism.apollo.derivation -import io.iohk.atala.prism.apollo.derivation.MnemonicHelper -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 zio.* - -import scala.jdk.CollectionConverters.* -import scala.util.{Try, Success, Failure} - -final case class KmpSecp256k1PublicKey(publicKey: KMMECSecp256k1PublicKey) extends Secp256k1PublicKey { - - override def getECPoint: ECPoint = { - val point = publicKey.getCurvePoint() - val x = BigInt(1, point.getX()) - val y = BigInt(1, point.getY()) - ECPoint(x, y) - } - - override def getEncoded: Array[Byte] = publicKey.getCompressed() - - override def getEncodedCompressed: Array[Byte] = getEncoded - - override def getEncodedUncompressed: Array[Byte] = - KmpSecp256k1KeyOps.secpLib.uncompressPublicKey(getEncodedCompressed) - - override def verify(data: Array[Byte], signature: Array[Byte]): Try[Unit] = - Try(publicKey.verify(signature, data)) - .flatMap(isValid => if (isValid) Success(()) else Failure(Exception("The signature verification does not match"))) -} - -final case class KmpSecp256k1PrivateKey(privateKey: KMMECSecp256k1PrivateKey) extends Secp256k1PrivateKey { - override def sign(data: Array[Byte]): Array[Byte] = privateKey.sign(data) - - override def toPublicKey: Secp256k1PublicKey = KmpSecp256k1PublicKey(privateKey.getPublicKey()) - - override def getEncoded: Array[Byte] = privateKey.getEncoded() -} - -object KmpSecp256k1KeyOps extends Secp256k1KeyOps { - private[crypto] val secpLib: Secp256k1Lib = Secp256k1Lib() - private[crypto] val secureRandom: SecureRandom = SecureRandom() - - override def publicKeyFromEncoded(bytes: Array[Byte]): Try[Secp256k1PublicKey] = - Try { - val publicKey = KMMECSecp256k1PublicKey.Companion.secp256k1FromBytes(bytes) - val point = publicKey.getCurvePoint() - val isOnCurve = KMMECSecp256k1PublicKey.Companion.isPointOnSecp256k1Curve(point) - if (isOnCurve) KmpSecp256k1PublicKey(publicKey) - else throw new Exception("The public key 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 - - def randomBip32Seed: UIO[(Array[Byte], Seq[String])] = - ZIO.attemptBlocking { - val words = MnemonicHelper.Companion.createRandomMnemonics() - val seed = MnemonicHelper.Companion.createSeed(words, "") - seed -> words.asScala.toList - }.orDie - - def deriveKeyPair(seed: Array[Byte])(path: DerivationPath*): UIO[Secp256k1KeyPair] = - ZIO.attemptBlocking { - val pathStr = path - .foldLeft(derivation.DerivationPath.empty()) { case (path, p) => - p match { - case DerivationPath.Hardened(i) => path.derive(derivation.DerivationAxis.hardened(i)) - case DerivationPath.Normal(i) => path.derive(derivation.DerivationAxis.normal(i)) - } - } - .toString() - val hdKey = derivation.HDKey(seed, 0, 0).derive(pathStr) - val privateKey = hdKey.getKMMSecp256k1PrivateKey() - val publicKey = privateKey.getPublicKey() - - Secp256k1KeyPair( - KmpSecp256k1PublicKey(publicKey), - KmpSecp256k1PrivateKey(privateKey) - ) - }.orDie - -} 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 88% 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 d2760358ab..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 @@ -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/org/hyperledger/identus/shared/crypto/KmpApollo.scala b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/KmpApollo.scala new file mode 100644 index 0000000000..4d043521fd --- /dev/null +++ b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/KmpApollo.scala @@ -0,0 +1,177 @@ +package org.hyperledger.identus.shared.crypto + +import io.iohk.atala.prism.apollo.derivation +import io.iohk.atala.prism.apollo.derivation.MnemonicHelper +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.* +import scala.util.{Try, Success, Failure} + +final case class KmpSecp256k1PublicKey(publicKey: KMMECSecp256k1PublicKey) extends Secp256k1PublicKey { + + override def getECPoint: ECPoint = { + val point = publicKey.getCurvePoint() + ECPoint(point.getX(), point.getY()) + } + + override def getEncoded: Array[Byte] = publicKey.getCompressed() + + override def getEncodedCompressed: Array[Byte] = getEncoded + + override def getEncodedUncompressed: Array[Byte] = + KmpSecp256k1KeyOps.secpLib.uncompressPublicKey(getEncodedCompressed) + + override def verify(data: Array[Byte], signature: Array[Byte]): Try[Unit] = + Try(publicKey.verify(signature, data)) + .flatMap(isValid => if (isValid) Success(()) else Failure(Exception("The signature verification does not match"))) +} + +final case class KmpSecp256k1PrivateKey(privateKey: KMMECSecp256k1PrivateKey) extends Secp256k1PrivateKey { + override def sign(data: Array[Byte]): Array[Byte] = privateKey.sign(data) + + override def toPublicKey: Secp256k1PublicKey = KmpSecp256k1PublicKey(privateKey.getPublicKey()) + + override def getEncoded: Array[Byte] = privateKey.getEncoded() +} + +object KmpSecp256k1KeyOps extends Secp256k1KeyOps { + private[crypto] val secpLib: Secp256k1Lib = Secp256k1Lib() + private[crypto] val secureRandom: SecureRandom = SecureRandom() + + override def publicKeyFromEncoded(bytes: Array[Byte]): Try[Secp256k1PublicKey] = + Try { + val publicKey = KMMECSecp256k1PublicKey.Companion.secp256k1FromBytes(bytes) + val point = publicKey.getCurvePoint() + val isOnCurve = KMMECSecp256k1PublicKey.Companion.isPointOnSecp256k1Curve(point) + if (isOnCurve) KmpSecp256k1PublicKey(publicKey) + 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: 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 { + val words = MnemonicHelper.Companion.createRandomMnemonics() + val seed = MnemonicHelper.Companion.createSeed(words, "") + seed -> words.asScala.toList + }.orDie + + def deriveKeyPair(seed: Array[Byte])(path: DerivationPath*): UIO[Secp256k1KeyPair] = + ZIO.attemptBlocking { + val pathStr = path + .foldLeft(derivation.DerivationPath.empty()) { case (path, p) => + p match { + case DerivationPath.Hardened(i) => path.derive(derivation.DerivationAxis.hardened(i)) + case DerivationPath.Normal(i) => path.derive(derivation.DerivationAxis.normal(i)) + } + } + .toString() + val hdKey = derivation.HDKey(seed, 0, 0).derive(pathStr) + val privateKey = hdKey.getKMMSecp256k1PrivateKey() + val publicKey = privateKey.getPublicKey() + + Secp256k1KeyPair( + KmpSecp256k1PublicKey(publicKey), + KmpSecp256k1PrivateKey(privateKey) + ) + }.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/org/hyperledger/identus/shared/crypto/Prism14Apollo.scala b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/Prism14Apollo.scala new file mode 100644 index 0000000000..6501618619 --- /dev/null +++ b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/Prism14Apollo.scala @@ -0,0 +1,96 @@ +package org.hyperledger.identus.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/org/hyperledger/identus/shared/crypto/jwk/JWK.scala b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/jwk/JWK.scala new file mode 100644 index 0000000000..fb6e7167e4 --- /dev/null +++ b/shared/crypto/src/main/scala/org/hyperledger/identus/shared/crypto/jwk/JWK.scala @@ -0,0 +1,61 @@ +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 org.hyperledger.identus.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/org/hyperledger/identus/shared/crypto/ApolloSpec.scala similarity index 93% 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 85a954ebba..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,27 +1,27 @@ -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 { 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] 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/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 ?: ""), 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: 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 100% rename from tests/performance-tests/atala-performance-tests-k6/webpack.config.js rename to tests/performance-tests/agent-performance-tests-k6/webpack.config.js 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" -