|
2 | 2 |
|
3 | 3 | import com.danubetech.verifiablecredentials.CredentialSubject; |
4 | 4 | import com.danubetech.verifiablecredentials.VerifiableCredential; |
| 5 | +import com.danubetech.verifiablecredentials.VerifiableCredentialV2; |
5 | 6 | import com.danubetech.verifiablecredentials.VerifiablePresentation; |
6 | 7 | import com.danubetech.verifiablecredentials.jsonld.VerifiableCredentialKeywords; |
7 | 8 | import com.nimbusds.jwt.JWTClaimsSet; |
@@ -147,4 +148,93 @@ public static JwtVerifiablePresentation toJwtVerifiablePresentation(VerifiablePr |
147 | 148 |
|
148 | 149 | return toJwtVerifiablePresentation(verifiablePresentation, null); |
149 | 150 | } |
| 151 | + |
| 152 | + |
| 153 | + /* |
| 154 | + * from JSON-LD to JWT VCDM V2 |
| 155 | + */ |
| 156 | + |
| 157 | + public static JwtVerifiableCredentialV2 toJwtVerifiableCredentialV2(VerifiableCredentialV2 verifiableCredential, String aud, boolean preserveVerifiableCredentialProperties, boolean includeIat) { |
| 158 | + |
| 159 | + JWTClaimsSet.Builder jwtPayloadBuilder = new JWTClaimsSet.Builder(); |
| 160 | + |
| 161 | + VerifiableCredentialV2 payloadVerifiableCredential = VerifiableCredentialV2.builder() |
| 162 | + .defaultContexts(false) |
| 163 | + .defaultTypes(false) |
| 164 | + .build(); |
| 165 | + |
| 166 | + JsonLDUtils.jsonLdAddAll(payloadVerifiableCredential, verifiableCredential.getJsonObject()); |
| 167 | + |
| 168 | + URI id = verifiableCredential.getId(); |
| 169 | + if (id != null) { |
| 170 | + jwtPayloadBuilder.jwtID(id.toString()); |
| 171 | + if (!preserveVerifiableCredentialProperties) { |
| 172 | + JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, JsonLDKeywords.JSONLD_TERM_ID); |
| 173 | + } |
| 174 | + } |
| 175 | + |
| 176 | + CredentialSubject credentialSubject = verifiableCredential.getCredentialSubject(); |
| 177 | + if (credentialSubject != null && credentialSubject.getId() != null) { |
| 178 | + jwtPayloadBuilder.subject(credentialSubject.getId().toString()); |
| 179 | + if (!preserveVerifiableCredentialProperties) { |
| 180 | + CredentialSubject payloadCredentialSubject = CredentialSubject.builder() |
| 181 | + .base(credentialSubject) |
| 182 | + .build(); |
| 183 | + JsonLDUtils.jsonLdRemove(payloadCredentialSubject, JsonLDKeywords.JSONLD_TERM_ID); |
| 184 | + CredentialSubject.removeFromJsonLdObject(payloadVerifiableCredential); |
| 185 | + payloadCredentialSubject.addToJsonLDObject(payloadVerifiableCredential); |
| 186 | + } |
| 187 | + } |
| 188 | + |
| 189 | + URI issuer = verifiableCredential.getIssuerUri(); |
| 190 | + if (issuer != null) { |
| 191 | + jwtPayloadBuilder.issuer(issuer.toString()); |
| 192 | + if (!preserveVerifiableCredentialProperties) { |
| 193 | + JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, VerifiableCredentialKeywords.JSONLD_TERM_ISSUER); |
| 194 | + } |
| 195 | + } |
| 196 | + |
| 197 | + Date issuanceDate = verifiableCredential.getValidFrom(); |
| 198 | + if (issuanceDate != null) { |
| 199 | + jwtPayloadBuilder.notBeforeTime(issuanceDate); |
| 200 | + if (includeIat) jwtPayloadBuilder.issueTime(issuanceDate); |
| 201 | + if (!preserveVerifiableCredentialProperties) { |
| 202 | + JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, VerifiableCredentialKeywords.JSONLD_TERM_ISSUANCEDATE); |
| 203 | + } |
| 204 | + } |
| 205 | + |
| 206 | + Date expirationDate = verifiableCredential.getValidUntil(); |
| 207 | + if (expirationDate != null) { |
| 208 | + jwtPayloadBuilder.expirationTime(expirationDate); |
| 209 | + if (!preserveVerifiableCredentialProperties) { |
| 210 | + JsonLDUtils.jsonLdRemove(payloadVerifiableCredential, VerifiableCredentialKeywords.JSONLD_TERM_EXPIRATIONDATE); |
| 211 | + } |
| 212 | + } |
| 213 | + |
| 214 | + if (aud != null) { |
| 215 | + jwtPayloadBuilder.audience(aud); |
| 216 | + } |
| 217 | + |
| 218 | + Map<String, Object> vcContent = new LinkedHashMap<>(payloadVerifiableCredential.getJsonObject()); |
| 219 | + jwtPayloadBuilder.claim(JwtKeywords.JWT_CLAIM_VC, vcContent); |
| 220 | + |
| 221 | + JWTClaimsSet jwtPayload = jwtPayloadBuilder.build(); |
| 222 | + |
| 223 | + return new JwtVerifiableCredentialV2(jwtPayload, payloadVerifiableCredential, null, null); |
| 224 | + } |
| 225 | + |
| 226 | + public static JwtVerifiableCredentialV2 toJwtVerifiableCredentialV2(VerifiableCredentialV2 verifiableCredential, String aud) { |
| 227 | + |
| 228 | + return toJwtVerifiableCredentialV2(verifiableCredential, null, false, false); |
| 229 | + } |
| 230 | + |
| 231 | + public static JwtVerifiableCredentialV2 toJwtVerifiableCredentialV2(VerifiableCredentialV2 verifiableCredential, boolean preserveVerifiableCredentialProperties, boolean includeIat) { |
| 232 | + |
| 233 | + return toJwtVerifiableCredentialV2(verifiableCredential, null, preserveVerifiableCredentialProperties, includeIat); |
| 234 | + } |
| 235 | + |
| 236 | + public static JwtVerifiableCredentialV2 toJwtVerifiableCredentialV2(VerifiableCredentialV2 verifiableCredential) { |
| 237 | + |
| 238 | + return toJwtVerifiableCredentialV2(verifiableCredential, null, false, false); |
| 239 | + } |
150 | 240 | } |
0 commit comments