Skip to content

Commit

Permalink
fix(prism-agent): use internal DIDComm service port defined in agent …
Browse files Browse the repository at this point in the history
…config

Signed-off-by: Benjamin Voiturier <benjamin.voiturier@iohk.io>
  • Loading branch information
bvoiturier committed Oct 13, 2023
1 parent d36533f commit 503dd39
Show file tree
Hide file tree
Showing 6 changed files with 25 additions and 32 deletions.
10 changes: 8 additions & 2 deletions prism-agent/service/server/src/main/resources/application.conf
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,14 @@ agent {
port =${?AGENT_HTTP_PORT}
}
}
didCommEndpoint {
http {
port = 8090
port =${?AGENT_DIDCOMM_PORT}
}
publicEndpointUrl = "http://localhost:8090"
publicEndpointUrl = ${?DIDCOMM_SERVICE_URL}
}
authentication {
admin {
token = "admin"
Expand Down Expand Up @@ -114,8 +122,6 @@ agent {
autoProvisioning = ${?API_KEY_AUTO_PROVISIONING}
}
}
didCommServiceEndpointUrl = "http://localhost:8090"
didCommServiceEndpointUrl = ${?DIDCOMM_SERVICE_URL}
restServiceUrl = "https://host.docker.internal:8080/prism-agent"
restServiceUrl = ${?REST_SERVICE_URL}
database {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,20 +23,23 @@ import io.iohk.atala.resolvers.DIDResolver
import io.iohk.atala.shared.models.WalletAccessContext
import zio.*
import zio.http.*

import java.util.UUID

object DidCommHttpServer {

def run(didCommServicePort: Int) = {
val server = {
def run = {
def server(didCommServicePort: Int) = {
val config = Server.Config.default.copy(address = new java.net.InetSocketAddress(didCommServicePort))
ZLayer.succeed(config) >>> Server.live
}
for {
appConfig <- ZIO.service[AppConfig]
didCommServicePort = appConfig.agent.didCommEndpoint.http.port
_ <- ZIO.logInfo(s"Server Started on port $didCommServicePort")
_ <- Server
.serve(didCommServiceEndpoint)
.provideSomeLayer(server)
.provideSomeLayer(server(didCommServicePort))
.debug *> ZIO
.logWarning(s"Server STOP (on port $didCommServicePort)")
.tapDefect(error => ZIO.logErrorCause("Defect processing incoming DIDComm message", Cause.fail(error)))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -105,23 +105,10 @@ object MainApp extends ZIOAppDefault {
|""".stripMargin)
.ignore

didCommServiceUrl <- System.env("DIDCOMM_SERVICE_URL").map {
case Some(s) => s
case _ => "http://localhost:8090"
}
_ <- ZIO.logInfo(s"DIDComm Service URL => $didCommServiceUrl")

didCommServicePort <- System.env("DIDCOMM_SERVICE_PORT").map {
case Some(s) if s.toIntOption.isDefined => s.toInt
case _ => 8090
}
_ <- ZIO.logInfo(s"DIDComm Service port => $didCommServicePort")

_ <- preMigrations
_ <- migrations

app <- PrismAgentApp
.run(didCommServicePort)
app <- PrismAgentApp.run
.provide(
DidCommX.liveLayer,
// infra
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,10 @@ 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.{
IssueBackgroundJobs,
ConnectBackgroundJobs,
DIDStateSyncBackgroundJobs,
PresentBackgroundJobs
}
import io.iohk.atala.agent.server.jobs.{ConnectBackgroundJobs, DIDStateSyncBackgroundJobs, IssueBackgroundJobs, PresentBackgroundJobs}
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
Expand All @@ -29,22 +25,21 @@ 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, WalletId}
import io.iohk.atala.shared.utils.DurationOps.toMetricsSeconds
import io.iohk.atala.system.controller.SystemServerEndpoints
import zio.*
import zio.metrics.*
import io.iohk.atala.shared.utils.DurationOps.toMetricsSeconds
import io.iohk.atala.agent.walletapi.storage.DIDNonSecretStorage

object PrismAgentApp {

def run(didCommServicePort: Int) = for {
def run = for {
_ <- AgentInitialization.run
_ <- issueCredentialDidCommExchangesJob.debug.fork
_ <- presentProofExchangeJob.debug.fork
_ <- connectDidCommExchangesJob.debug.fork
_ <- syncDIDPublicationStateFromDltJob.fork
_ <- AgentHttpServer.run.fork
fiber <- DidCommHttpServer.run(didCommServicePort).fork
fiber <- DidCommHttpServer.run.fork
_ <- WebhookPublisher.layer.build.map(_.get[WebhookPublisher]).flatMap(_.run.debug.fork)
_ <- fiber.join *> ZIO.log(s"Server End")
_ <- ZIO.never
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -124,8 +124,8 @@ final case class DefaultWalletConfig(

final case class AgentConfig(
httpEndpoint: HttpEndpointConfig,
didCommEndpoint: DidCommEndpointConfig,
authentication: AuthenticationConfig,
didCommServiceEndpointUrl: String,
restServiceUrl: String,
database: DatabaseConfig,
verification: VerificationConfig,
Expand All @@ -143,6 +143,8 @@ final case class AgentConfig(

final case class HttpEndpointConfig(http: HttpConfig)

final case class DidCommEndpointConfig(http: HttpConfig, publicEndpointUrl: String)

final case class HttpConfig(port: Int)

final case class SecretStorageConfig(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ class ConnectionControllerImpl(
rc: RequestContext
): ZIO[WalletAccessContext, ErrorResponse, Connection] = {
val result = for {
pairwiseDid <- managedDIDService.createAndStorePeerDID(appConfig.agent.didCommServiceEndpointUrl)
pairwiseDid <- managedDIDService.createAndStorePeerDID(appConfig.agent.didCommEndpoint.publicEndpointUrl)
connection <- service.createConnectionInvitation(request.label, pairwiseDid.did)
} yield Connection.fromDomain(connection)

Expand Down Expand Up @@ -66,7 +66,7 @@ class ConnectionControllerImpl(
)(implicit rc: RequestContext): ZIO[WalletAccessContext, ErrorResponse, Connection] = {
val result = for {
record <- service.receiveConnectionInvitation(request.invitation)
pairwiseDid <- managedDIDService.createAndStorePeerDID(appConfig.agent.didCommServiceEndpointUrl)
pairwiseDid <- managedDIDService.createAndStorePeerDID(appConfig.agent.didCommEndpoint.publicEndpointUrl)
connection <- service.acceptConnectionInvitation(record.id, pairwiseDid.did)
} yield Connection.fromDomain(connection)

Expand Down

0 comments on commit 503dd39

Please sign in to comment.