Skip to content

Commit

Permalink
fix: Add expiration time for cloud-agent (#1132)
Browse files Browse the repository at this point in the history
Signed-off-by: mineme0110 <shailesh.patil@iohk.io>
  • Loading branch information
mineme0110 authored Jun 3, 2024
1 parent 9f1bb9c commit f719120
Show file tree
Hide file tree
Showing 8 changed files with 30 additions and 23 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ pollux {
awaitConnectionThreads = 4
awaitConnectionThreads = ${?POLLUX_DB_AWAIT_CONNECTION_THREADS}
}
credentialSdJwtExpirationTime = 30 days // Default exp claim duration in days sd jwt token if not provided in credential offer
statusListRegistry {
# defaults to the exposed AGENT_HTTP_PORT port
publicEndpointUrl = "http://localhost:"${agent.httpEndpoint.http.port}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ object ValidatedVaultConfig {

final case class PolluxConfig(
database: DatabaseConfig,
credentialSdJwtExpirationTime: Duration,
statusListRegistry: StatusListRegistryConfig,
issueBgJobRecordsLimit: Int,
issueBgJobRecurrenceDelay: Duration,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -495,7 +495,7 @@ object IssueBackgroundJobs extends BackgroundJobsHelper {
credentialService <- ZIO.service[CredentialService]
config <- ZIO.service[AppConfig]
_ <- credentialService
.generateSDJWTCredential(id)
.generateSDJWTCredential(id, config.pollux.credentialSdJwtExpirationTime)
.provideSomeLayer(ZLayer.succeed(walletAccessContext))
} yield ()).mapError(e => (walletAccessContext, e))
} yield result
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ 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 zio.{Duration, IO, ZIO}

import java.nio.charset.StandardCharsets
import java.util.UUID
Expand Down Expand Up @@ -118,6 +118,7 @@ trait CredentialService {

def generateSDJWTCredential(
recordId: DidCommID,
expirationTime: Duration,
): ZIO[WalletAccessContext, CredentialServiceError, IssueCredentialRecord]

def generateAnonCredsCredential(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -607,11 +607,7 @@ private class CredentialServiceImpl(
for {
ed25519keyPair <- getEd25519SigningKeyPair(jwtIssuerDID, verificationRelationship)
} yield {

val d = java.util.Base64.getUrlEncoder.withoutPadding().encodeToString(ed25519keyPair.privateKey.getEncoded)
val x = java.util.Base64.getUrlEncoder.withoutPadding().encodeToString(ed25519keyPair.publicKey.getEncoded)
val okpJson = s"""{"kty":"OKP","crv":"Ed25519","d":"$d","x":"$x"}"""
val octetKeyPair = OctetKeyPair.parse(okpJson)
val octetKeyPair = ed25519keyPair.toOctetKeyPair
JwtIssuer(
org.hyperledger.identus.pollux.vc.jwt.DID(jwtIssuerDID.toString),
EdSigner(ed25519keyPair),
Expand Down Expand Up @@ -1326,6 +1322,7 @@ private class CredentialServiceImpl(
// Issuer Generating the credential
override def generateSDJWTCredential(
recordId: DidCommID,
expirationTime: Duration,
): ZIO[WalletAccessContext, CredentialServiceError, IssueCredentialRecord] = {
for {
record <- getRecordWithState(recordId, ProtocolState.CredentialPending)
Expand Down Expand Up @@ -1364,17 +1361,24 @@ private class CredentialServiceImpl(
preview = offerCredentialData.body.credential_preview
claims <- CredentialService.convertAttributesToJsonClaims(preview.body.attributes)
sdJwtPrivateKey = sdjwt.IssuerPrivateKey(ed25519KeyPair.privateKey)
didDocResult <- didResolver.resolve(jwtPresentation.iss) map {
case failed: DIDResolutionFailed => CredentialServiceError.UnexpectedError(failed.error.toString)
case succeeded: DIDResolutionSucceeded => succeeded.didDocument.authentication.map(x => x)
didDocResult <- didResolver.resolve(jwtPresentation.iss) flatMap {
case failed: DIDResolutionFailed =>
ZIO.fail(CredentialServiceError.UnexpectedError(failed.error.toString))
case succeeded: DIDResolutionSucceeded => ZIO.succeed(succeeded.didDocument.authentication)
}
now = Instant.now.getEpochSecond
in30Days = Instant.now.plus(30, ChronoUnit.DAYS).getEpochSecond // FIXME hardcode 30days
exp = claims("exp").flatMap(_.asNumber).flatMap(_.toLong)
expInSeconds <- ZIO.fromEither(exp match {
case Some(e) if e > now => Right(e)
case Some(e) =>
Left(CredentialServiceError.UnsupportedVCClaimsValue(s"Error: Expiration Time Not valid or expired :$e"))
case _ => Right(Instant.now.plus(expirationTime).getEpochSecond)
})
claimsUpdated = claims
.add("iss", issuingDID.did.toString.asJson)
.add("iss", issuingDID.did.toString.asJson) // This is issuer did
.add("sub", jwtPresentation.iss.asJson) // This is subject did
.add("iat", now.asJson)
.add("exp", in30Days.asJson)
.add("exp", expInSeconds.asJson)
credential = SDJWT.issueCredential(
sdJwtPrivateKey,
claimsUpdated.asJson.noSpaces,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import org.hyperledger.identus.mercury.protocol.issuecredential.{IssueCredential
import org.hyperledger.identus.pollux.core.model.{DidCommID, IssueCredentialRecord}
import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{Duration, IO, URLayer, ZIO, ZLayer}
import zio.{IO, URLayer, ZIO, ZLayer}

import java.util.UUID
Expand Down Expand Up @@ -151,9 +152,10 @@ class CredentialServiceNotifier(
notifyOnSuccess(svc.generateJWTCredential(recordId, statusListRegistryUrl))

override def generateSDJWTCredential(
recordId: DidCommID
recordId: DidCommID,
expirationTime: Duration,
): ZIO[WalletAccessContext, CredentialServiceError, IssueCredentialRecord] =
notifyOnSuccess(svc.generateSDJWTCredential(recordId))
notifyOnSuccess(svc.generateSDJWTCredential(recordId, expirationTime))

override def generateAnonCredsCredential(
recordId: DidCommID
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import org.hyperledger.identus.mercury.protocol.issuecredential.{IssueCredential
import org.hyperledger.identus.pollux.core.model.{DidCommID, IssueCredentialRecord}
import org.hyperledger.identus.pollux.core.model.error.CredentialServiceError
import org.hyperledger.identus.shared.models.WalletAccessContext
import zio.{mock, Duration, IO, URLayer, ZIO, ZLayer}
import zio.{mock, IO, URLayer, ZIO, ZLayer}
import zio.mock.{Mock, Proxy}

Expand Down Expand Up @@ -70,7 +71,7 @@ object MockCredentialService extends Mock[CredentialService] {
object ReceiveCredentialRequest extends Effect[RequestCredential, CredentialServiceError, IssueCredentialRecord]
object AcceptCredentialRequest extends Effect[DidCommID, CredentialServiceError, IssueCredentialRecord]
object GenerateJWTCredential extends Effect[(DidCommID, String), CredentialServiceError, IssueCredentialRecord]
object GenerateSDJWTCredential extends Effect[DidCommID, CredentialServiceError, IssueCredentialRecord]
object GenerateSDJWTCredential extends Effect[(DidCommID, Duration), CredentialServiceError, IssueCredentialRecord]
object GenerateAnonCredsCredential extends Effect[DidCommID, CredentialServiceError, IssueCredentialRecord]
object ReceiveCredentialIssue extends Effect[IssueCredential, CredentialServiceError, IssueCredentialRecord]
object MarkOfferSent extends Effect[DidCommID, CredentialServiceError, IssueCredentialRecord]
Expand Down Expand Up @@ -191,9 +192,10 @@ object MockCredentialService extends Mock[CredentialService] {
proxy(GenerateJWTCredential, recordId, statusListRegistryUrl)

override def generateSDJWTCredential(
recordId: DidCommID
recordId: DidCommID,
expirationTime: Duration,
): ZIO[WalletAccessContext, CredentialServiceError, IssueCredentialRecord] =
proxy(GenerateSDJWTCredential, recordId)
proxy(GenerateSDJWTCredential, recordId, expirationTime)

override def generateAnonCredsCredential(
recordId: DidCommID
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -56,11 +56,7 @@ class ES256KSigner(privateKey: PrivateKey) extends Signer {

class EdSigner(ed25519KeyPair: Ed25519KeyPair) extends Signer {
lazy val signer: Ed25519Signer = {
val d = java.util.Base64.getUrlEncoder.withoutPadding().encodeToString(ed25519KeyPair.privateKey.getEncoded)
val x = java.util.Base64.getUrlEncoder.withoutPadding().encodeToString(ed25519KeyPair.publicKey.getEncoded)
val okpJson = s"""{"kty":"OKP","crv":"Ed25519","d":"$d","x":"$x"}"""
val octetKeyPair = OctetKeyPair.parse(okpJson)
val ed25519Signer = Ed25519Signer(octetKeyPair)
val ed25519Signer = Ed25519Signer(ed25519KeyPair.toOctetKeyPair)
ed25519Signer
}

Expand Down

0 comments on commit f719120

Please sign in to comment.