From c62319d0f60f03ae1e14fa9f1e0fed57268d39af Mon Sep 17 00:00:00 2001 From: Markus Sabadello Date: Fri, 24 May 2024 07:10:06 -0400 Subject: [PATCH] feat: Ability to preserve VCDM fields in VC-JWT --- .../jwt/ToJwtConverter.java | 47 ++++++++++++------- 1 file changed, 31 insertions(+), 16 deletions(-) diff --git a/src/main/java/com/danubetech/verifiablecredentials/jwt/ToJwtConverter.java b/src/main/java/com/danubetech/verifiablecredentials/jwt/ToJwtConverter.java index 8da8001..ece7556 100644 --- a/src/main/java/com/danubetech/verifiablecredentials/jwt/ToJwtConverter.java +++ b/src/main/java/com/danubetech/verifiablecredentials/jwt/ToJwtConverter.java @@ -19,7 +19,7 @@ public class ToJwtConverter { * from JSON-LD to JWT VC */ - public static JwtVerifiableCredential toJwtVerifiableCredential(VerifiableCredential verifiableCredential, String aud) { + public static JwtVerifiableCredential toJwtVerifiableCredential(VerifiableCredential verifiableCredential, String aud, boolean preserveVerifiableCredentialProperties) { JWTClaimsSet.Builder jwtPayloadBuilder = new JWTClaimsSet.Builder(); @@ -33,27 +33,28 @@ public static JwtVerifiableCredential toJwtVerifiableCredential(VerifiableCreden URI id = verifiableCredential.getId(); if (id != null) { jwtPayloadBuilder.jwtID(id.toString()); - JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, JsonLDKeywords.JSONLD_TERM_ID); + if (!preserveVerifiableCredentialProperties) { + JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, JsonLDKeywords.JSONLD_TERM_ID); + } } CredentialSubject credentialSubject = verifiableCredential.getCredentialSubject(); - if (credentialSubject != null) { - if (credentialSubject.getId() != null) { - jwtPayloadBuilder.subject(credentialSubject.getId().toString()); + if (credentialSubject != null && credentialSubject.getId() != null) { + jwtPayloadBuilder.subject(credentialSubject.getId().toString()); + if (!preserveVerifiableCredentialProperties) { + CredentialSubject payloadCredentialSubject = CredentialSubject.builder() + .base(credentialSubject) + .build(); + JsonLDUtils.jsonLdRemove(payloadCredentialSubject, JsonLDKeywords.JSONLD_TERM_ID); + CredentialSubject.removeFromJsonLdObject(payloadVerifiableCredential); + payloadCredentialSubject.addToJsonLDObject(payloadVerifiableCredential); } - CredentialSubject payloadCredentialSubject = CredentialSubject.builder() - .base(credentialSubject) - .build(); - JsonLDUtils.jsonLdRemove(payloadCredentialSubject, JsonLDKeywords.JSONLD_TERM_ID); - CredentialSubject.removeFromJsonLdObject(payloadVerifiableCredential); - payloadCredentialSubject.addToJsonLDObject(payloadVerifiableCredential); } URI issuer = verifiableCredential.getIssuer(); if (issuer != null) { jwtPayloadBuilder.issuer(issuer.toString()); - if ( verifiableCredential.getJsonObject().containsKey(VerifiableCredentialKeywords.JSONLD_TERM_ISSUER) - && !( verifiableCredential.getJsonObject().get(VerifiableCredentialKeywords.JSONLD_TERM_ISSUER) instanceof Map)) { + if (!preserveVerifiableCredentialProperties) { JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, VerifiableCredentialKeywords.JSONLD_TERM_ISSUER); } } @@ -61,13 +62,17 @@ public static JwtVerifiableCredential toJwtVerifiableCredential(VerifiableCreden Date issuanceDate = verifiableCredential.getIssuanceDate(); if (issuanceDate != null) { jwtPayloadBuilder.notBeforeTime(issuanceDate); - JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, VerifiableCredentialKeywords.JSONLD_TERM_ISSUANCEDATE); + if (!preserveVerifiableCredentialProperties) { + JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, VerifiableCredentialKeywords.JSONLD_TERM_ISSUANCEDATE); + } } Date expirationDate = verifiableCredential.getExpirationDate(); if (expirationDate != null) { jwtPayloadBuilder.expirationTime(expirationDate); - JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, VerifiableCredentialKeywords.JSONLD_TERM_EXPIRATIONDATE); + if (!preserveVerifiableCredentialProperties) { + JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, VerifiableCredentialKeywords.JSONLD_TERM_EXPIRATIONDATE); + } } if (aud != null) { @@ -82,9 +87,19 @@ public static JwtVerifiableCredential toJwtVerifiableCredential(VerifiableCreden return new JwtVerifiableCredential(jwtPayload, payloadVerifiableCredential, null, null); } + public static JwtVerifiableCredential toJwtVerifiableCredential(VerifiableCredential verifiableCredential, String aud) { + + return toJwtVerifiableCredential(verifiableCredential, null, false); + } + + public static JwtVerifiableCredential toJwtVerifiableCredential(VerifiableCredential verifiableCredential, boolean preserveVerifiableCredentialProperties) { + + return toJwtVerifiableCredential(verifiableCredential, null, preserveVerifiableCredentialProperties); + } + public static JwtVerifiableCredential toJwtVerifiableCredential(VerifiableCredential verifiableCredential) { - return toJwtVerifiableCredential(verifiableCredential, null); + return toJwtVerifiableCredential(verifiableCredential, null, false); } /*