From 07dd0ea8b64ddfee6cb01c012dd7628764247fdd Mon Sep 17 00:00:00 2001 From: Koptan Date: Tue, 7 Nov 2023 12:11:01 +0100 Subject: [PATCH 01/12] feat: new Exception system BREAKING CHANGE: a lot of Exception has been added and removed --- ...BuildDIDDocEd25519VerificationKey2020.java | 2 +- .../tractusx/ssi/examples/ResolveDIDDoc.java | 22 ++--- .../org/eclipse/tractusx/ssi/examples/VC.java | 20 ++-- .../tractusx/ssi/examples/Validation.java | 9 +- .../tractusx/ssi/examples/Verification.java | 63 +++++++----- .../eclipse/tractusx/ssi/lib/crypt/IKey.java | 6 +- .../tractusx/ssi/lib/crypt/IKeyGenerator.java | 2 +- .../ssi/lib/crypt/x21559/x21559Generator.java | 10 +- .../lib/crypt/x21559/x21559PrivateKey.java | 36 ++++--- .../ssi/lib/crypt/x21559/x21559PublicKey.java | 31 +++--- .../resolver/DidDocumentResolverRegistry.java | 56 ----------- .../DidDocumentResolverRegistryImpl.java | 69 -------------- .../ssi/lib/did/resolver/DidResolver.java | 4 +- .../did/resolver/DidResolverException.java | 9 +- .../lib/did/web/DidWebDocumentResolver.java | 95 ------------------- .../ssi/lib/did/web/DidWebResolver.java | 3 +- .../ssi/lib/did/web/util/DidWebParser.java | 14 +-- .../did/web/util/Ed25519PublicKeyParser.java | 21 ++-- .../exception/InvalidePrivateKeyFormat.java | 45 --------- .../exception/InvalidePublicKeyFormat.java | 46 --------- .../JwtSignatureCheckFailedException.java | 53 ----------- ...atureVerificationKeyNotFoundException.java | 25 ----- .../lib/exception/KeyGenerationException.java | 33 ------- .../NoVerificationKeyFoundExcpetion.java | 35 ------- .../{SsiException.java => SSIException.java} | 23 ++--- .../UnsupportedDidMethodException.java | 40 -------- .../{ => did}/DidParseException.java | 32 +++---- .../{ => json}/InvalidJsonLdException.java | 19 +++- .../json/TransformJsonLdException.java | 69 ++++++++++++++ .../key/InvalidPrivateKeyFormatException.java | 81 ++++++++++++++++ .../key/InvalidPublicKeyFormatException.java | 81 ++++++++++++++++ .../exception/key/KeyGenerationException.java | 69 ++++++++++++++ .../key/KeyTransformationException.java | 68 +++++++++++++ .../JwtAudienceCheckFailedException.java | 23 ++++- .../{ => proof}/JwtExpiredException.java | 46 ++++++++- .../NoVerificationKeyFoundException.java} | 35 +++---- .../SignatureGenerateFailedException.java | 69 ++++++++++++++ .../proof/SignatureParseException.java | 69 ++++++++++++++ .../SignatureVerificationFailedException.java | 69 ++++++++++++++ .../UnsupportedSignatureTypeException.java | 41 +++++++- ...nsupportedVerificationMethodException.java | 11 ++- ...entResolverAlreadyRegisteredException.java | 79 +++++++++++++++ ...ocumentResolverNotRegisteredException.java | 19 +++- .../{ => resolver}/DidWebException.java | 9 +- .../ssi/lib/jwt/SignedJwtValidator.java | 39 ++++---- .../ssi/lib/jwt/SignedJwtVerifier.java | 39 +++++--- .../ssi/lib/model/RemoteDocumentLoader.java | 3 +- .../tractusx/ssi/lib/model/did/DidParser.java | 13 ++- .../tractusx/ssi/lib/proof/ISigner.java | 6 +- .../tractusx/ssi/lib/proof/IVerifier.java | 34 ++++--- .../lib/proof/LinkedDataProofGenerator.java | 10 +- .../lib/proof/LinkedDataProofValidation.java | 39 +++++--- .../transform/LinkedDataTransformer.java | 15 ++- .../types/ed25519/Ed25519ProofSigner.java | 4 +- .../types/ed25519/Ed25519ProofVerifier.java | 21 ++-- .../lib/proof/types/jws/JWSProofSigner.java | 12 +-- .../lib/proof/types/jws/JWSProofVerifier.java | 60 ++++++++---- .../jsonLd/JsonLdSerializer.java | 2 +- .../jsonLd/JsonLdSerializerImpl.java | 2 +- .../ssi/lib/validation/JsonLdValidator.java | 2 +- .../lib/validation/JsonLdValidatorImpl.java | 2 +- .../ssi/lib/cypto/ed21995/ed21559KeyTest.java | 13 ++- .../resolver/CompositeDidResolverTest.java | 19 ++-- .../ssi/lib/did/web/DidWebResolverIT.java | 8 +- .../ssi/lib/did/web/DidWebResolverTest.java | 10 +- .../lib/did/web/util/DidWebParserTest.java | 2 + ...inkedDataProofValidationComponentTest.java | 83 ++++------------ .../ssi/lib/proof/SignAndVerifyTest.java | 17 +--- .../proof/LinkedDataTransformerTest.java | 2 + .../lib/serialization/SerializeUtilTest.java | 7 +- .../jsonld/DanubeTechMapperTest.java | 55 ----------- .../identity/TestDidDocumentResolver.java | 82 ---------------- .../util/identity/TestIdentityFactory.java | 9 +- .../verifiable/VerifiableCredentialTest.java | 4 +- 74 files changed, 1237 insertions(+), 1038 deletions(-) delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidDocumentResolverRegistry.java delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidDocumentResolverRegistryImpl.java delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebDocumentResolver.java delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidePrivateKeyFormat.java delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidePublicKeyFormat.java delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtSignatureCheckFailedException.java delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtSignatureVerificationKeyNotFoundException.java delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/KeyGenerationException.java delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/NoVerificationKeyFoundExcpetion.java rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{SsiException.java => SSIException.java} (76%) delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedDidMethodException.java rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{ => did}/DidParseException.java (64%) rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{ => json}/InvalidJsonLdException.java (71%) create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyTransformationException.java rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{ => proof}/JwtAudienceCheckFailedException.java (68%) rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{ => proof}/JwtExpiredException.java (50%) rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{JwtException.java => proof/NoVerificationKeyFoundException.java} (61%) create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{ => proof}/UnsupportedSignatureTypeException.java (50%) rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{ => proof}/UnsupportedVerificationMethodException.java (89%) create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{ => resolver}/DidDocumentResolverNotRegisteredException.java (70%) rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{ => resolver}/DidWebException.java (91%) delete mode 100644 src/test/java/org/eclipse/tractusx/ssi/lib/serialization/jsonld/DanubeTechMapperTest.java delete mode 100644 src/test/java/org/eclipse/tractusx/ssi/lib/util/identity/TestDidDocumentResolver.java diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/BuildDIDDocEd25519VerificationKey2020.java b/src/main/java/org/eclipse/tractusx/ssi/examples/BuildDIDDocEd25519VerificationKey2020.java index 922c3b02..e6ff4865 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/BuildDIDDocEd25519VerificationKey2020.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/BuildDIDDocEd25519VerificationKey2020.java @@ -29,7 +29,7 @@ import org.eclipse.tractusx.ssi.lib.crypt.KeyPair; import org.eclipse.tractusx.ssi.lib.crypt.x21559.x21559Generator; import org.eclipse.tractusx.ssi.lib.did.web.DidWebFactory; -import org.eclipse.tractusx.ssi.lib.exception.KeyGenerationException; +import org.eclipse.tractusx.ssi.lib.exception.key.KeyGenerationException; import org.eclipse.tractusx.ssi.lib.model.MultibaseString; import org.eclipse.tractusx.ssi.lib.model.base.MultibaseFactory; import org.eclipse.tractusx.ssi.lib.model.did.Did; diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java b/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java index f3c180e7..00cfa3cb 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java @@ -22,14 +22,15 @@ package org.eclipse.tractusx.ssi.examples; import java.net.http.HttpClient; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidDocumentResolverRegistryImpl; -import org.eclipse.tractusx.ssi.lib.did.web.DidWebDocumentResolver; +import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.did.web.DidWebFactory; +import org.eclipse.tractusx.ssi.lib.did.web.DidWebResolver; import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; -import org.eclipse.tractusx.ssi.lib.exception.DidDocumentResolverNotRegisteredException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverAlreadyRegisteredException; +import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; -import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; /** This is an example class to demonstrate did document resolve from given did web url */ public class ResolveDIDDoc { @@ -42,22 +43,19 @@ public class ResolveDIDDoc { * exception */ public static DidDocument ResovleDocument(String didUrl) - throws DidDocumentResolverNotRegisteredException { + throws DidDocumentResolverNotRegisteredException, + DidDocumentResolverAlreadyRegisteredException, DidParseException, DidResolverException { // DID Resolver Constracture params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); var enforceHttps = false; - // DID Method - DidMethod didWeb = new DidMethod("web"); - // DID Did did = DidWebFactory.fromHostname(didUrl); - var didDocumentResolverRegistry = new DidDocumentResolverRegistryImpl(); - didDocumentResolverRegistry.register( - new DidWebDocumentResolver(httpClient, didParser, enforceHttps)); - return didDocumentResolverRegistry.get(didWeb).resolve(did); + var didResolver = new DidWebResolver(httpClient, didParser, enforceHttps); + + return didResolver.resolve(did); } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/VC.java b/src/main/java/org/eclipse/tractusx/ssi/examples/VC.java index 061f26bd..7be6a8f3 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/VC.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/VC.java @@ -26,9 +26,10 @@ import java.util.List; import java.util.Map; import org.eclipse.tractusx.ssi.lib.crypt.IPrivateKey; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePrivateKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.SsiException; -import org.eclipse.tractusx.ssi.lib.exception.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.json.TransformJsonLdException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPrivateKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureGenerateFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.proof.ed21559.Ed25519Signature2020; import org.eclipse.tractusx.ssi.lib.model.proof.jws.JWSSignature2020; @@ -83,7 +84,8 @@ public static VerifiableCredential createVCWithoutProof() { */ public static VerifiableCredential createVCWithED21559Proof( VerifiableCredential credential, IPrivateKey privateKey, Did issuer) - throws UnsupportedSignatureTypeException, SsiException, InvalidePrivateKeyFormat { + throws UnsupportedSignatureTypeException, InvalidPrivateKeyFormatException, + SignatureGenerateFailedException, TransformJsonLdException { // VC Builder final VerifiableCredentialBuilder builder = @@ -122,7 +124,8 @@ public static VerifiableCredential createVCWithED21559Proof( */ public static VerifiableCredential createVCWithJWSProof( VerifiableCredential credential, IPrivateKey privateKey, Did issuer) - throws UnsupportedSignatureTypeException, SsiException, InvalidePrivateKeyFormat { + throws UnsupportedSignatureTypeException, InvalidPrivateKeyFormatException, + SignatureGenerateFailedException, TransformJsonLdException { // VC Builder final VerifiableCredentialBuilder builder = @@ -136,9 +139,10 @@ public static VerifiableCredential createVCWithJWSProof( .type(credential.getTypes()); // JWS Proof Builder - final LinkedDataProofGenerator generator = - LinkedDataProofGenerator.newInstance(SignatureType.JWS); - final JWSSignature2020 proof = + LinkedDataProofGenerator generator = LinkedDataProofGenerator.newInstance(SignatureType.JWS); + + JWSSignature2020 proof = null; + proof = (JWSSignature2020) generator.createProof(builder.build(), URI.create(issuer + "#key-1"), privateKey); diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/Validation.java b/src/main/java/org/eclipse/tractusx/ssi/examples/Validation.java index 43bf4b79..0ba2b497 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/Validation.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/Validation.java @@ -22,8 +22,9 @@ package org.eclipse.tractusx.ssi.examples; import com.nimbusds.jwt.SignedJWT; -import org.eclipse.tractusx.ssi.lib.exception.JwtAudienceCheckFailedException; -import org.eclipse.tractusx.ssi.lib.exception.JwtExpiredException; +import org.eclipse.tractusx.ssi.lib.exception.proof.JwtAudienceCheckFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.JwtExpiredException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; import org.eclipse.tractusx.ssi.lib.jwt.SignedJwtValidator; /** This is example class to demonstrate how to validate JWT expiry date and audience */ @@ -37,7 +38,7 @@ public class Validation { * @throws JwtExpiredException the jwt expired exception */ public static void validateJWTDate(SignedJWT signedJWT, String audience) - throws JwtAudienceCheckFailedException, JwtExpiredException { + throws JwtAudienceCheckFailedException, JwtExpiredException, SignatureParseException { SignedJwtValidator jwtValidator = new SignedJwtValidator(); jwtValidator.validateDate(signedJWT); } @@ -51,7 +52,7 @@ public static void validateJWTDate(SignedJWT signedJWT, String audience) * @throws JwtExpiredException the jwt expired exception */ public static void validateJWTAudiences(SignedJWT signedJWT, String audience) - throws JwtAudienceCheckFailedException, JwtExpiredException { + throws JwtAudienceCheckFailedException, JwtExpiredException, SignatureParseException { SignedJwtValidator jwtValidator = new SignedJwtValidator(); jwtValidator.validateAudiences(signedJWT, audience); } diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java b/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java index 59497719..846b0015 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java @@ -23,10 +23,19 @@ import com.nimbusds.jwt.SignedJWT; import java.net.http.HttpClient; +import java.security.SignatureException; +import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.did.web.DidWebResolver; import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; -import org.eclipse.tractusx.ssi.lib.exception.DidDocumentResolverNotRegisteredException; -import org.eclipse.tractusx.ssi.lib.exception.JwtException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.json.TransformJsonLdException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedVerificationMethodException; +import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; import org.eclipse.tractusx.ssi.lib.jwt.SignedJwtVerifier; import org.eclipse.tractusx.ssi.lib.model.verifiable.credential.VerifiableCredential; import org.eclipse.tractusx.ssi.lib.proof.LinkedDataProofValidation; @@ -34,15 +43,18 @@ /** * This is example class to demonstrate how to verify @{@link SignedJWT} and {@link * VerifiableCredential} + * + * @throws DidParseException + * @throws SignatureException + * @throws DidResolverException + * @throws SignatureVerificationFailedException + * @throws UnsupportedVerificationMethodException */ public class Verification { - /** - * Verify jwt. - * - * @param jwt the jwt - */ - public static void verifyJWT(SignedJWT jwt) { + public static void verifyJWT(SignedJWT jwt) + throws DidParseException, SignatureException, DidResolverException, + SignatureVerificationFailedException, UnsupportedVerificationMethodException { // DID Resolver constructor params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); @@ -50,13 +62,8 @@ public static void verifyJWT(SignedJWT jwt) { var didResolver = new DidWebResolver(httpClient, didParser, enforceHttps); SignedJwtVerifier jwtVerifier = new SignedJwtVerifier(didResolver); - try { - jwtVerifier.verify(jwt); - } catch (JwtException | DidDocumentResolverNotRegisteredException e) { - // An exception will be thrown here in case JWT verification failed or DID - // Document Resolver not able to resolve. - e.printStackTrace(); - } + + jwtVerifier.verify(jwt); } /** @@ -64,8 +71,20 @@ public static void verifyJWT(SignedJWT jwt) { * * @param verifiableCredential the verifiable credential * @return the boolean + * @throws DidDocumentResolverNotRegisteredException + * @throws TransformJsonLdException + * @throws NoVerificationKeyFoundException + * @throws SignatureVerificationFailedException + * @throws InvalidPublicKeyFormatException + * @throws DidParseException + * @throws SignatureParseException + * @throws UnsupportedSignatureTypeException */ - public static boolean verifyED21559LD(VerifiableCredential verifiableCredential) { + public static boolean verifyED21559LD(VerifiableCredential verifiableCredential) + throws UnsupportedSignatureTypeException, SignatureParseException, DidParseException, + InvalidPublicKeyFormatException, SignatureVerificationFailedException, + NoVerificationKeyFoundException, TransformJsonLdException, + DidDocumentResolverNotRegisteredException { // DID Resolver constructor params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); @@ -76,13 +95,11 @@ public static boolean verifyED21559LD(VerifiableCredential verifiableCredential) return proofValidation.verify(verifiableCredential); } - /** - * Verify jws signed ld. - * - * @param verifiableCredential the verifiable credential - * @return the boolean - */ - public static boolean verifyJWSLD(VerifiableCredential verifiableCredential) { + public static boolean verifyJWSLD(VerifiableCredential verifiableCredential) + throws UnsupportedSignatureTypeException, SignatureParseException, DidParseException, + InvalidPublicKeyFormatException, SignatureVerificationFailedException, + NoVerificationKeyFoundException, DidDocumentResolverNotRegisteredException, + TransformJsonLdException { // DID Resolver constructor params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/IKey.java b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/IKey.java index 6fa68596..36d5fbf1 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/IKey.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/IKey.java @@ -21,7 +21,7 @@ package org.eclipse.tractusx.ssi.lib.crypt; -import java.io.IOException; +import org.eclipse.tractusx.ssi.lib.exception.key.KeyTransformationException; import org.eclipse.tractusx.ssi.lib.model.base.EncodeType; /** The interface Key. */ @@ -39,7 +39,7 @@ public interface IKey { * @return the string * @throws IOException the io exception */ - String asStringForStoring() throws IOException; + String asStringForStoring() throws KeyTransformationException; /** * Convert the key to a string for exchange. @@ -48,7 +48,7 @@ public interface IKey { * @return the string * @throws IOException the io exception */ - String asStringForExchange(EncodeType encodeType) throws IOException; + String asStringForExchange(EncodeType encodeType) throws KeyTransformationException; /** * Convert the key to a byte array. diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/IKeyGenerator.java b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/IKeyGenerator.java index 70a380a1..d292e921 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/IKeyGenerator.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/IKeyGenerator.java @@ -21,7 +21,7 @@ package org.eclipse.tractusx.ssi.lib.crypt; -import org.eclipse.tractusx.ssi.lib.exception.KeyGenerationException; +import org.eclipse.tractusx.ssi.lib.exception.key.KeyGenerationException; /** The interface KeyGenerator. */ public interface IKeyGenerator { diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java index 50b14a09..d0416108 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java @@ -29,9 +29,9 @@ import org.bouncycastle.crypto.params.Ed25519PublicKeyParameters; import org.eclipse.tractusx.ssi.lib.crypt.IKeyGenerator; import org.eclipse.tractusx.ssi.lib.crypt.KeyPair; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePrivateKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePublicKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.KeyGenerationException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPrivateKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.key.KeyGenerationException; /** X21559 key generator. */ public class x21559Generator implements IKeyGenerator { @@ -51,13 +51,13 @@ public KeyPair generateKey() throws KeyGenerationException { x21559PrivateKey x21559PrivateKey; try { x21559PrivateKey = new x21559PrivateKey(privateKey.getEncoded()); - } catch (InvalidePrivateKeyFormat e) { + } catch (InvalidPrivateKeyFormatException e) { throw new KeyGenerationException(e.getCause()); } x21559PublicKey x21559PublicKey; try { x21559PublicKey = new x21559PublicKey(publicKey.getEncoded()); - } catch (InvalidePublicKeyFormat e) { + } catch (InvalidPublicKeyFormatException e) { throw new KeyGenerationException(e.getCause()); } return new KeyPair(x21559PublicKey, x21559PrivateKey); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559PrivateKey.java b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559PrivateKey.java index 49f31f1e..e50fa9ce 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559PrivateKey.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559PrivateKey.java @@ -31,13 +31,15 @@ import org.bouncycastle.util.io.pem.PemReader; import org.bouncycastle.util.io.pem.PemWriter; import org.eclipse.tractusx.ssi.lib.crypt.IPrivateKey; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePrivateKeyFormat; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPrivateKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.key.KeyTransformationException; import org.eclipse.tractusx.ssi.lib.model.base.EncodeType; import org.eclipse.tractusx.ssi.lib.model.base.MultibaseFactory; /** The type X21559 private key. */ public class x21559PrivateKey implements IPrivateKey { + private final int KEY_LENGTH = 32; private final @NonNull byte[] key; /** @@ -46,9 +48,9 @@ public class x21559PrivateKey implements IPrivateKey { * @param privateKey the private key * @throws InvalidePrivateKeyFormat the invalide private key format */ - public x21559PrivateKey(byte[] privateKey) throws InvalidePrivateKeyFormat { + public x21559PrivateKey(byte[] privateKey) throws InvalidPrivateKeyFormatException { if (this.getKeyLength() != privateKey.length) { - throw new InvalidePrivateKeyFormat(getKeyLength(), privateKey.length); + throw new InvalidPrivateKeyFormatException(getKeyLength(), privateKey.length); } this.key = privateKey; } @@ -61,12 +63,17 @@ public x21559PrivateKey(byte[] privateKey) throws InvalidePrivateKeyFormat { * @throws InvalidePrivateKeyFormat the invalide private key format * @throws IOException the io exception */ - public x21559PrivateKey(String privateKey, boolean pemFormat) - throws InvalidePrivateKeyFormat, IOException { - if (pemFormat) { + public x21559PrivateKey(String privateKey, boolean PEMFormat) + throws InvalidPrivateKeyFormatException { + if (PEMFormat) { StringReader sr = new StringReader(privateKey); PemReader reader = new PemReader(sr); - PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(reader.readPemObject().getContent()); + PKCS8EncodedKeySpec keySpec; + try { + keySpec = new PKCS8EncodedKeySpec(reader.readPemObject().getContent()); + } catch (IOException e) { + throw new InvalidPrivateKeyFormatException(e.getMessage()); + } Ed25519PrivateKeyParameters ed25519PrivateKeyParameters = new Ed25519PrivateKeyParameters(keySpec.getEncoded()); this.key = ed25519PrivateKeyParameters.getEncoded(); @@ -76,18 +83,23 @@ public x21559PrivateKey(String privateKey, boolean pemFormat) } if (this.getKeyLength() != key.length) { - throw new InvalidePrivateKeyFormat(getKeyLength(), privateKey.length()); + throw new InvalidPrivateKeyFormatException(getKeyLength(), privateKey.length()); } } @Override - public String asStringForStoring() throws IOException { + public String asStringForStoring() throws KeyTransformationException { PemObject pemObject = new PemObject("ED21559 Private Key", this.key); StringWriter sw = new StringWriter(); PemWriter writer = new PemWriter(sw); - writer.writeObject(pemObject); - writer.close(); + try { + writer.writeObject(pemObject); + writer.close(); + } catch (IOException e) { + throw new KeyTransformationException(e.getMessage()); + } + return sw.toString(); } @@ -104,6 +116,6 @@ public byte[] asByte() { @Override public int getKeyLength() { - return 32; + return KEY_LENGTH; } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559PublicKey.java b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559PublicKey.java index 1be1e7d3..669a7386 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559PublicKey.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559PublicKey.java @@ -31,13 +31,15 @@ import org.bouncycastle.util.io.pem.PemReader; import org.bouncycastle.util.io.pem.PemWriter; import org.eclipse.tractusx.ssi.lib.crypt.IPublicKey; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePublicKeyFormat; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.key.KeyTransformationException; import org.eclipse.tractusx.ssi.lib.model.base.EncodeType; import org.eclipse.tractusx.ssi.lib.model.base.MultibaseFactory; /** The type X 21559 public key. */ public class x21559PublicKey implements IPublicKey { + private final int KEY_LENGTH = 32; private final @NonNull byte[] originalKey; /** @@ -46,9 +48,9 @@ public class x21559PublicKey implements IPublicKey { * @param publicKey the public key * @throws InvalidePublicKeyFormat the invalide public key format */ - public x21559PublicKey(byte[] publicKey) throws InvalidePublicKeyFormat { + public x21559PublicKey(byte[] publicKey) throws InvalidPublicKeyFormatException { if (this.getKeyLength() != publicKey.length) { - throw new InvalidePublicKeyFormat(getKeyLength(), publicKey.length); + throw new InvalidPublicKeyFormatException(getKeyLength(), publicKey.length); } this.originalKey = publicKey; } @@ -61,10 +63,10 @@ public x21559PublicKey(byte[] publicKey) throws InvalidePublicKeyFormat { * @throws InvalidePublicKeyFormat the invalide public key format * @throws IOException the io exception */ - public x21559PublicKey(String publicKey, boolean pemFormat) - throws InvalidePublicKeyFormat, IOException { + public x21559PublicKey(String publicKey, boolean PEMformat) + throws InvalidPublicKeyFormatException, IOException { - if (pemFormat) { + if (PEMformat) { StringReader sr = new StringReader(publicKey); PemReader reader = new PemReader(sr); PemObject pemObject = reader.readPemObject(); @@ -77,22 +79,27 @@ public x21559PublicKey(String publicKey, boolean pemFormat) } if (this.getKeyLength() != originalKey.length) { - throw new InvalidePublicKeyFormat(getKeyLength(), originalKey.length); + throw new InvalidPublicKeyFormatException(getKeyLength(), originalKey.length); } } @Override - public String asStringForStoring() throws IOException { + public String asStringForStoring() throws KeyTransformationException { PemObject pemObject = new PemObject("ED21559 Public Key", this.originalKey); StringWriter sw = new StringWriter(); PemWriter writer = new PemWriter(sw); - writer.writeObject(pemObject); - writer.close(); + try { + writer.writeObject(pemObject); + writer.close(); + } catch (IOException e) { + throw new KeyTransformationException(e.getMessage()); + } + return sw.toString(); } @Override - public String asStringForExchange(EncodeType encodeType) throws IOException { + public String asStringForExchange(EncodeType encodeType) { return MultibaseFactory.create(encodeType, originalKey).getEncoded(); } @@ -103,6 +110,6 @@ public byte[] asByte() { @Override public int getKeyLength() { - return 32; + return KEY_LENGTH; } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidDocumentResolverRegistry.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidDocumentResolverRegistry.java deleted file mode 100644 index 07ac4d55..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidDocumentResolverRegistry.java +++ /dev/null @@ -1,56 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.did.resolver; - -import org.eclipse.tractusx.ssi.lib.exception.DidDocumentResolverNotRegisteredException; -import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; - -/** - * The interface Did document resolver registry. - * - * @deprecated replaced by {@link DidResolver} - */ -public interface DidDocumentResolverRegistry { - /** - * Get did document resolver. - * - * @param did the did - * @return the did document resolver - * @throws DidDocumentResolverNotRegisteredException the did document resolver not registered - * exception - */ - DidDocumentResolver get(DidMethod did) throws DidDocumentResolverNotRegisteredException; - - /** - * Register a new did document resolver - * - * @param resolver the resolver - */ - void register(DidDocumentResolver resolver); - - /** - * Unregister a did document resolver - * - * @param resolver the resolver - */ - void unregister(DidDocumentResolver resolver); -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidDocumentResolverRegistryImpl.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidDocumentResolverRegistryImpl.java deleted file mode 100644 index a9f8f553..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidDocumentResolverRegistryImpl.java +++ /dev/null @@ -1,69 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.did.resolver; - -import java.util.HashMap; -import java.util.Map; -import org.eclipse.tractusx.ssi.lib.exception.DidDocumentResolverNotRegisteredException; -import org.eclipse.tractusx.ssi.lib.exception.SsiException; -import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; - -/** - * The type Did document resolver registry. - * - * @deprecated replaced by {@link DidResolver} - */ -public class DidDocumentResolverRegistryImpl implements DidDocumentResolverRegistry { - - /** The Resolvers. */ - public final Map resolvers = new HashMap<>(); - - @Override - public DidDocumentResolver get(DidMethod didMethod) - throws DidDocumentResolverNotRegisteredException { - - if (!resolvers.containsKey(didMethod)) { - throw new DidDocumentResolverNotRegisteredException(didMethod); - } - - return resolvers.get(didMethod); - } - - @Override - public void register(DidDocumentResolver resolver) { - if (resolvers.containsKey(resolver.getSupportedMethod())) { - throw new SsiException( - String.format( - "Resolver for method '%s' is already registered", resolver.getSupportedMethod())); - } - resolvers.put(resolver.getSupportedMethod(), resolver); - } - - @Override - public void unregister(DidDocumentResolver resolver) { - if (!resolvers.containsKey(resolver.getSupportedMethod())) { - throw new SsiException( - String.format("Resolver for method '%s' not registered", resolver.getSupportedMethod())); - } - resolvers.remove(resolver.getSupportedMethod()); - } -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolver.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolver.java index fc0ed659..68048e35 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolver.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolver.java @@ -21,6 +21,7 @@ package org.eclipse.tractusx.ssi.lib.did.resolver; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; @@ -34,8 +35,9 @@ public interface DidResolver { * @return the resolved DID document or null if the provided {@code did} could not be * resolved * @throws DidResolverException if the DID is invalid or cannot be resolved to a DID document + * @throws DidParseException */ - DidDocument resolve(Did did) throws DidResolverException; + DidDocument resolve(Did did) throws DidResolverException, DidParseException; /** * Indicates whether the resolver is capable of resolving the provided {@code did} to a DID diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolverException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolverException.java index 9be80912..f8812602 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolverException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolverException.java @@ -21,13 +21,10 @@ package org.eclipse.tractusx.ssi.lib.did.resolver; -/** The type Did resolver exception. */ -public class DidResolverException extends Exception { - - private static final long serialVersionUID = 1L; +import org.eclipse.tractusx.ssi.lib.exception.SSIException; - /** Instantiates a new Did resolver exception. */ - public DidResolverException() {} +/** The type Did resolver exception. */ +public class DidResolverException extends SSIException { /** * Instantiates a new Did resolver exception. diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebDocumentResolver.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebDocumentResolver.java deleted file mode 100644 index 55e85ed6..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebDocumentResolver.java +++ /dev/null @@ -1,95 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.did.web; - -import com.fasterxml.jackson.databind.ObjectMapper; -import java.io.IOException; -import java.net.URI; -import java.net.http.HttpClient; -import java.net.http.HttpRequest; -import java.net.http.HttpResponse; -import java.nio.charset.StandardCharsets; -import java.util.Map; -import lombok.RequiredArgsConstructor; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidDocumentResolver; -import org.eclipse.tractusx.ssi.lib.did.web.util.Constants; -import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; -import org.eclipse.tractusx.ssi.lib.exception.DidWebException; -import org.eclipse.tractusx.ssi.lib.exception.SsiException; -import org.eclipse.tractusx.ssi.lib.model.did.Did; -import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; -import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; - -/** The type Did web document resolver. */ -@RequiredArgsConstructor -@Deprecated -/** - * @deprecated replaced by {@link DidWebResolver} - */ -public class DidWebDocumentResolver implements DidDocumentResolver { - - private final HttpClient client; - private final DidWebParser parser; - private final boolean enforceHttps; - - @Override - public DidMethod getSupportedMethod() { - return Constants.DID_WEB_METHOD; - } - - @Override - public DidDocument resolve(Did did) { - if (!did.getMethod().equals(Constants.DID_WEB_METHOD)) { - throw new SsiException( - "Handler can only handle the following methods:" + Constants.DID_WEB_METHOD); - } - - final URI uri = parser.parse(did, enforceHttps); - - final HttpRequest request = HttpRequest.newBuilder().uri(uri).GET().build(); - - try { - final HttpResponse response = - client.send(request, HttpResponse.BodyHandlers.ofString()); - - if (response.statusCode() < 200 || response.statusCode() > 299) { - throw new DidWebException( - String.format( - "Unexpected response when resolving did document [Code=%s, Payload=%s]", - response.statusCode(), response.body())); - } - if (response.body() == null) { - throw new DidWebException("Empty response body"); - } - - final byte[] body = response.body().getBytes(StandardCharsets.UTF_8); - - // TODO Fix this - final ObjectMapper mapper = new ObjectMapper(); - final Map json = mapper.readValue(body, Map.class); - - return new DidDocument(json); - } catch (IOException | InterruptedException e) { - throw new RuntimeException(e); - } - } -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolver.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolver.java index 403c4724..998f0111 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolver.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolver.java @@ -33,6 +33,7 @@ import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.did.web.util.Constants; import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; @@ -51,7 +52,7 @@ public boolean isResolvable(Did did) { @SuppressWarnings("unchecked") @Override - public DidDocument resolve(Did did) throws DidResolverException { + public DidDocument resolve(Did did) throws DidResolverException, DidParseException { if (!did.getMethod().equals(Constants.DID_WEB_METHOD)) { throw new DidResolverException( String.format( diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/util/DidWebParser.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/util/DidWebParser.java index f15c9adf..833257ae 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/util/DidWebParser.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/util/DidWebParser.java @@ -24,8 +24,7 @@ import java.net.URI; import java.net.URISyntaxException; import lombok.RequiredArgsConstructor; -import lombok.SneakyThrows; -import org.eclipse.tractusx.ssi.lib.exception.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; import org.eclipse.tractusx.ssi.lib.model.did.Did; /** The type Did web parser. */ @@ -41,7 +40,7 @@ public class DidWebParser { * @param did the did * @return the uri */ - public URI parse(Did did) { + public URI parse(Did did) throws DidParseException { return parse(did, true); } @@ -52,8 +51,7 @@ public URI parse(Did did) { * @param enforceHttps the enforce https * @return the uri */ - @SneakyThrows({URISyntaxException.class}) - public URI parse(Did did, boolean enforceHttps) { + public URI parse(Did did, boolean enforceHttps) throws DidParseException { if (!did.getMethod().equals(Constants.DID_WEB_METHOD)) { throw new DidParseException( "Did Method not allowed: " + did.getMethod() + ". Expected did:web"); @@ -75,6 +73,10 @@ public URI parse(Did did, boolean enforceHttps) { didUrl = didUrl + WELL_KNOWN_DID_JSON; } - return new URI(didUrl); + try { + return new URI(didUrl); + } catch (URISyntaxException e) { + throw new DidParseException(e.getMessage()); + } } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/util/Ed25519PublicKeyParser.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/util/Ed25519PublicKeyParser.java index 845916ad..bc0066c4 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/util/Ed25519PublicKeyParser.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/util/Ed25519PublicKeyParser.java @@ -21,9 +21,10 @@ package org.eclipse.tractusx.ssi.lib.did.web.util; +import java.io.IOException; import java.io.StringReader; -import lombok.SneakyThrows; import org.bouncycastle.util.io.pem.PemReader; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; import org.eclipse.tractusx.ssi.lib.model.MultibaseString; import org.eclipse.tractusx.ssi.lib.model.base.MultibaseFactory; @@ -36,16 +37,24 @@ public class Ed25519PublicKeyParser { * * @param publicKey the public key * @return public key as multibase string + * @throws InvalidPublicKeyFormatException */ - public static MultibaseString parsePublicKey(String publicKey) { - final byte[] publicKey64 = readPublicKey(publicKey); + public static MultibaseString parsePublicKey(String publicKey) + throws InvalidPublicKeyFormatException { + byte[] publicKey64 = null; + + publicKey64 = readPublicKey(publicKey); + return MultibaseFactory.create(publicKey64); } - @SneakyThrows - private static byte[] readPublicKey(String publicKey) { + private static byte[] readPublicKey(String publicKey) throws InvalidPublicKeyFormatException { PemReader pemReader = new PemReader(new StringReader(publicKey)); - return pemReader.readPemObject().getContent(); + try { + return pemReader.readPemObject().getContent(); + } catch (IOException e) { + throw new InvalidPublicKeyFormatException(e.getMessage()); + } } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidePrivateKeyFormat.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidePrivateKeyFormat.java deleted file mode 100644 index 16a4f9c6..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidePrivateKeyFormat.java +++ /dev/null @@ -1,45 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.exception; - -/** The type Invalide private key format. */ -public class InvalidePrivateKeyFormat extends Exception { - /** - * Instantiates a new Invalide private key format. - * - * @param correctLength the correct length - * @param providedLength the provided length - */ - public InvalidePrivateKeyFormat(int correctLength, int providedLength) { - super( - String.format( - "Invalide Private Key Format, this key should have '%s' as lenght but we got %s", - correctLength, providedLength)); - } - - /** - * Instantiates a new Invalide private key format. - * - * @param cause the cause - */ - public InvalidePrivateKeyFormat(Throwable cause) {} -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidePublicKeyFormat.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidePublicKeyFormat.java deleted file mode 100644 index 7be04f24..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidePublicKeyFormat.java +++ /dev/null @@ -1,46 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.exception; - -/** The type Invalide public key format. */ -public class InvalidePublicKeyFormat extends Exception { - - /** - * Instantiates a new Invalide public key format. - * - * @param correctLength the correct length - * @param providedLength the provided length - */ - public InvalidePublicKeyFormat(int correctLength, int providedLength) { - super( - String.format( - "Invalide Publice Key Format, this key should have '%s' as lenght but we got %s", - correctLength, providedLength)); - } - - /** - * Instantiates a new Invalide public key format. - * - * @param cause the cause - */ - public InvalidePublicKeyFormat(Throwable cause) {} -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtSignatureCheckFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtSignatureCheckFailedException.java deleted file mode 100644 index e698e664..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtSignatureCheckFailedException.java +++ /dev/null @@ -1,53 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.exception; - -import java.net.URI; -import lombok.Getter; -import org.eclipse.tractusx.ssi.lib.model.did.Did; - -/** The type Jwt signature check failed exception. */ -@Getter -public class JwtSignatureCheckFailedException extends JwtException { - - /** Issuer did */ - private final Did issuerDid; - - /** Verification key */ - private final URI verificationKey; - - /** - * Instantiates a new Jwt signature check failed exception. - * - * @param issuerDid the issuer did - * @param verificationKey the verification key - */ - public JwtSignatureCheckFailedException(Did issuerDid, URI verificationKey) { - super( - "JWT signature check failed for issuer " - + issuerDid - + " and verification key " - + verificationKey); - this.issuerDid = issuerDid; - this.verificationKey = verificationKey; - } -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtSignatureVerificationKeyNotFoundException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtSignatureVerificationKeyNotFoundException.java deleted file mode 100644 index b3d2dcae..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtSignatureVerificationKeyNotFoundException.java +++ /dev/null @@ -1,25 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.exception; - -/** The type Jwt signature verification key not found exception. */ -public class JwtSignatureVerificationKeyNotFoundException {} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/KeyGenerationException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/KeyGenerationException.java deleted file mode 100644 index e87cb316..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/KeyGenerationException.java +++ /dev/null @@ -1,33 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.exception; - -/** The type Key generation exception. */ -public class KeyGenerationException extends Exception { - - /** - * Instantiates a new Key generation exception. - * - * @param cause the cause - */ - public KeyGenerationException(Throwable cause) {} -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/NoVerificationKeyFoundExcpetion.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/NoVerificationKeyFoundExcpetion.java deleted file mode 100644 index 1f18380d..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/NoVerificationKeyFoundExcpetion.java +++ /dev/null @@ -1,35 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.exception; - -/** NoVerificationKeyFoundExcpetion */ -public class NoVerificationKeyFoundExcpetion extends Exception { - - /** - * Instantiates a new No verification key found excpetion. - * - * @param message the message - */ - public NoVerificationKeyFoundExcpetion(String message) { - super(message); - } -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SsiException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.java similarity index 76% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/SsiException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.java index 8a55cf30..e99554e3 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SsiException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.java @@ -21,49 +21,46 @@ package org.eclipse.tractusx.ssi.lib.exception; -/** The type Ssi exception. */ -public class SsiException extends RuntimeException { - - /** Instantiates a new Ssi exception. */ - public SsiException() {} +/** The type SSI exception. */ +public class SSIException extends Exception { /** - * Instantiates a new Ssi exception. + * Instantiates a new SSI exception. * * @param message the message */ - public SsiException(String message) { + protected SSIException(String message) { super(message); } /** - * Instantiates a new Ssi exception. + * Instantiates a new SSI exception. * * @param message the message * @param cause the cause */ - public SsiException(String message, Throwable cause) { + protected SSIException(String message, Throwable cause) { super(message, cause); } /** - * Instantiates a new Ssi exception. + * Instantiates a new SSI exception. * * @param cause the cause */ - public SsiException(Throwable cause) { + protected SSIException(Throwable cause) { super(cause); } /** - * Instantiates a new Ssi exception. + * Instantiates a new SSI exception. * * @param message the message * @param cause the cause * @param enableSuppression the enable suppression * @param writableStackTrace the writable stack trace */ - public SsiException( + protected SSIException( String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { super(message, cause, enableSuppression, writableStackTrace); } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedDidMethodException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedDidMethodException.java deleted file mode 100644 index 75a6853b..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedDidMethodException.java +++ /dev/null @@ -1,40 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.exception; - -import org.eclipse.tractusx.ssi.lib.model.did.Did; - -/** The type Unsupported did method exception. */ -public class UnsupportedDidMethodException extends Exception { - /** - * Instantiates a new Unsupported did method exception. - * - * @param did the did - * @param contextMessage the context message - */ - public UnsupportedDidMethodException(Did did, String contextMessage) { - super( - String.format( - "No DID document resolver registered for DID method '%s'. %s", - did.getMethod(), contextMessage)); - } -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/DidParseException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java similarity index 64% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/DidParseException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java index 8f34dc98..7213ea9e 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/DidParseException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java @@ -19,26 +19,26 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception; +package org.eclipse.tractusx.ssi.lib.exception.did; -/** The type Did parse exception. */ -public class DidParseException extends SsiException { - /** - * Instantiates a new Did parse exception. - * - * @param message the message - */ - public DidParseException(String message) { - super(message); +import org.eclipse.tractusx.ssi.lib.exception.SSIException; + +public class DidParseException extends SSIException { + + public DidParseException(String did) { + super(String.format("Invalid DID URL: %s, not able to parse it", did)); } - /** - * Instantiates a new Did parse exception. - * - * @param message the message - * @param cause the cause - */ public DidParseException(String message, Throwable cause) { super(message, cause); } + + public DidParseException(Throwable cause) { + super(cause); + } + + public DidParseException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidJsonLdException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/InvalidJsonLdException.java similarity index 71% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidJsonLdException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/InvalidJsonLdException.java index 093a21da..ac3468e0 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/InvalidJsonLdException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/InvalidJsonLdException.java @@ -19,10 +19,12 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception; +package org.eclipse.tractusx.ssi.lib.exception.json; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; /** The type Invalid json ld exception. */ -public class InvalidJsonLdException extends Exception { +public class InvalidJsonLdException extends SSIException { /** * Instantiates a new Invalid json ld exception. * @@ -50,4 +52,17 @@ public InvalidJsonLdException(String message, Throwable cause) { public InvalidJsonLdException(Throwable cause) { super(cause); } + + /** + * Instantiates a new Invalid json ld exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public InvalidJsonLdException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java new file mode 100644 index 00000000..5d40b968 --- /dev/null +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java @@ -0,0 +1,69 @@ +/* + * ****************************************************************************** + * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Apache License, Version 2.0 which is available at + * https://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * SPDX-License-Identifier: Apache-2.0 + * ******************************************************************************* + */ + +package org.eclipse.tractusx.ssi.lib.exception.json; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; + +/** The type tranform json LD exception. */ +public class TransformJsonLdException extends SSIException { + + /** + * Instantiates a new tranform json LD exception. + * + * @param message the message + */ + public TransformJsonLdException(String message) { + super(message); + } + + /** + * Instantiates a new tranform json LD exception. + * + * @param message the message + * @param cause the cause + */ + public TransformJsonLdException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new tranform json LD exception. + * + * @param cause the cause + */ + public TransformJsonLdException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a new tranform json LD exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public TransformJsonLdException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } +} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java new file mode 100644 index 00000000..03312c71 --- /dev/null +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java @@ -0,0 +1,81 @@ +/* + * ****************************************************************************** + * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Apache License, Version 2.0 which is available at + * https://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * SPDX-License-Identifier: Apache-2.0 + * ******************************************************************************* + */ + +package org.eclipse.tractusx.ssi.lib.exception.key; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; + +/** The type Invalide private key format. */ +public class InvalidPrivateKeyFormatException extends SSIException { + /** + * Instantiates a new Invalid private key format. + * + * @param correctLength the correct length + * @param providedLength the provided length + */ + public InvalidPrivateKeyFormatException(int correctLength, int providedLength) { + super( + String.format( + "Invalide Private Key Format, this key should have '%s' as lenght but we got %s", + correctLength, providedLength)); + } + + /** + * Instantiates a new Invalid private key format. + * + * @param message message + */ + public InvalidPrivateKeyFormatException(String message) { + super(message); + } + + /** + * Instantiates a new Invalid private key format. + * + * @param message message + * @param cuase the cause + */ + public InvalidPrivateKeyFormatException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new Invalid private key format. + * + * @param cuase the cause + */ + public InvalidPrivateKeyFormatException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a new Invalid private key format. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public InvalidPrivateKeyFormatException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } +} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java new file mode 100644 index 00000000..17e25507 --- /dev/null +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java @@ -0,0 +1,81 @@ +/* + * ****************************************************************************** + * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Apache License, Version 2.0 which is available at + * https://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * SPDX-License-Identifier: Apache-2.0 + * ******************************************************************************* + */ + +package org.eclipse.tractusx.ssi.lib.exception.key; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; + +/** The type Invalid public key format. */ +public class InvalidPublicKeyFormatException extends SSIException { + /** + * Instantiates a new Invalide public key format. + * + * @param correctLength the correct length + * @param providedLength the provided length + */ + public InvalidPublicKeyFormatException(int correctLength, int providedLength) { + super( + String.format( + "Invalide Publice Key Format, this key should have '%s' as lenght but we got %s", + correctLength, providedLength)); + } + + /** + * Instantiates a new invalide public key format exception. + * + * @param message the message + */ + public InvalidPublicKeyFormatException(String message) { + super(message); + } + + /** + * Instantiates a new invalide public key format exception. + * + * @param message the message + * @param cause the cause + */ + public InvalidPublicKeyFormatException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new invalide public key format exception. + * + * @param cause the cause + */ + public InvalidPublicKeyFormatException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a new invalide public key format exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public InvalidPublicKeyFormatException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } +} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java new file mode 100644 index 00000000..aa570bde --- /dev/null +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java @@ -0,0 +1,69 @@ +/* + * ****************************************************************************** + * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Apache License, Version 2.0 which is available at + * https://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * SPDX-License-Identifier: Apache-2.0 + * ******************************************************************************* + */ + +package org.eclipse.tractusx.ssi.lib.exception.key; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; + +/** The type Key Generation Exception */ +public class KeyGenerationException extends SSIException { + + /** + * Instantiates a new key generation exception. + * + * @param message the message + */ + public KeyGenerationException(String message) { + super(message); + } + + /** + * Instantiates a new key generation exception. + * + * @param message the message + * @param cause the cause + */ + public KeyGenerationException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new key generation exception. + * + * @param cause the cause + */ + public KeyGenerationException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a key generation exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public KeyGenerationException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } +} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyTransformationException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyTransformationException.java new file mode 100644 index 00000000..7b7e14d4 --- /dev/null +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyTransformationException.java @@ -0,0 +1,68 @@ +/* + * ****************************************************************************** + * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Apache License, Version 2.0 which is available at + * https://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * SPDX-License-Identifier: Apache-2.0 + * ******************************************************************************* + */ + +package org.eclipse.tractusx.ssi.lib.exception.key; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; + +public class KeyTransformationException extends SSIException { + + /** + * Instantiates a new key trnasformation exception. + * + * @param message the message + */ + public KeyTransformationException(String message) { + super(message); + } + + /** + * Instantiates a new key trnasformation exception. + * + * @param message the message + * @param cause the cause + */ + public KeyTransformationException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new key trnasformation exception. + * + * @param cause the cause + */ + public KeyTransformationException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a new key trnasformation exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public KeyTransformationException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } +} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtAudienceCheckFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java similarity index 68% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtAudienceCheckFailedException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java index aace1b2e..12d0156f 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtAudienceCheckFailedException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java @@ -19,12 +19,14 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception; +package org.eclipse.tractusx.ssi.lib.exception.proof; import java.util.List; +import org.eclipse.tractusx.ssi.lib.exception.SSIException; /** The type Jwt audience check failed exception. */ -public class JwtAudienceCheckFailedException extends JwtException { +public class JwtAudienceCheckFailedException extends SSIException { + /** * Instantiates a new Jwt audience check failed exception. * @@ -38,4 +40,21 @@ public JwtAudienceCheckFailedException(String expectedAudience, List act + ", actual audience: " + String.join(", ", actualAudience)); } + + public JwtAudienceCheckFailedException(String message) { + super(message); + } + + public JwtAudienceCheckFailedException(String message, Throwable cause) { + super(message, cause); + } + + public JwtAudienceCheckFailedException(Throwable cause) { + super(cause); + } + + public JwtAudienceCheckFailedException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtExpiredException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java similarity index 50% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtExpiredException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java index aea6b0c8..c6fcd278 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtExpiredException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java @@ -19,12 +19,13 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception; +package org.eclipse.tractusx.ssi.lib.exception.proof; import java.util.Date; +import org.eclipse.tractusx.ssi.lib.exception.SSIException; /** The type Jwt expired exception. */ -public class JwtExpiredException extends JwtException { +public class JwtExpiredException extends SSIException { /** * Instantiates a new Jwt expired exception. @@ -34,4 +35,45 @@ public class JwtExpiredException extends JwtException { public JwtExpiredException(Date expiryDate) { super("JWT expired at " + expiryDate); } + + /** + * Instantiates a new jwt expired exception. + * + * @param message the message + */ + public JwtExpiredException(String message) { + super(message); + } + + /** + * Instantiates a new jwt expired exception. + * + * @param message the message + * @param cause the cause + */ + public JwtExpiredException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new jwt expired exception. + * + * @param cause the cause + */ + public JwtExpiredException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a new jwt expired exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public JwtExpiredException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java similarity index 61% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java index 90eab35a..02c97c26 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/JwtException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java @@ -19,36 +19,27 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception; +package org.eclipse.tractusx.ssi.lib.exception.proof; -/** The type Jwt exception. */ -public class JwtException extends Exception { +import org.eclipse.tractusx.ssi.lib.exception.SSIException; - /** - * Instantiates a new Jwt exception. - * - * @param message the message - */ - public JwtException(String message) { +/** NoVerificationKeyFoundExcpetion */ +public class NoVerificationKeyFoundException extends SSIException { + + public NoVerificationKeyFoundException(String message) { super(message); } - /** - * Instantiates a new Jwt exception. - * - * @param message the message - * @param cause the cause - */ - public JwtException(String message, Throwable cause) { + public NoVerificationKeyFoundException(String message, Throwable cause) { super(message, cause); } - /** - * Instantiates a new Jwt exception. - * - * @param cause the cause - */ - public JwtException(Throwable cause) { + public NoVerificationKeyFoundException(Throwable cause) { super(cause); } + + public NoVerificationKeyFoundException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java new file mode 100644 index 00000000..3c88dbe1 --- /dev/null +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java @@ -0,0 +1,69 @@ +/* + * ****************************************************************************** + * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Apache License, Version 2.0 which is available at + * https://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * SPDX-License-Identifier: Apache-2.0 + * ******************************************************************************* + */ + +package org.eclipse.tractusx.ssi.lib.exception.proof; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; + +/** The type signature check failed exception. */ +public class SignatureGenerateFailedException extends SSIException { + + /** + * Instantiates a new signature generate failed exception. + * + * @param message the message + */ + public SignatureGenerateFailedException(String message) { + super(message); + } + + /** + * Instantiates a new signature generate failed exception. + * + * @param message the message + * @param cause the cause + */ + public SignatureGenerateFailedException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new signature generate failed exception. + * + * @param cause the cause + */ + public SignatureGenerateFailedException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a new signature generate failed exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public SignatureGenerateFailedException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } +} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java new file mode 100644 index 00000000..6bca1ed6 --- /dev/null +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java @@ -0,0 +1,69 @@ +/* + * ****************************************************************************** + * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Apache License, Version 2.0 which is available at + * https://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * SPDX-License-Identifier: Apache-2.0 + * ******************************************************************************* + */ + +package org.eclipse.tractusx.ssi.lib.exception.proof; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; + +/** The type signature parse exception. */ +public class SignatureParseException extends SSIException { + + /** + * Instantiates a new signature parse exception. + * + * @param message the message + */ + public SignatureParseException(String message) { + super(message); + } + + /** + * Instantiatesa a new signature parse exception. + * + * @param message the message + * @param cause the cause + */ + public SignatureParseException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new signature parse exception. + * + * @param cause the cause + */ + public SignatureParseException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a new signature parse exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public SignatureParseException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } +} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java new file mode 100644 index 00000000..9bee64c7 --- /dev/null +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java @@ -0,0 +1,69 @@ +/* + * ****************************************************************************** + * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Apache License, Version 2.0 which is available at + * https://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * SPDX-License-Identifier: Apache-2.0 + * ******************************************************************************* + */ + +package org.eclipse.tractusx.ssi.lib.exception.proof; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; + +/** The type Signature Verification Failed exception. */ +public class SignatureVerificationFailedException extends SSIException { + + /** + * Instantiates a new signature verification failed exception. + * + * @param message the message + */ + public SignatureVerificationFailedException(String message) { + super(message); + } + + /** + * Instantiates a new signature verification failed exception. + * + * @param message the message + * @param cause the cause + */ + protected SignatureVerificationFailedException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new signature verification failed exception. + * + * @param cause the cause + */ + protected SignatureVerificationFailedException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a new signature verification failed exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + protected SignatureVerificationFailedException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } +} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedSignatureTypeException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java similarity index 50% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedSignatureTypeException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java index 64f11b23..4bc944ba 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedSignatureTypeException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java @@ -19,16 +19,51 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception; +package org.eclipse.tractusx.ssi.lib.exception.proof; + +import org.eclipse.tractusx.ssi.lib.exception.SSIException; /** The type Unsupported signature type exception. */ -public class UnsupportedSignatureTypeException extends Exception { +public class UnsupportedSignatureTypeException extends SSIException { + /** - * Instantiates a new Unsupported signature type exception. + * Instantiates a new unsupported signature type exception. * * @param signatureType the signature type */ public UnsupportedSignatureTypeException(String signatureType) { super("Unsupported signature type: " + signatureType); } + + /** + * Instantiates a unsupported signature type exception. + * + * @param message the message + * @param cause the cause + */ + public UnsupportedSignatureTypeException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a unsupported signature type exception. + * + * @param cause the cause + */ + public UnsupportedSignatureTypeException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a unsupported signature type exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public UnsupportedSignatureTypeException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedVerificationMethodException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java similarity index 89% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedVerificationMethodException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java index 229dbcb2..9781cac9 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/UnsupportedVerificationMethodException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java @@ -19,13 +19,17 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception; +package org.eclipse.tractusx.ssi.lib.exception.proof; import lombok.Getter; +import org.eclipse.tractusx.ssi.lib.exception.SSIException; import org.eclipse.tractusx.ssi.lib.model.did.VerificationMethod; /** The type Unsupported verification method exception. */ -public class UnsupportedVerificationMethodException extends RuntimeException { +public class UnsupportedVerificationMethodException extends SSIException { + + /** The verification method */ + @Getter private final VerificationMethod method; /** * Instantiates a new Unsupported verification method exception. @@ -39,7 +43,4 @@ public UnsupportedVerificationMethodException(VerificationMethod method, String "Unsupported verification method: %s. %s", method.getClass().getName(), message)); this.method = method; } - - /** The verification method */ - @Getter private final VerificationMethod method; } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java new file mode 100644 index 00000000..4e796701 --- /dev/null +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java @@ -0,0 +1,79 @@ +/* + * ****************************************************************************** + * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation + * + * See the NOTICE file(s) distributed with this work for additional + * information regarding copyright ownership. + * + * This program and the accompanying materials are made available under the + * terms of the Apache License, Version 2.0 which is available at + * https://www.apache.org/licenses/LICENSE-2.0. + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations + * under the License. + * + * SPDX-License-Identifier: Apache-2.0 + * ******************************************************************************* + */ + +package org.eclipse.tractusx.ssi.lib.exception.resolver; + +import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; + +/** The type SSI did document resolver already registered exception. */ +public class DidDocumentResolverAlreadyRegisteredException extends Exception { + + /** + * Instantiates a new did document resolver already registered exception. + * + * @param message the message + */ + public DidDocumentResolverAlreadyRegisteredException(DidMethod didMethod) { + super(String.format("No DID document resolver registered for DID method '%s'", didMethod)); + } + + /** + * Instantiates a new did document resolver already registered exception. + * + * @param message the message + * @param cause the cause + */ + public DidDocumentResolverAlreadyRegisteredException(String message) { + super(message); + } + + /** + * Instantiates a new did document resolver already registered exception. + * + * @param cause the cause + */ + public DidDocumentResolverAlreadyRegisteredException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Instantiates a new did document resolver already registered exception. + * + * @param message the message + * @param cause the cause + */ + public DidDocumentResolverAlreadyRegisteredException(Throwable cause) { + super(cause); + } + + /** + * Instantiates a new did document resolver already registered exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ + public DidDocumentResolverAlreadyRegisteredException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } +} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/DidDocumentResolverNotRegisteredException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java similarity index 70% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/DidDocumentResolverNotRegisteredException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java index 906df501..70139c41 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/DidDocumentResolverNotRegisteredException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java @@ -19,7 +19,7 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception; +package org.eclipse.tractusx.ssi.lib.exception.resolver; import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; @@ -34,4 +34,21 @@ public class DidDocumentResolverNotRegisteredException extends Exception { public DidDocumentResolverNotRegisteredException(DidMethod didMethod) { super(String.format("No DID document resolver registered for DID method '%s'", didMethod)); } + + public DidDocumentResolverNotRegisteredException(String message) { + super(message); + } + + public DidDocumentResolverNotRegisteredException(String message, Throwable cause) { + super(message, cause); + } + + public DidDocumentResolverNotRegisteredException(Throwable cause) { + super(cause); + } + + public DidDocumentResolverNotRegisteredException( + String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { + super(message, cause, enableSuppression, writableStackTrace); + } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/DidWebException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java similarity index 91% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/DidWebException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java index 3284555c..127f0787 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/DidWebException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java @@ -19,13 +19,12 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception; +package org.eclipse.tractusx.ssi.lib.exception.resolver; -/** The type Did web exception. */ -public class DidWebException extends RuntimeException { +import org.eclipse.tractusx.ssi.lib.exception.SSIException; - /** Instantiates a new Did web exception. */ - public DidWebException() {} +/** The type Did web exception. */ +public class DidWebException extends SSIException { /** * Instantiates a new Did web exception. diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java index 83820a08..d6f73973 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java @@ -22,38 +22,37 @@ package org.eclipse.tractusx.ssi.lib.jwt; import com.nimbusds.jwt.SignedJWT; +import java.text.ParseException; import java.util.Date; import java.util.List; -import lombok.SneakyThrows; -import org.eclipse.tractusx.ssi.lib.exception.JwtAudienceCheckFailedException; -import org.eclipse.tractusx.ssi.lib.exception.JwtExpiredException; +import org.eclipse.tractusx.ssi.lib.exception.proof.JwtAudienceCheckFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.JwtExpiredException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; /** The type Signed jwt validator. */ public class SignedJwtValidator { - /** - * Validate date. - * - * @param jwt the jwt - */ - @SneakyThrows - public void validateDate(SignedJWT jwt) { - Date expiryDate = jwt.getJWTClaimsSet().getExpirationTime(); + public void validateDate(SignedJWT jwt) throws JwtExpiredException, SignatureParseException { + Date expiryDate; + try { + expiryDate = jwt.getJWTClaimsSet().getExpirationTime(); + } catch (ParseException e) { + throw new SignatureParseException(e.getMessage()); + } boolean isExpired = expiryDate.before(new Date()); // Todo add Timezone if (isExpired) { throw new JwtExpiredException(expiryDate); } } - /** - * Validate audiences. - * - * @param jwt the jwt - * @param expectedAudience the expected audience - */ - @SneakyThrows - public void validateAudiences(SignedJWT jwt, String expectedAudience) { - List audiences = jwt.getJWTClaimsSet().getAudience(); + public void validateAudiences(SignedJWT jwt, String expectedAudience) + throws JwtAudienceCheckFailedException, SignatureParseException { + List audiences; + try { + audiences = jwt.getJWTClaimsSet().getAudience(); + } catch (ParseException e) { + throw new SignatureParseException(e.getMessage()); + } boolean isValidAudience = audiences.stream().anyMatch(x -> x.equals(expectedAudience)); if (!isValidAudience) { throw new JwtAudienceCheckFailedException(expectedAudience, audiences); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java index e083525b..4bb33776 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java @@ -28,16 +28,16 @@ import com.nimbusds.jose.util.Base64URL; import com.nimbusds.jwt.JWTClaimsSet; import com.nimbusds.jwt.SignedJWT; +import java.security.SignatureException; import java.text.ParseException; import java.util.List; import lombok.RequiredArgsConstructor; -import lombok.SneakyThrows; import org.bouncycastle.crypto.params.Ed25519PublicKeyParameters; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolver; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; -import org.eclipse.tractusx.ssi.lib.exception.DidDocumentResolverNotRegisteredException; -import org.eclipse.tractusx.ssi.lib.exception.JwtException; -import org.eclipse.tractusx.ssi.lib.exception.UnsupportedVerificationMethodException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedVerificationMethodException; import org.eclipse.tractusx.ssi.lib.model.MultibaseString; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; @@ -60,19 +60,21 @@ public class SignedJwtVerifier { * * @param jwt a {@link SignedJWT} that was sent by the claiming party. * @return true if verified, false otherwise - * @throws JwtException the jwt exception - * @throws DidDocumentResolverNotRegisteredException the did document resolver not registered - * exception + * @throws DidParseException + * @throws SignatureException + * @throws DidResolverException + * @throws SignatureVerificationFailedException + * @throws UnsupportedVerificationMethodException */ - @SneakyThrows({JOSEException.class, DidResolverException.class}) public boolean verify(SignedJWT jwt) - throws JwtException, DidDocumentResolverNotRegisteredException { + throws DidParseException, SignatureException, DidResolverException, + SignatureVerificationFailedException, UnsupportedVerificationMethodException { JWTClaimsSet jwtClaimsSet; try { jwtClaimsSet = jwt.getJWTClaimsSet(); } catch (ParseException e) { - throw new JwtException(e); + throw new SignatureException(e.getMessage()); } final String issuer = jwtClaimsSet.getIssuer(); @@ -89,11 +91,16 @@ public boolean verify(SignedJWT jwt) final String kty = method.getPublicKeyJwk().getKty(); final String crv = method.getPublicKeyJwk().getCrv(); final String x = method.getPublicKeyJwk().getX(); + if (kty.equals("OKP") && crv.equals("Ed25519")) { final OctetKeyPair keyPair = new OctetKeyPair.Builder(Curve.Ed25519, Base64URL.from(x)).build(); - if (jwt.verify(new Ed25519Verifier(keyPair))) { - return true; + try { + if (jwt.verify(new Ed25519Verifier(keyPair))) { + return true; + } + } catch (JOSEException e) { + throw new SignatureVerificationFailedException(e.getMessage()); } } else { throw new UnsupportedVerificationMethodException( @@ -109,8 +116,12 @@ public boolean verify(SignedJWT jwt) Curve.Ed25519, Base64URL.encode(publicKeyParameters.getEncoded())) .build(); - if (jwt.verify(new Ed25519Verifier(keyPair))) { - return true; + try { + if (jwt.verify(new Ed25519Verifier(keyPair))) { + return true; + } + } catch (JOSEException e) { + throw new SignatureVerificationFailedException(e.getMessage()); } } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/model/RemoteDocumentLoader.java b/src/main/java/org/eclipse/tractusx/ssi/lib/model/RemoteDocumentLoader.java index a8be25d8..60b78089 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/model/RemoteDocumentLoader.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/model/RemoteDocumentLoader.java @@ -44,6 +44,7 @@ /** The type Remote document loader. */ public class RemoteDocumentLoader implements DocumentLoader { + private static int CACHE_PERIOD_IN_DAYS = 1; private static DocumentLoader DEFAULT_HTTP_LOADER; private static DocumentLoader DEFAULT_FILE_LOADER; @Getter private DocumentLoader httpLoader; @@ -57,7 +58,7 @@ public class RemoteDocumentLoader implements DocumentLoader { @Getter @Setter private Cache remoteCache = - Caffeine.newBuilder().expireAfterWrite(Duration.ofDays(1)).build(); + Caffeine.newBuilder().expireAfterWrite(Duration.ofDays(CACHE_PERIOD_IN_DAYS)).build(); @Getter @Setter private List httpContexts = new ArrayList(); @Getter @Setter private List httpsContexts = new ArrayList(); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/model/did/DidParser.java b/src/main/java/org/eclipse/tractusx/ssi/lib/model/did/DidParser.java index 7f01f88e..ed209a8d 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/model/did/DidParser.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/model/did/DidParser.java @@ -26,18 +26,17 @@ import java.util.List; import java.util.Objects; import java.util.stream.Collectors; -import org.eclipse.tractusx.ssi.lib.exception.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; /** The type Did parser. */ public class DidParser { - /** - * Parse did. + * Parse did from URI. * * @param uri the uri * @return the did */ - public static Did parse(URI uri) { + public static Did parse(URI uri) throws DidParseException { Objects.requireNonNull(uri); if (!uri.getScheme().equals("did")) { @@ -66,12 +65,12 @@ public static Did parse(URI uri) { } /** - * Parse did. + * Parse did from String. * - * @param did the did + * @param did the did String * @return the did */ - public static Did parse(String did) { + public static Did parse(String did) throws DidParseException { Objects.requireNonNull(did); final URI uri; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/ISigner.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/ISigner.java index 3505e281..83fc8515 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/ISigner.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/ISigner.java @@ -22,8 +22,8 @@ package org.eclipse.tractusx.ssi.lib.proof; import org.eclipse.tractusx.ssi.lib.crypt.IPrivateKey; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePrivateKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.SsiException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPrivateKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureGenerateFailedException; import org.eclipse.tractusx.ssi.lib.proof.hash.HashedLinkedData; /** The interface Signer. */ @@ -38,5 +38,5 @@ public interface ISigner { * @throws InvalidePrivateKeyFormat the invalide private key format */ public byte[] sign(HashedLinkedData hashedLinkedData, IPrivateKey privateKey) - throws SsiException, InvalidePrivateKeyFormat; + throws InvalidPrivateKeyFormatException, SignatureGenerateFailedException; } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/IVerifier.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/IVerifier.java index ce0e2449..b1512b75 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/IVerifier.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/IVerifier.java @@ -21,10 +21,14 @@ package org.eclipse.tractusx.ssi.lib.proof; -import org.eclipse.tractusx.ssi.lib.exception.DidDocumentResolverNotRegisteredException; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePublicKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.NoVerificationKeyFoundExcpetion; -import org.eclipse.tractusx.ssi.lib.exception.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureGenerateFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable; import org.eclipse.tractusx.ssi.lib.model.verifiable.credential.VerifiableCredential; import org.eclipse.tractusx.ssi.lib.proof.hash.HashedLinkedData; @@ -36,15 +40,19 @@ public interface IVerifier { * model to get the public key of issuer. * * @param hashedLinkedData the hashed linked data - * @param verifiable the verifiable - * @return the boolean - * @throws UnsupportedSignatureTypeException the unsupported signature type exception - * @throws DidDocumentResolverNotRegisteredException the did document resolver not registered - * exception - * @throws InvalidePublicKeyFormat the invalide public key format - * @throws NoVerificationKeyFoundExcpetion the no verification key found excpetion + * @param document {@link VerifiableCredential} the verifiable + * @return boolean if verified or not + * @throws UnsupportedSignatureTypeException + * @throws SignatureParseException + * @throws InvalidPublicKeyFormatException + * @throws SignatureGenerateFailedException + * @throws SignatureVerificationFailedException + * @throws DidParseException + * @throws DidDocumentResolverNotRegisteredException + * @throws NoVerificationKeyFoundException */ public boolean verify(HashedLinkedData hashedLinkedData, Verifiable verifiable) - throws UnsupportedSignatureTypeException, DidDocumentResolverNotRegisteredException, - InvalidePublicKeyFormat, NoVerificationKeyFoundExcpetion; + throws SignatureParseException, DidParseException, InvalidPublicKeyFormatException, + SignatureVerificationFailedException, UnsupportedSignatureTypeException, + NoVerificationKeyFoundException, DidDocumentResolverNotRegisteredException; } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofGenerator.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofGenerator.java index 37b8fd58..ade51050 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofGenerator.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofGenerator.java @@ -26,9 +26,10 @@ import java.time.Instant; import lombok.RequiredArgsConstructor; import org.eclipse.tractusx.ssi.lib.crypt.IPrivateKey; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePrivateKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.SsiException; -import org.eclipse.tractusx.ssi.lib.exception.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.json.TransformJsonLdException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPrivateKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureGenerateFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; import org.eclipse.tractusx.ssi.lib.model.MultibaseString; import org.eclipse.tractusx.ssi.lib.model.base.MultibaseFactory; import org.eclipse.tractusx.ssi.lib.model.proof.Proof; @@ -84,7 +85,8 @@ public static LinkedDataProofGenerator newInstance(SignatureType type) * @throws InvalidePrivateKeyFormat the invalide private key format */ public Proof createProof(Verifiable document, URI verificationMethodId, IPrivateKey privateKey) - throws SsiException, InvalidePrivateKeyFormat { + throws InvalidPrivateKeyFormatException, SignatureGenerateFailedException, + TransformJsonLdException { final TransformedLinkedData transformedData = transformer.transform(document); final HashedLinkedData hashedData = hasher.hash(transformedData); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java index 657d584b..2c9ff6fa 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java @@ -24,10 +24,16 @@ import java.util.logging.Logger; import lombok.AccessLevel; import lombok.RequiredArgsConstructor; -import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolver; -import org.eclipse.tractusx.ssi.lib.exception.InvalidJsonLdException; -import org.eclipse.tractusx.ssi.lib.exception.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.json.InvalidJsonLdException; +import org.eclipse.tractusx.ssi.lib.exception.json.TransformJsonLdException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable.VerifiableType; import org.eclipse.tractusx.ssi.lib.model.verifiable.credential.VerifiableCredential; @@ -77,12 +83,21 @@ public static LinkedDataProofValidation newInstance(DidResolver didResolver) { * * @param verifiable the verifiable * @return the boolean + * @throws UnsupportedSignatureTypeException + * @throws DidDocumentResolverNotRegisteredException + * @throws NoVerificationKeyFoundException + * @throws SignatureVerificationFailedException + * @throws InvalidPublicKeyFormatException + * @throws DidParseException + * @throws SignatureParseException + * @throws TransformJsonLdException */ - @SneakyThrows - public boolean verify(Verifiable verifiable) { - if (verifiable.getProof() == null) { - throw new UnsupportedSignatureTypeException("Proof can't be empty"); - } + public boolean verify(Verifiable verifiable) + throws UnsupportedSignatureTypeException, SignatureParseException, DidParseException, + InvalidPublicKeyFormatException, SignatureVerificationFailedException, + NoVerificationKeyFoundException, DidDocumentResolverNotRegisteredException, + TransformJsonLdException { + var type = verifiable.getProof().getType(); IVerifier verifier = null; @@ -119,8 +134,8 @@ public boolean verify(Verifiable verifiable) { * @return * @throws UnsupportedSignatureTypeException */ - @SneakyThrows - private Boolean validateVerificationMethodOfVC(Verifiable verifiable) { + private Boolean validateVerificationMethodOfVC(Verifiable verifiable) + throws UnsupportedSignatureTypeException { // Verifiable Presentation doesn't have an Issuer if (verifiable.getType() == VerifiableType.VP) { return true; @@ -139,8 +154,8 @@ private Boolean validateVerificationMethodOfVC(Verifiable verifiable) { * @return * @throws UnsupportedSignatureTypeException */ - @SneakyThrows - private String getVerificationMethod(Verifiable verifiable) { + private String getVerificationMethod(Verifiable verifiable) + throws UnsupportedSignatureTypeException { try { return (String) verifiable.getProof().get("verificationMethod"); } catch (Exception e) { diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/transform/LinkedDataTransformer.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/transform/LinkedDataTransformer.java index abc171bb..28256e8c 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/transform/LinkedDataTransformer.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/transform/LinkedDataTransformer.java @@ -33,30 +33,29 @@ import java.io.IOException; import java.io.StringWriter; import java.security.NoSuchAlgorithmException; -import lombok.SneakyThrows; import org.apache.commons.lang3.SerializationUtils; +import org.eclipse.tractusx.ssi.lib.exception.json.TransformJsonLdException; import org.eclipse.tractusx.ssi.lib.model.JsonLdObject; import org.eclipse.tractusx.ssi.lib.model.RemoteDocumentLoader; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable; /** The type Linked data transformer. */ public class LinkedDataTransformer { - /** * Transform linked data. * * @param document the document * @return the transformed linked data */ - @SneakyThrows - public TransformedLinkedData transform(Verifiable document) { + public TransformedLinkedData transform(Verifiable document) throws TransformJsonLdException { // Make a copy and remove proof, as it is not part of the linked data var copy = (JsonLdObject) SerializationUtils.clone(document); copy.remove(Verifiable.PROOF); return this.canocliztion(copy); } - private TransformedLinkedData canocliztion(JsonLdObject document) { + private TransformedLinkedData canocliztion(JsonLdObject document) + throws TransformJsonLdException { try { RdfDataset rdfDataset = toDataset(document); @@ -68,10 +67,8 @@ private TransformedLinkedData canocliztion(JsonLdObject document) { return new TransformedLinkedData(normalized); - } catch (NoSuchAlgorithmException e) { - throw new RuntimeException(e); - } catch (IOException e) { - throw new RuntimeException(e); + } catch (NoSuchAlgorithmException | IOException e) { + throw new TransformJsonLdException(e.getMessage()); } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofSigner.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofSigner.java index f8752880..84d43bb9 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofSigner.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofSigner.java @@ -24,7 +24,6 @@ import org.bouncycastle.crypto.params.Ed25519PrivateKeyParameters; import org.bouncycastle.crypto.signers.Ed25519Signer; import org.eclipse.tractusx.ssi.lib.crypt.IPrivateKey; -import org.eclipse.tractusx.ssi.lib.exception.SsiException; import org.eclipse.tractusx.ssi.lib.proof.ISigner; import org.eclipse.tractusx.ssi.lib.proof.hash.HashedLinkedData; @@ -32,8 +31,7 @@ public class Ed25519ProofSigner implements ISigner { @Override - public byte[] sign(HashedLinkedData hashedLinkedData, IPrivateKey privateKey) - throws SsiException { + public byte[] sign(HashedLinkedData hashedLinkedData, IPrivateKey privateKey) { final byte[] message = hashedLinkedData.getValue(); Ed25519PrivateKeyParameters secretKeyParameters = diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofVerifier.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofVerifier.java index a33bb0ab..5936161a 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofVerifier.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofVerifier.java @@ -32,10 +32,11 @@ import org.eclipse.tractusx.ssi.lib.crypt.x21559.x21559PublicKey; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolver; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; -import org.eclipse.tractusx.ssi.lib.exception.DidDocumentResolverNotRegisteredException; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePublicKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.NoVerificationKeyFoundExcpetion; -import org.eclipse.tractusx.ssi.lib.exception.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; +import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; import org.eclipse.tractusx.ssi.lib.model.MultibaseString; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; @@ -55,8 +56,9 @@ public class Ed25519ProofVerifier implements IVerifier { @SneakyThrows({DidResolverException.class}) public boolean verify(HashedLinkedData hashedLinkedData, Verifiable verifiable) - throws UnsupportedSignatureTypeException, DidDocumentResolverNotRegisteredException, - InvalidePublicKeyFormat, NoVerificationKeyFoundExcpetion { + throws UnsupportedSignatureTypeException, InvalidPublicKeyFormatException, + NoVerificationKeyFoundException, DidParseException, + DidDocumentResolverNotRegisteredException { final Proof proof = verifiable.getProof(); final Ed25519Signature2020 ed25519Signature2020 = new Ed25519Signature2020(proof); @@ -74,7 +76,8 @@ public boolean verify(HashedLinkedData hashedLinkedData, Verifiable verifiable) private IPublicKey discoverPublicKey(Ed25519Signature2020 signature) throws DidDocumentResolverNotRegisteredException, UnsupportedSignatureTypeException, - InvalidePublicKeyFormat, NoVerificationKeyFoundExcpetion, DidResolverException { + InvalidPublicKeyFormatException, NoVerificationKeyFoundException, DidResolverException, + DidParseException { final Did issuer = DidParser.parse(signature.getVerificationMethod()); @@ -89,14 +92,14 @@ private IPublicKey discoverPublicKey(Ed25519Signature2020 signature) .findFirst() .orElseThrow( () -> - new NoVerificationKeyFoundExcpetion( + new NoVerificationKeyFoundException( "No Ed25519 verification key found in DID Document")); IPublicKey publicKey; try { publicKey = (IPublicKey) new x21559PublicKey(key.getPublicKeyBase58().getEncoded(), false); } catch (IOException e) { - throw new InvalidePublicKeyFormat(e.getCause()); + throw new InvalidPublicKeyFormatException(e.getCause()); } return publicKey; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofSigner.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofSigner.java index 973ce991..a6000cce 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofSigner.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofSigner.java @@ -32,8 +32,8 @@ import java.io.IOException; import org.eclipse.tractusx.ssi.lib.crypt.IPrivateKey; import org.eclipse.tractusx.ssi.lib.crypt.octet.OctetKeyPairFactory; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePrivateKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.SsiException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPrivateKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureGenerateFailedException; import org.eclipse.tractusx.ssi.lib.proof.ISigner; import org.eclipse.tractusx.ssi.lib.proof.hash.HashedLinkedData; @@ -42,21 +42,21 @@ public class JWSProofSigner implements ISigner { @Override public byte[] sign(HashedLinkedData hashedLinkedData, IPrivateKey privateKey) - throws InvalidePrivateKeyFormat { + throws InvalidPrivateKeyFormatException, SignatureGenerateFailedException { OctetKeyPairFactory octetKeyPairFactory = new OctetKeyPairFactory(); OctetKeyPair keyPair; try { keyPair = octetKeyPairFactory.fromPrivateKey(privateKey); } catch (IOException e) { - throw new InvalidePrivateKeyFormat(e.getCause()); + throw new InvalidPrivateKeyFormatException(e.getCause()); } JWSSigner signer; try { signer = new Ed25519Signer(keyPair); } catch (JOSEException e) { - throw new SsiException(e.getMessage()); + throw new InvalidPrivateKeyFormatException(e.getMessage()); } var header = new JWSHeader.Builder(JWSAlgorithm.EdDSA).build(); @@ -66,7 +66,7 @@ public byte[] sign(HashedLinkedData hashedLinkedData, IPrivateKey privateKey) try { jwsObject.sign(signer); } catch (JOSEException e) { - throw new SsiException(e.getMessage()); + throw new SignatureGenerateFailedException(e.getMessage()); } return jwsObject.serialize(true).getBytes(); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofVerifier.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofVerifier.java index 3e4125d1..7888c294 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofVerifier.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofVerifier.java @@ -36,11 +36,11 @@ import org.eclipse.tractusx.ssi.lib.crypt.IPublicKey; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolver; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; -import org.eclipse.tractusx.ssi.lib.exception.DidDocumentResolverNotRegisteredException; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePublicKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.NoVerificationKeyFoundExcpetion; -import org.eclipse.tractusx.ssi.lib.exception.SsiException; -import org.eclipse.tractusx.ssi.lib.exception.UnsupportedSignatureTypeException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; import org.eclipse.tractusx.ssi.lib.model.did.DidParser; @@ -59,12 +59,13 @@ public class JWSProofVerifier implements IVerifier { @SneakyThrows({DidResolverException.class}) public boolean verify(HashedLinkedData hashedLinkedData, Verifiable document) - throws UnsupportedSignatureTypeException, DidDocumentResolverNotRegisteredException, - NoVerificationKeyFoundExcpetion, InvalidePublicKeyFormat { + throws SignatureParseException, DidParseException, InvalidPublicKeyFormatException, + SignatureVerificationFailedException { final Proof proof = document.getProof(); if (!proof.getType().equals(JWSSignature2020.JWS_VERIFICATION_KEY_2020)) { - throw new UnsupportedSignatureTypeException(proof.getType()); + throw new SignatureParseException( + String.format("Unsupported verification method: %s", proof.getType())); } final JWSSignature2020 jwsSignature2020 = new JWSSignature2020(proof); @@ -76,28 +77,32 @@ public boolean verify(HashedLinkedData hashedLinkedData, Verifiable document) try { jws = JWSObject.parse(jwsSignature2020.getJws(), payload); } catch (ParseException e) { - throw new SsiException(e.getMessage()); + throw new SignatureParseException(jwsSignature2020.getJws()); } - var keyPair = this.discoverOctectKey(jwsSignature2020); - JWSVerifier verifier; + OctetKeyPair keyPair = null; + try { + keyPair = this.discoverOctectKey(jwsSignature2020); + } catch (NoVerificationKeyFoundException e) { + throw new SignatureParseException(e.getMessage()); + } + JWSVerifier verifier; try { verifier = new Ed25519Verifier(keyPair); } catch (JOSEException e) { - throw new SsiException(e.getMessage()); + throw new InvalidPublicKeyFormatException(e.getMessage()); } try { return jws.verify(verifier); } catch (JOSEException e) { - throw new SsiException(e.getMessage()); + throw new SignatureVerificationFailedException(e.getMessage()); } } private OctetKeyPair discoverOctectKey(JWSSignature2020 signature) - throws DidDocumentResolverNotRegisteredException, UnsupportedSignatureTypeException, - InvalidePublicKeyFormat, NoVerificationKeyFoundExcpetion, DidResolverException { + throws NoVerificationKeyFoundException, DidParseException, DidResolverException { final Did issuer = DidParser.parse(signature.getVerificationMethod()); @@ -113,7 +118,7 @@ private OctetKeyPair discoverOctectKey(JWSSignature2020 signature) .findFirst() .orElseThrow( () -> - new NoVerificationKeyFoundExcpetion( + new NoVerificationKeyFoundException( "No JWS verification Key found in DID Document")); var x = Base64URL.from(key.getPublicKeyJwk().getX()); @@ -130,21 +135,34 @@ private OctetKeyPair discoverOctectKey(JWSSignature2020 signature) * @param signature the signature * @param publicKey the public key * @return the boolean + * @throws SignatureParseException + * @throws SignatureVerificationFailedException + * @throws InvalidPublicKeyFormatException */ - @SneakyThrows - public boolean verify(HashedLinkedData hashedLinkedData, byte[] signature, IPublicKey publicKey) { + public boolean verify(HashedLinkedData hashedLinkedData, byte[] signature, IPublicKey publicKey) + throws SignatureParseException, SignatureVerificationFailedException, + InvalidPublicKeyFormatException { var keyPair = new OctetKeyPair.Builder(Curve.Ed25519, Base64URL.encode(publicKey.asByte())).build(); - JWSVerifier verifier = (JWSVerifier) new Ed25519Verifier(keyPair.toPublicJWK()); + JWSVerifier verifier; + try { + verifier = (JWSVerifier) new Ed25519Verifier(keyPair.toPublicJWK()); + } catch (JOSEException e) { + throw new InvalidPublicKeyFormatException(e.getMessage()); + } Payload payload = new Payload(hashedLinkedData.getValue()); JWSObject jws; try { jws = JWSObject.parse(new String(signature), payload); } catch (ParseException e) { - throw new SsiException(e.getMessage()); + throw new SignatureParseException(String.format("Error while parsing JWS %s", signature)); + } + try { + return jws.verify(verifier); + } catch (JOSEException e) { + throw new SignatureVerificationFailedException(e.getMessage()); } - return jws.verify(verifier); } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/serialization/jsonLd/JsonLdSerializer.java b/src/main/java/org/eclipse/tractusx/ssi/lib/serialization/jsonLd/JsonLdSerializer.java index b6cc2cc2..fb42bf8a 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/serialization/jsonLd/JsonLdSerializer.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/serialization/jsonLd/JsonLdSerializer.java @@ -21,7 +21,7 @@ package org.eclipse.tractusx.ssi.lib.serialization.jsonLd; -import org.eclipse.tractusx.ssi.lib.exception.InvalidJsonLdException; +import org.eclipse.tractusx.ssi.lib.exception.json.InvalidJsonLdException; import org.eclipse.tractusx.ssi.lib.model.verifiable.presentation.VerifiablePresentation; import org.eclipse.tractusx.ssi.lib.serialization.jwt.SerializedVerifiablePresentation; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/serialization/jsonLd/JsonLdSerializerImpl.java b/src/main/java/org/eclipse/tractusx/ssi/lib/serialization/jsonLd/JsonLdSerializerImpl.java index d289b4fb..528e8634 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/serialization/jsonLd/JsonLdSerializerImpl.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/serialization/jsonLd/JsonLdSerializerImpl.java @@ -21,7 +21,7 @@ package org.eclipse.tractusx.ssi.lib.serialization.jsonLd; -import org.eclipse.tractusx.ssi.lib.exception.InvalidJsonLdException; +import org.eclipse.tractusx.ssi.lib.exception.json.InvalidJsonLdException; import org.eclipse.tractusx.ssi.lib.model.verifiable.presentation.VerifiablePresentation; import org.eclipse.tractusx.ssi.lib.serialization.jwt.SerializedVerifiablePresentation; import org.eclipse.tractusx.ssi.lib.validation.JsonLdValidator; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidator.java b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidator.java index 3a9df3c7..e63d166c 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidator.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidator.java @@ -21,7 +21,7 @@ package org.eclipse.tractusx.ssi.lib.validation; -import org.eclipse.tractusx.ssi.lib.exception.InvalidJsonLdException; +import org.eclipse.tractusx.ssi.lib.exception.json.InvalidJsonLdException; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable; public interface JsonLdValidator { diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java index 9e3ff27b..c8a75cd2 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java @@ -32,7 +32,7 @@ import jakarta.json.JsonValue; import java.util.Map; import java.util.logging.Logger; -import org.eclipse.tractusx.ssi.lib.exception.InvalidJsonLdException; +import org.eclipse.tractusx.ssi.lib.exception.json.InvalidJsonLdException; import org.eclipse.tractusx.ssi.lib.model.JsonLdObject; import org.eclipse.tractusx.ssi.lib.model.RemoteDocumentLoader; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable; diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/cypto/ed21995/ed21559KeyTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/cypto/ed21995/ed21559KeyTest.java index 00524296..ca65a053 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/cypto/ed21995/ed21559KeyTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/cypto/ed21995/ed21559KeyTest.java @@ -26,14 +26,15 @@ import java.io.IOException; import java.util.Arrays; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.crypt.IKeyGenerator; import org.eclipse.tractusx.ssi.lib.crypt.KeyPair; import org.eclipse.tractusx.ssi.lib.crypt.x21559.x21559Generator; import org.eclipse.tractusx.ssi.lib.crypt.x21559.x21559PrivateKey; import org.eclipse.tractusx.ssi.lib.crypt.x21559.x21559PublicKey; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePrivateKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePublicKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.KeyGenerationException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPrivateKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.key.KeyGenerationException; import org.eclipse.tractusx.ssi.lib.model.base.EncodeType; import org.junit.jupiter.api.Test; @@ -60,6 +61,7 @@ public void testED21559KeyGeneration() throws KeyGenerationException { * @throws IOException the io exception */ @Test + @SneakyThrows public void testED21559KeySerliztion() throws KeyGenerationException, IOException { IKeyGenerator keyGenerator = new x21559Generator(); KeyPair keyPair = keyGenerator.generateKey(); @@ -82,9 +84,10 @@ public void testED21559KeySerliztion() throws KeyGenerationException, IOExceptio * @throws InvalidePublicKeyFormat the invalide public key format */ @Test + @SneakyThrows public void testED21559KeyDeserliztion() - throws KeyGenerationException, IOException, InvalidePrivateKeyFormat, - InvalidePublicKeyFormat { + throws KeyGenerationException, IOException, InvalidPrivateKeyFormatException, + InvalidPublicKeyFormatException { IKeyGenerator keyGenerator = new x21559Generator(); KeyPair keyPair = keyGenerator.generateKey(); diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolverTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolverTest.java index 62ded3e0..83afa40c 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolverTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolverTest.java @@ -33,6 +33,7 @@ import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; @@ -68,7 +69,8 @@ public void resetMocks() { * @throws DidResolverException the did resolver exception */ @Test - public void shouldResolveWithOneResolver() throws DidResolverException { + @SneakyThrows + public void shouldResolveWithOneResolver() { when(resolver1.isResolvable(any())).thenReturn(true); when(resolver1.resolve(any())).thenReturn(RESOLVED_DID_DOC); CompositeDidResolver resolver = new CompositeDidResolver(resolver1); @@ -82,7 +84,8 @@ public void shouldResolveWithOneResolver() throws DidResolverException { * @throws DidResolverException the did resolver exception */ @Test - public void shouldResolveWithFirstResolver() throws DidResolverException { + @SneakyThrows + public void shouldResolveWithFirstResolver() { when(resolver1.isResolvable(any())).thenReturn(true); when(resolver1.resolve(any())).thenReturn(RESOLVED_DID_DOC); @@ -99,7 +102,8 @@ public void shouldResolveWithFirstResolver() throws DidResolverException { * @throws DidResolverException the did resolver exception */ @Test - public void shouldResolveWithSecondResolver() throws DidResolverException { + @SneakyThrows + public void shouldResolveWithSecondResolver() { when(resolver1.isResolvable(any())).thenReturn(false); when(resolver2.isResolvable(any())).thenReturn(true); when(resolver2.resolve(any())).thenReturn(RESOLVED_DID_DOC); @@ -116,7 +120,8 @@ public void shouldResolveWithSecondResolver() throws DidResolverException { * @throws DidResolverException the did resolver exception */ @Test - public void mustNotResolveOnFalse() throws DidResolverException { + @SneakyThrows + public void mustNotResolveOnFalse() { when(resolver1.isResolvable(any())).thenReturn(false); when(resolver2.isResolvable(any())).thenReturn(false); @@ -133,7 +138,8 @@ public void mustNotResolveOnFalse() throws DidResolverException { * @throws DidResolverException the did resolver exception */ @Test - public void mustNotResolveOnException() throws DidResolverException { + @SneakyThrows + public void mustNotResolveOnException() { when(resolver1.isResolvable(any())).thenReturn(true); when(resolver1.resolve(any())).thenThrow(DidResolverException.class); when(resolver1.isResolvable(any())).thenReturn(true); @@ -154,7 +160,8 @@ public void mustNotResolveOnException() throws DidResolverException { * @throws DidResolverException the did resolver exception */ @Test - public void shouldConstructCompositeResolverUsingStaticMethod() throws DidResolverException { + @SneakyThrows + public void shouldConstructCompositeResolverUsingStaticMethod() { when(resolver1.isResolvable(any())).thenReturn(true); when(resolver1.resolve(any())).thenReturn(RESOLVED_DID_DOC); diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverIT.java b/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverIT.java index 191de5c4..20f7ca88 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverIT.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverIT.java @@ -25,7 +25,7 @@ import static org.junit.jupiter.api.Assertions.assertTrue; import java.net.http.HttpClient; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; @@ -68,7 +68,8 @@ public void initEach() { * @throws DidResolverException the did resolver exception */ @Test - public void shouldResolveValidWebDid() throws DidResolverException { + @SneakyThrows + public void shouldResolveValidWebDid() { Did validDidWeb = new Did( new DidMethod("web"), @@ -85,7 +86,8 @@ public void shouldResolveValidWebDid() throws DidResolverException { * @throws DidResolverException the did resolver exception */ @Test - public void shouldResolveValidExternalWebDid() throws DidResolverException { + @SneakyThrows + public void shouldResolveValidExternalWebDid() { final String didIdentifier = "did.actor:alice"; Did validDidWeb = new Did(new DidMethod("web"), new DidMethodIdentifier(didIdentifier), null); assertTrue(httpsResolver.isResolvable(validDidWeb)); diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverTest.java index 19c3af54..9a2f91a2 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverTest.java @@ -29,11 +29,10 @@ import static org.mockito.ArgumentMatchers.anyBoolean; import static org.mockito.Mockito.when; -import java.io.IOException; import java.net.URI; -import java.net.URISyntaxException; import java.net.http.HttpClient; import java.net.http.HttpResponse; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; import org.eclipse.tractusx.ssi.lib.model.did.Did; @@ -72,8 +71,8 @@ public void initEach() { * @throws URISyntaxException the uri syntax exception */ @Test - public void shouldResolveValidWebDid() - throws DidResolverException, IOException, InterruptedException, URISyntaxException { + @SneakyThrows + public void shouldResolveValidWebDid() { Did validDidWeb = new Did(new DidMethod("web"), new DidMethodIdentifier("localhost"), null); assertTrue(resolver.isResolvable(validDidWeb)); when(httpClient.send(any(), any())).thenReturn(response); @@ -91,7 +90,8 @@ public void shouldResolveValidWebDid() * @throws DidResolverException the did resolver exception */ @Test - public void shouldNotResolveNonWebDid() throws DidResolverException { + @SneakyThrows + public void shouldNotResolveNonWebDid() { Did validDidKey = new Did( new DidMethod("key"), diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/util/DidWebParserTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/util/DidWebParserTest.java index be8f5f9d..8f48769d 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/util/DidWebParserTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/util/DidWebParserTest.java @@ -22,6 +22,7 @@ package org.eclipse.tractusx.ssi.lib.did.web.util; import java.net.URI; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; import org.eclipse.tractusx.ssi.lib.model.did.DidMethodIdentifier; @@ -49,6 +50,7 @@ public class DidWebParserTest { "some-host:path1:path2, https://some-host/path1/path2/did.json", "some-host%3A9090:path1:path2, https://some-host:9090/path1/path2/did.json" }) + @SneakyThrows public void testResolveUriFromDid(String methodIdentifier, String expectedUri) { final Did did = new Did(new DidMethod("web"), new DidMethodIdentifier(methodIdentifier), null); diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidationComponentTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidationComponentTest.java index 15fcb242..1a9d5794 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidationComponentTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidationComponentTest.java @@ -21,17 +21,13 @@ package org.eclipse.tractusx.ssi.lib.proof; -import java.io.IOException; import java.net.URI; import java.time.Instant; import java.time.ZoneOffset; import java.time.format.DateTimeFormatter; import java.util.List; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.SsiLibrary; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePrivateKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.KeyGenerationException; -import org.eclipse.tractusx.ssi.lib.exception.SsiException; -import org.eclipse.tractusx.ssi.lib.exception.UnsupportedSignatureTypeException; import org.eclipse.tractusx.ssi.lib.model.proof.Proof; import org.eclipse.tractusx.ssi.lib.model.proof.jws.JWSSignature2020; import org.eclipse.tractusx.ssi.lib.model.verifiable.credential.VerifiableCredential; @@ -60,19 +56,10 @@ public void setup() { this.didResolver = new TestDidResolver(); } - /** - * Test vc proof failure on manipulated credential. - * - * @throws IOException the io exception - * @throws UnsupportedSignatureTypeException the unsupported signature type exception - * @throws InvalidePrivateKeyFormat the invalide private key format - * @throws KeyGenerationException the key generation exception - */ + /** Test vc proof failure on manipulated credential. */ @Test - public void testVCProofFailureOnManipulatedCredential() - throws IOException, UnsupportedSignatureTypeException, InvalidePrivateKeyFormat, - KeyGenerationException { - + @SneakyThrows + public void testVCProofFailureOnManipulatedCredential() { credentialIssuer = TestIdentityFactory.newIdentityWithED25519Keys(); didResolver.register(credentialIssuer); @@ -106,18 +93,10 @@ public void testVCProofFailureOnManipulatedCredential() Assertions.assertFalse(isOk); } - /** - * Test vc ed 21559 proof generation and verification. - * - * @throws IOException the io exception - * @throws UnsupportedSignatureTypeException the unsupported signature type exception - * @throws InvalidePrivateKeyFormat the invalide private key format - * @throws KeyGenerationException the key generation exception - */ + /** Test vc ed 21559 proof generation and verification. */ @Test - public void testVCEd21559ProofGenerationAndVerification() - throws IOException, UnsupportedSignatureTypeException, InvalidePrivateKeyFormat, - KeyGenerationException { + @SneakyThrows + public void testVCEd21559ProofGenerationAndVerification() { credentialIssuer = TestIdentityFactory.newIdentityWithED25519Keys(); didResolver.register(credentialIssuer); @@ -146,18 +125,10 @@ public void testVCEd21559ProofGenerationAndVerification() Assertions.assertTrue(isOk); } - /** - * Test vcjws proof generation and verification. - * - * @throws IOException the io exception - * @throws UnsupportedSignatureTypeException the unsupported signature type exception - * @throws InvalidePrivateKeyFormat the invalide private key format - * @throws KeyGenerationException the key generation exception - */ + /** Test vcjws proof generation and verification. */ @Test - public void testVCJWSProofGenerationAndVerification() - throws IOException, UnsupportedSignatureTypeException, InvalidePrivateKeyFormat, - KeyGenerationException { + @SneakyThrows + public void testVCJWSProofGenerationAndVerification() { credentialIssuer = TestIdentityFactory.newIdentityWithED25519Keys(); didResolver.register(credentialIssuer); @@ -187,18 +158,10 @@ public void testVCJWSProofGenerationAndVerification() Assertions.assertTrue(isOk); } - /** - * Test vp ed 21559 proof generation and verification. - * - * @throws IOException the io exception - * @throws UnsupportedSignatureTypeException the unsupported signature type exception - * @throws InvalidePrivateKeyFormat the invalide private key format - * @throws KeyGenerationException the key generation exception - */ + /** Test vp ed 21559 proof generation and verification. */ @Test - public void testVPEd21559ProofGenerationAndVerification() - throws IOException, UnsupportedSignatureTypeException, InvalidePrivateKeyFormat, - KeyGenerationException { + @SneakyThrows + public void testVPEd21559ProofGenerationAndVerification() { credentialIssuer = TestIdentityFactory.newIdentityWithED25519Keys(); didResolver.register(credentialIssuer); @@ -236,18 +199,10 @@ public void testVPEd21559ProofGenerationAndVerification() Assertions.assertTrue(isOk); } - /** - * Test vpjws proof generation and verification. - * - * @throws IOException the io exception - * @throws UnsupportedSignatureTypeException the unsupported signature type exception - * @throws InvalidePrivateKeyFormat the invalide private key format - * @throws KeyGenerationException the key generation exception - */ + /** Test vpjws proof generation and verification. */ @Test - public void testVPJWSProofGenerationAndVerification() - throws IOException, UnsupportedSignatureTypeException, InvalidePrivateKeyFormat, - KeyGenerationException { + @SneakyThrows + public void testVPJWSProofGenerationAndVerification() { credentialIssuer = TestIdentityFactory.newIdentityWithED25519Keys(); didResolver.register(credentialIssuer); @@ -287,10 +242,10 @@ public void testVPJWSProofGenerationAndVerification() Assertions.assertTrue(isOk); } + /** Test verification method. */ @Test - public void testVerificationMethodOfVC() - throws IOException, KeyGenerationException, UnsupportedSignatureTypeException, SsiException, - InvalidePrivateKeyFormat { + @SneakyThrows + public void testVerificationMethodOfVC() { credentialIssuer = TestIdentityFactory.newIdentityWithED25519Keys(); didResolver.register(credentialIssuer); diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/proof/SignAndVerifyTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/proof/SignAndVerifyTest.java index c23cd128..227c4f27 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/proof/SignAndVerifyTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/proof/SignAndVerifyTest.java @@ -21,13 +21,8 @@ package org.eclipse.tractusx.ssi.lib.proof; -import com.nimbusds.jose.JOSEException; -import java.io.IOException; import java.security.MessageDigest; -import java.security.NoSuchAlgorithmException; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePrivateKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.InvalidePublicKeyFormat; -import org.eclipse.tractusx.ssi.lib.exception.KeyGenerationException; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.proof.hash.HashedLinkedData; import org.eclipse.tractusx.ssi.lib.proof.types.ed25519.Ed25519ProofSigner; import org.eclipse.tractusx.ssi.lib.proof.types.ed25519.Ed25519ProofVerifier; @@ -50,9 +45,8 @@ public class SignAndVerifyTest { * @throws KeyGenerationException the key generation exception */ @Test - public void testSignAndVerify_ED201559() - throws IOException, InvalidePrivateKeyFormat, InvalidePublicKeyFormat, - KeyGenerationException { + @SneakyThrows + public void testSignAndVerify_ED201559() { final TestDidResolver didResolver = new TestDidResolver(); var testIdentity = TestIdentityFactory.newIdentityWithED25519Keys(); @@ -81,9 +75,8 @@ public void testSignAndVerify_ED201559() * @throws KeyGenerationException the key generation exception */ @Test - public void testSignAndVerify_JWS() - throws IOException, JOSEException, NoSuchAlgorithmException, InvalidePrivateKeyFormat, - InvalidePublicKeyFormat, KeyGenerationException { + @SneakyThrows + public void testSignAndVerify_JWS() { final TestDidResolver didResolver = new TestDidResolver(); var testIdentity = TestIdentityFactory.newIdentityWithED25519Keys(); diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/proof/proof/LinkedDataTransformerTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/proof/proof/LinkedDataTransformerTest.java index 65407f78..5cae3199 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/proof/proof/LinkedDataTransformerTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/proof/proof/LinkedDataTransformerTest.java @@ -73,6 +73,7 @@ public class LinkedDataTransformerTest { /** Test two transformations equal. */ @Test + @SneakyThrows public void testTwoTransformationsEqual() { final VerifiableCredential credential1 = deserializeCredential(SummaryVerifiableCredential); final var data1 = transformer.transform(credential1); @@ -92,6 +93,7 @@ public void testTwoTransformationsEqual() { value = { "issuer\": \"did:web:localhost%3A8080:BPNOPERATOR, issuer\": \"did:web:localhost%3A8080:BPNATTACKER" }) + @SneakyThrows public void testTwoTransformationDifference(String original, String replace) { final VerifiableCredential credential1 = deserializeCredential(SummaryVerifiableCredential); final VerifiableCredential credential2 = diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/serialization/SerializeUtilTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/serialization/SerializeUtilTest.java index 4557bec8..9184f531 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/serialization/SerializeUtilTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/serialization/SerializeUtilTest.java @@ -28,6 +28,7 @@ import java.util.List; import java.util.Map; import java.util.Set; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; import org.eclipse.tractusx.ssi.lib.model.did.Ed25519VerificationMethod; import org.eclipse.tractusx.ssi.lib.model.verifiable.credential.VerifiableCredential; @@ -69,7 +70,8 @@ public void shouldSerializeVpContextFirst() { */ @Test @DisplayName("Test property order in json string for VC") - void testVCJsonPropertyOrder() throws JsonProcessingException { + @SneakyThrows + void testVCJsonPropertyOrder() { ObjectMapper objectMapper = new ObjectMapper(); // test VC json @@ -99,7 +101,8 @@ void testVCJsonPropertyOrder() throws JsonProcessingException { */ @Test @DisplayName("Test property order in json string for did document") - void testDidDocumentJsonPropertyOrder() throws JsonProcessingException { + @SneakyThrows + void testDidDocumentJsonPropertyOrder() { ObjectMapper objectMapper = new ObjectMapper(); // test did document json DidDocument didDocument = diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/serialization/jsonld/DanubeTechMapperTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/serialization/jsonld/DanubeTechMapperTest.java deleted file mode 100644 index 4f9a26b0..00000000 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/serialization/jsonld/DanubeTechMapperTest.java +++ /dev/null @@ -1,55 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.serialization.jsonld; - -/** The type Danube tech mapper test. */ -public class DanubeTechMapperTest { - - // @SneakyThrows - // @Test - // public void canMapVerifiableCredential() { - - // VerifiableCredential expected = - // new VerifiableCredential(TestResourceUtil.getAlumniVerifiableCredential()); - - // com.danubetech.verifiablecredentials.VerifiableCredential dtCredential = - // DanubeTechMapper.map(expected); - - // VerifiableCredential result = DanubeTechMapper.map(dtCredential); - - // Assertions.assertEquals(expected.toPrettyJson(), result.toPrettyJson()); - // } - - // @SneakyThrows - // @Test - // public void canMapVerifiablePresentation() { - - // VerifiablePresentation expected = - // new VerifiablePresentation(TestResourceUtil.getAlumniVerifiablePresentation()); - - // com.danubetech.verifiablecredentials.VerifiablePresentation dtCredential = - // DanubeTechMapper.map(expected); - // VerifiablePresentation result = //DanubeTechMapper.map(dtCredential); - - // Assertions.assertEquals(expected.toPrettyJson(), result.toPrettyJson()); - // } -} diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/util/identity/TestDidDocumentResolver.java b/src/test/java/org/eclipse/tractusx/ssi/lib/util/identity/TestDidDocumentResolver.java deleted file mode 100644 index a61a408a..00000000 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/util/identity/TestDidDocumentResolver.java +++ /dev/null @@ -1,82 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.util.identity; - -import java.util.HashMap; -import java.util.Map; -import java.util.stream.Collectors; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidDocumentResolver; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidDocumentResolverRegistry; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidDocumentResolverRegistryImpl; -import org.eclipse.tractusx.ssi.lib.model.did.Did; -import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; -import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; - -/** The type Test did document resolver. */ -@Deprecated -/** Remove when {@code DidDocumentResolver} is removed. */ -public class TestDidDocumentResolver implements DidDocumentResolver { - private final Map documents = new HashMap<>(); - - @Override - public DidMethod getSupportedMethod() { - return TestDidFactory.DID_METHOD; - } - - @Override - public DidDocument resolve(Did did) { - - // We don't need fragment when we are searching for DID document ID. - Did didWithoutFragment = did.excludeFragment(); - if (!documents.containsKey(didWithoutFragment)) { - throw new RuntimeException( - String.format( - "Did not found: %s. Got [%s]", - did.toString(), - documents.values().stream() - .map(DidDocument::toString) - .collect(Collectors.joining(", ")))); - } - - return documents.get(didWithoutFragment); - } - - /** - * Register. - * - * @param testIdentity the test identity - */ - public void register(TestIdentity testIdentity) { - documents.put(testIdentity.getDid(), testIdentity.getDidDocument()); - } - - /** - * With registry did document resolver registry. - * - * @return the did document resolver registry - */ - public DidDocumentResolverRegistry withRegistry() { - final DidDocumentResolverRegistry registry = new DidDocumentResolverRegistryImpl(); - registry.register(this); - return registry; - } -} diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/util/identity/TestIdentityFactory.java b/src/test/java/org/eclipse/tractusx/ssi/lib/util/identity/TestIdentityFactory.java index d3275795..94dc63e4 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/util/identity/TestIdentityFactory.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/util/identity/TestIdentityFactory.java @@ -21,16 +21,15 @@ package org.eclipse.tractusx.ssi.lib.util.identity; -import java.io.IOException; import java.net.URI; import java.util.List; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.crypt.IKeyGenerator; import org.eclipse.tractusx.ssi.lib.crypt.IPrivateKey; import org.eclipse.tractusx.ssi.lib.crypt.IPublicKey; import org.eclipse.tractusx.ssi.lib.crypt.KeyPair; import org.eclipse.tractusx.ssi.lib.crypt.jwk.JsonWebKey; import org.eclipse.tractusx.ssi.lib.crypt.x21559.x21559Generator; -import org.eclipse.tractusx.ssi.lib.exception.KeyGenerationException; import org.eclipse.tractusx.ssi.lib.model.MultibaseString; import org.eclipse.tractusx.ssi.lib.model.base.MultibaseFactory; import org.eclipse.tractusx.ssi.lib.model.did.Did; @@ -48,11 +47,9 @@ public class TestIdentityFactory { * New identity with ed 25519 keys test identity. * * @return the test identity - * @throws IOException the io exception - * @throws KeyGenerationException the key generation exception */ - public static TestIdentity newIdentityWithED25519Keys() - throws IOException, KeyGenerationException { + @SneakyThrows + public static TestIdentity newIdentityWithED25519Keys() { final Did did = TestDidFactory.createRandom(); diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/verifiable/VerifiableCredentialTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/verifiable/VerifiableCredentialTest.java index 8bd4ef38..c3dd1535 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/verifiable/VerifiableCredentialTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/verifiable/VerifiableCredentialTest.java @@ -21,8 +21,6 @@ package org.eclipse.tractusx.ssi.lib.verifiable; -import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.JsonMappingException; import com.fasterxml.jackson.databind.ObjectMapper; import java.util.Map; import lombok.SneakyThrows; @@ -45,7 +43,7 @@ public class VerifiableCredentialTest { */ @Test @SneakyThrows - public void canSerializeVC() throws JsonMappingException, JsonProcessingException { + public void canSerializeVC() { final Map vpFromMap = TestResourceUtil.getAlumniVerifiableCredential(); var vp = new VerifiableCredential(vpFromMap); var json = vp.toJson(); From a6a296556f42fc310bf8f22046f9762319c1641d Mon Sep 17 00:00:00 2001 From: Koptan Date: Thu, 11 Jan 2024 09:45:22 +0100 Subject: [PATCH 02/12] chore: Adding SerialVersion to all Exceptions --- .gitignore | 1 + .../ssi/lib/exception/SSIException.java | 2 ++ .../lib/exception/did/DidParseException.java | 30 ++++++++++++++++--- .../json/InvalidJsonLdException.java | 1 + .../json/TransformJsonLdException.java | 3 +- .../key/InvalidPrivateKeyFormatException.java | 1 + .../key/InvalidPublicKeyFormatException.java | 1 + .../exception/key/KeyGenerationException.java | 3 +- .../key/KeyTransformationException.java | 1 + .../JwtAudienceCheckFailedException.java | 2 +- .../exception/proof/JwtExpiredException.java | 2 +- .../NoVerificationKeyFoundException.java | 2 +- .../SignatureGenerateFailedException.java | 2 +- .../proof/SignatureParseException.java | 2 +- .../SignatureVerificationFailedException.java | 2 +- ...entResolverAlreadyRegisteredException.java | 1 + ...ocumentResolverNotRegisteredException.java | 2 ++ .../exception/resolver/DidWebException.java | 2 +- .../ssi/lib/base/Base58BitcoinTest.java | 5 +++- 19 files changed, 51 insertions(+), 14 deletions(-) diff --git a/.gitignore b/.gitignore index 2e9cba3d..b1dd9bc7 100644 --- a/.gitignore +++ b/.gitignore @@ -4,6 +4,7 @@ target/ !**/src/main/**/target/ !**/src/test/**/target/ .DS_Store +.class ### STS ### .apt_generated diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.java index e99554e3..8118e6f9 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.java @@ -24,6 +24,8 @@ /** The type SSI exception. */ public class SSIException extends Exception { + private static final long serialVersionUID = -6426089110128695365L; + /** * Instantiates a new SSI exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java index 7213ea9e..4ea9eab7 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java @@ -22,21 +22,43 @@ package org.eclipse.tractusx.ssi.lib.exception.did; import org.eclipse.tractusx.ssi.lib.exception.SSIException; - +/** The type Did parse exception. */ public class DidParseException extends SSIException { + private static final long serialVersionUID = -8099856673022088164L; +/** + * Instantiates a new Did parse exception. + * + * @param message the message + */ public DidParseException(String did) { super(String.format("Invalid DID URL: %s, not able to parse it", did)); } - +/** + * Instantiates a new Did parse exception. + * + * @param message the message + * @param cause the cause + */ public DidParseException(String message, Throwable cause) { super(message, cause); } - + /** + * Instantiates a new Did parse exception. + * + * @param cause the cause + */ public DidParseException(Throwable cause) { super(cause); } - +/** + * Instantiates a new Did parse exception. + * + * @param message the message + * @param cause the cause + * @param enableSuppression the enable suppression + * @param writableStackTrace the writable stack trace + */ public DidParseException( String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { super(message, cause, enableSuppression, writableStackTrace); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/InvalidJsonLdException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/InvalidJsonLdException.java index ac3468e0..9b3f8d91 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/InvalidJsonLdException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/InvalidJsonLdException.java @@ -25,6 +25,7 @@ /** The type Invalid json ld exception. */ public class InvalidJsonLdException extends SSIException { + private static final long serialVersionUID = -6582674613332525307L; /** * Instantiates a new Invalid json ld exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java index 5d40b968..beefc88b 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java @@ -25,7 +25,8 @@ /** The type tranform json LD exception. */ public class TransformJsonLdException extends SSIException { - + + private static final long serialVersionUID = -1139580728763064789L; /** * Instantiates a new tranform json LD exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java index 03312c71..02b301cb 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java @@ -25,6 +25,7 @@ /** The type Invalide private key format. */ public class InvalidPrivateKeyFormatException extends SSIException { + private static final long serialVersionUID = -3348735256693555408L; /** * Instantiates a new Invalid private key format. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java index 17e25507..91650f6a 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java @@ -25,6 +25,7 @@ /** The type Invalid public key format. */ public class InvalidPublicKeyFormatException extends SSIException { + private static final long serialVersionUID = -8303592321627404757L; /** * Instantiates a new Invalide public key format. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java index aa570bde..8c6bf4cd 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java @@ -20,12 +20,13 @@ */ package org.eclipse.tractusx.ssi.lib.exception.key; - import org.eclipse.tractusx.ssi.lib.exception.SSIException; /** The type Key Generation Exception */ public class KeyGenerationException extends SSIException { + private static final long serialVersionUID = -6351788213852014647L; + /** * Instantiates a new key generation exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyTransformationException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyTransformationException.java index 7b7e14d4..a0b899cf 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyTransformationException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyTransformationException.java @@ -25,6 +25,7 @@ public class KeyTransformationException extends SSIException { + private static final long serialVersionUID = 7992457773475211865L; /** * Instantiates a new key trnasformation exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java index 12d0156f..9498059b 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java @@ -26,7 +26,7 @@ /** The type Jwt audience check failed exception. */ public class JwtAudienceCheckFailedException extends SSIException { - + private static final long serialVersionUID = -3258865938704740787L; /** * Instantiates a new Jwt audience check failed exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java index c6fcd278..d4d72acc 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java @@ -26,7 +26,7 @@ /** The type Jwt expired exception. */ public class JwtExpiredException extends SSIException { - +private static final long serialVersionUID = -1766884006095685877L; /** * Instantiates a new Jwt expired exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java index 02c97c26..25ff3abe 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java @@ -25,7 +25,7 @@ /** NoVerificationKeyFoundExcpetion */ public class NoVerificationKeyFoundException extends SSIException { - +private static final long serialVersionUID = -3859874631952203429L; public NoVerificationKeyFoundException(String message) { super(message); } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java index 3c88dbe1..d56bc48c 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java @@ -25,7 +25,7 @@ /** The type signature check failed exception. */ public class SignatureGenerateFailedException extends SSIException { - +private static final long serialVersionUID = -994642818493030478L; /** * Instantiates a new signature generate failed exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java index 6bca1ed6..a280bacf 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java @@ -25,7 +25,7 @@ /** The type signature parse exception. */ public class SignatureParseException extends SSIException { - +private static final long serialVersionUID = -3875927810143603019L; /** * Instantiates a new signature parse exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java index 9bee64c7..182a03fb 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java @@ -25,7 +25,7 @@ /** The type Signature Verification Failed exception. */ public class SignatureVerificationFailedException extends SSIException { - +private static final long serialVersionUID = 7515946489095871265L; /** * Instantiates a new signature verification failed exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java index 4e796701..5991115f 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java @@ -26,6 +26,7 @@ /** The type SSI did document resolver already registered exception. */ public class DidDocumentResolverAlreadyRegisteredException extends Exception { + private static final long serialVersionUID = 1101625710675168299L; /** * Instantiates a new did document resolver already registered exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java index 70139c41..a48a1187 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java @@ -26,6 +26,8 @@ /** The type Did document resolver not registered exception. */ public class DidDocumentResolverNotRegisteredException extends Exception { + + private static final long serialVersionUID = 1101625710675168299L; /** * Instantiates a new Did document resolver not registered exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java index 127f0787..c534d0e7 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java @@ -25,7 +25,7 @@ /** The type Did web exception. */ public class DidWebException extends SSIException { - +private static final long serialVersionUID = 1101625710675168299L; /** * Instantiates a new Did web exception. * diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/base/Base58BitcoinTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/base/Base58BitcoinTest.java index f6c2d017..1d12fa64 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/base/Base58BitcoinTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/base/Base58BitcoinTest.java @@ -21,13 +21,16 @@ package org.eclipse.tractusx.ssi.lib.base; +import java.io.Serializable; import java.nio.charset.StandardCharsets; import org.eclipse.tractusx.ssi.lib.model.base.Base58Bitcoin; import org.junit.jupiter.api.Assertions; import org.junit.jupiter.api.Test; /** The type Base 58 bitcoin test. */ -public class Base58BitcoinTest { +public class Base58BitcoinTest implements Serializable { + + static final long serialVersionUID = 6034044314589513430L; private static final byte[] DECODED = "Multibase is awesome! \\o/".getBytes(StandardCharsets.UTF_8); From da82f77d1210e9d4e1031b3962c695381c1f9548 Mon Sep 17 00:00:00 2001 From: Koptan Date: Mon, 15 Jan 2024 10:04:16 +0100 Subject: [PATCH 03/12] chore: Fixing code review --- .../tractusx/ssi/examples/ResolveDIDDoc.java | 7 +-- .../tractusx/ssi/examples/Validation.java | 10 ++-- .../tractusx/ssi/examples/Verification.java | 22 ++++---- .../ssi/lib/crypt/x21559/x21559Generator.java | 15 +---- .../did/resolver/CompositeDidResolver.java | 1 + .../ssi/lib/did/resolver/DidResolver.java | 1 + .../ssi/lib/did/resolver/DidUniResolver.java | 4 +- .../ssi/lib/did/web/DidWebResolver.java | 4 +- .../lib/exception/did/DidParseException.java | 17 +++--- .../DidResolverException.java} | 38 +++++-------- .../json/TransformJsonLdException.java | 2 +- .../key/InvalidPrivateKeyFormatException.java | 4 +- .../key/InvalidPublicKeyFormatException.java | 4 +- .../exception/key/KeyGenerationException.java | 1 + ...on.java => JwtAudienceCheckException.java} | 13 ++--- .../exception/proof/JwtExpiredException.java | 5 +- .../NoVerificationKeyFoundException.java | 7 +-- .../SignatureGenerateFailedException.java | 2 +- .../proof/SignatureParseException.java | 2 +- .../SignatureValidationException.java} | 24 ++++---- ...va => SignatureVerificationException.java} | 12 ++-- .../UnsupportedSignatureTypeException.java | 4 +- ...nsupportedVerificationMethodException.java | 3 +- ...ocumentResolverNotRegisteredException.java | 56 ------------------- .../ssi/lib/jwt/SignedJwtValidator.java | 6 +- .../ssi/lib/jwt/SignedJwtVerifier.java | 19 ++++--- .../tractusx/ssi/lib/proof/IVerifier.java | 10 ++-- .../lib/proof/LinkedDataProofValidation.java | 10 ++-- .../types/ed25519/Ed25519ProofVerifier.java | 11 ++-- .../lib/proof/types/jws/JWSProofVerifier.java | 14 ++--- .../lib/validation/JsonLdValidatorImpl.java | 11 ++-- .../resolver/CompositeDidResolverTest.java | 1 + .../lib/did/resolver/DidUniResolverIT.java | 5 +- .../ssi/lib/did/web/DidWebResolverTest.java | 2 +- 34 files changed, 129 insertions(+), 218 deletions(-) rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{resolver/DidDocumentResolverAlreadyRegisteredException.java => did/DidResolverException.java} (54%) rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/{JwtAudienceCheckFailedException.java => JwtAudienceCheckException.java} (78%) rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/{resolver/DidWebException.java => proof/SignatureValidationException.java} (71%) rename src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/{SignatureVerificationFailedException.java => SignatureVerificationException.java} (82%) delete mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java b/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java index 00cfa3cb..4f673fbb 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java @@ -22,13 +22,11 @@ package org.eclipse.tractusx.ssi.examples; import java.net.http.HttpClient; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.did.web.DidWebFactory; import org.eclipse.tractusx.ssi.lib.did.web.DidWebResolver; import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; -import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverAlreadyRegisteredException; -import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; @@ -43,8 +41,7 @@ public class ResolveDIDDoc { * exception */ public static DidDocument ResovleDocument(String didUrl) - throws DidDocumentResolverNotRegisteredException, - DidDocumentResolverAlreadyRegisteredException, DidParseException, DidResolverException { + throws DidParseException, DidResolverException { // DID Resolver Constracture params DidWebParser didParser = new DidWebParser(); diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/Validation.java b/src/main/java/org/eclipse/tractusx/ssi/examples/Validation.java index 0ba2b497..2dd7072e 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/Validation.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/Validation.java @@ -22,7 +22,7 @@ package org.eclipse.tractusx.ssi.examples; import com.nimbusds.jwt.SignedJWT; -import org.eclipse.tractusx.ssi.lib.exception.proof.JwtAudienceCheckFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.JwtAudienceCheckException; import org.eclipse.tractusx.ssi.lib.exception.proof.JwtExpiredException; import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; import org.eclipse.tractusx.ssi.lib.jwt.SignedJwtValidator; @@ -34,11 +34,11 @@ public class Validation { * * @param signedJWT the signed jwt * @param audience the audience - * @throws JwtAudienceCheckFailedException the jwt audience check failed exception + * @throws JwtAudienceCheckException the jwt audience check failed exception * @throws JwtExpiredException the jwt expired exception */ public static void validateJWTDate(SignedJWT signedJWT, String audience) - throws JwtAudienceCheckFailedException, JwtExpiredException, SignatureParseException { + throws JwtAudienceCheckException, JwtExpiredException, SignatureParseException { SignedJwtValidator jwtValidator = new SignedJwtValidator(); jwtValidator.validateDate(signedJWT); } @@ -48,11 +48,11 @@ public static void validateJWTDate(SignedJWT signedJWT, String audience) * * @param signedJWT the signed jwt * @param audience the audience - * @throws JwtAudienceCheckFailedException the jwt audience check failed exception + * @throws JwtAudienceCheckException the jwt audience check failed exception * @throws JwtExpiredException the jwt expired exception */ public static void validateJWTAudiences(SignedJWT signedJWT, String audience) - throws JwtAudienceCheckFailedException, JwtExpiredException, SignatureParseException { + throws JwtAudienceCheckException, JwtExpiredException, SignatureParseException { SignedJwtValidator jwtValidator = new SignedJwtValidator(); jwtValidator.validateAudiences(signedJWT, audience); } diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java b/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java index 846b0015..7d87273a 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java @@ -24,18 +24,17 @@ import com.nimbusds.jwt.SignedJWT; import java.net.http.HttpClient; import java.security.SignatureException; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.did.web.DidWebResolver; import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.exception.json.TransformJsonLdException; import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; -import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationException; import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedVerificationMethodException; -import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; import org.eclipse.tractusx.ssi.lib.jwt.SignedJwtVerifier; import org.eclipse.tractusx.ssi.lib.model.verifiable.credential.VerifiableCredential; import org.eclipse.tractusx.ssi.lib.proof.LinkedDataProofValidation; @@ -47,14 +46,15 @@ * @throws DidParseException * @throws SignatureException * @throws DidResolverException - * @throws SignatureVerificationFailedException + * @throws SignatureVerificationException * @throws UnsupportedVerificationMethodException */ public class Verification { public static void verifyJWT(SignedJWT jwt) throws DidParseException, SignatureException, DidResolverException, - SignatureVerificationFailedException, UnsupportedVerificationMethodException { + SignatureVerificationException, UnsupportedVerificationMethodException, + SignatureParseException { // DID Resolver constructor params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); @@ -74,7 +74,7 @@ public static void verifyJWT(SignedJWT jwt) * @throws DidDocumentResolverNotRegisteredException * @throws TransformJsonLdException * @throws NoVerificationKeyFoundException - * @throws SignatureVerificationFailedException + * @throws SignatureVerificationException * @throws InvalidPublicKeyFormatException * @throws DidParseException * @throws SignatureParseException @@ -82,9 +82,8 @@ public static void verifyJWT(SignedJWT jwt) */ public static boolean verifyED21559LD(VerifiableCredential verifiableCredential) throws UnsupportedSignatureTypeException, SignatureParseException, DidParseException, - InvalidPublicKeyFormatException, SignatureVerificationFailedException, - NoVerificationKeyFoundException, TransformJsonLdException, - DidDocumentResolverNotRegisteredException { + InvalidPublicKeyFormatException, SignatureVerificationException, + NoVerificationKeyFoundException, TransformJsonLdException { // DID Resolver constructor params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); @@ -97,9 +96,8 @@ public static boolean verifyED21559LD(VerifiableCredential verifiableCredential) public static boolean verifyJWSLD(VerifiableCredential verifiableCredential) throws UnsupportedSignatureTypeException, SignatureParseException, DidParseException, - InvalidPublicKeyFormatException, SignatureVerificationFailedException, - NoVerificationKeyFoundException, DidDocumentResolverNotRegisteredException, - TransformJsonLdException { + InvalidPublicKeyFormatException, SignatureVerificationException, + NoVerificationKeyFoundException, TransformJsonLdException { // DID Resolver constructor params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java index d0416108..7428488c 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java @@ -29,8 +29,6 @@ import org.bouncycastle.crypto.params.Ed25519PublicKeyParameters; import org.eclipse.tractusx.ssi.lib.crypt.IKeyGenerator; import org.eclipse.tractusx.ssi.lib.crypt.KeyPair; -import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPrivateKeyFormatException; -import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; import org.eclipse.tractusx.ssi.lib.exception.key.KeyGenerationException; /** X21559 key generator. */ @@ -49,17 +47,10 @@ public KeyPair generateKey() throws KeyGenerationException { Ed25519PublicKeyParameters publicKey = (Ed25519PublicKeyParameters) keyPair.getPublic(); x21559PrivateKey x21559PrivateKey; - try { - x21559PrivateKey = new x21559PrivateKey(privateKey.getEncoded()); - } catch (InvalidPrivateKeyFormatException e) { - throw new KeyGenerationException(e.getCause()); - } + x21559PrivateKey = new x21559PrivateKey(privateKey.getEncoded()); + x21559PublicKey x21559PublicKey; - try { - x21559PublicKey = new x21559PublicKey(publicKey.getEncoded()); - } catch (InvalidPublicKeyFormatException e) { - throw new KeyGenerationException(e.getCause()); - } + x21559PublicKey = new x21559PublicKey(publicKey.getEncoded()); return new KeyPair(x21559PublicKey, x21559PrivateKey); } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolver.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolver.java index cd7f2618..fc88aefa 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolver.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolver.java @@ -21,6 +21,7 @@ package org.eclipse.tractusx.ssi.lib.did.resolver; import java.util.Arrays; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolver.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolver.java index 68048e35..a86c10f9 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolver.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidResolver.java @@ -22,6 +22,7 @@ package org.eclipse.tractusx.ssi.lib.did.resolver; import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidUniResolver.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidUniResolver.java index d139dcbd..55174295 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidUniResolver.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidUniResolver.java @@ -27,6 +27,8 @@ import java.net.http.HttpClient; import java.net.http.HttpRequest; import java.net.http.HttpResponse; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; @@ -70,7 +72,7 @@ public DidUniResolver(HttpClient client, URI uniResolverEndpoint) } @Override - public DidDocument resolve(Did did) throws DidResolverException { + public DidDocument resolve(Did did) throws DidResolverException, DidParseException { URI requestUri = uniResolverEndpoint.resolve(uniResolverResolvePath).resolve("./" + did.toString()); final HttpRequest request = HttpRequest.newBuilder().uri(requestUri).GET().build(); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolver.java b/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolver.java index 998f0111..cb6f8326 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolver.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolver.java @@ -30,10 +30,10 @@ import java.util.Map; import lombok.RequiredArgsConstructor; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolver; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.did.web.util.Constants; import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; @@ -63,7 +63,6 @@ public DidDocument resolve(Did did) throws DidResolverException, DidParseExcepti final URI uri = parser.parse(did, enforceHttps); final HttpRequest request = HttpRequest.newBuilder().uri(uri).GET().build(); - try { final HttpResponse response = client.send(request, HttpResponse.BodyHandlers.ofString()); @@ -84,6 +83,7 @@ public DidDocument resolve(Did did) throws DidResolverException, DidParseExcepti final Map json = mapper.readValue(body, Map.class); return new DidDocument(json); + } catch (Exception e) { throw new DidResolverException( String.format("Unexpected exception: %s", e.getClass().getName()), e); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java index 4ea9eab7..4fdada59 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidParseException.java @@ -22,20 +22,21 @@ package org.eclipse.tractusx.ssi.lib.exception.did; import org.eclipse.tractusx.ssi.lib.exception.SSIException; -/** The type Did parse exception. */ + +/** The type Did parse exception. */ public class DidParseException extends SSIException { private static final long serialVersionUID = -8099856673022088164L; -/** - * Instantiates a new Did parse exception. + /** + * Instantiates a new Did parse exception. * * @param message the message */ public DidParseException(String did) { super(String.format("Invalid DID URL: %s, not able to parse it", did)); } -/** - * Instantiates a new Did parse exception. + /** + * Instantiates a new Did parse exception. * * @param message the message * @param cause the cause @@ -43,15 +44,15 @@ public DidParseException(String did) { public DidParseException(String message, Throwable cause) { super(message, cause); } - /** - * Instantiates a new Did parse exception. + /** + * Instantiates a new Did parse exception. * * @param cause the cause */ public DidParseException(Throwable cause) { super(cause); } -/** + /** * Instantiates a new Did parse exception. * * @param message the message diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidResolverException.java similarity index 54% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidResolverException.java index 5991115f..173b6db8 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverAlreadyRegisteredException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/did/DidResolverException.java @@ -19,61 +19,51 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception.resolver; +package org.eclipse.tractusx.ssi.lib.exception.did; -import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; +import org.eclipse.tractusx.ssi.lib.exception.SSIException; -/** The type SSI did document resolver already registered exception. */ -public class DidDocumentResolverAlreadyRegisteredException extends Exception { +/** The type Did resolver exception. */ +public class DidResolverException extends SSIException { - private static final long serialVersionUID = 1101625710675168299L; /** - * Instantiates a new did document resolver already registered exception. + * Instantiates a new Did resolver exception. * * @param message the message */ - public DidDocumentResolverAlreadyRegisteredException(DidMethod didMethod) { - super(String.format("No DID document resolver registered for DID method '%s'", didMethod)); - } - - /** - * Instantiates a new did document resolver already registered exception. - * - * @param message the message - * @param cause the cause - */ - public DidDocumentResolverAlreadyRegisteredException(String message) { + public DidResolverException(String message) { super(message); } /** - * Instantiates a new did document resolver already registered exception. + * Instantiates a new Did resolver exception from another exception with a message. * + * @param message the message * @param cause the cause */ - public DidDocumentResolverAlreadyRegisteredException(String message, Throwable cause) { + public DidResolverException(String message, Throwable cause) { super(message, cause); } /** - * Instantiates a new did document resolver already registered exception. + * Instantiates a new Did resolver exception from another exception. * - * @param message the message * @param cause the cause */ - public DidDocumentResolverAlreadyRegisteredException(Throwable cause) { + public DidResolverException(Throwable cause) { super(cause); } /** - * Instantiates a new did document resolver already registered exception. + * Instantiates a new Did resolver exception with a message from another exception, allowing for + * disabling and printing the stack trace. * * @param message the message * @param cause the cause * @param enableSuppression the enable suppression * @param writableStackTrace the writable stack trace */ - public DidDocumentResolverAlreadyRegisteredException( + public DidResolverException( String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { super(message, cause, enableSuppression, writableStackTrace); } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java index beefc88b..dd6b044d 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/json/TransformJsonLdException.java @@ -25,7 +25,7 @@ /** The type tranform json LD exception. */ public class TransformJsonLdException extends SSIException { - + private static final long serialVersionUID = -1139580728763064789L; /** * Instantiates a new tranform json LD exception. diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java index 02b301cb..f676441a 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPrivateKeyFormatException.java @@ -21,10 +21,8 @@ package org.eclipse.tractusx.ssi.lib.exception.key; -import org.eclipse.tractusx.ssi.lib.exception.SSIException; - /** The type Invalide private key format. */ -public class InvalidPrivateKeyFormatException extends SSIException { +public class InvalidPrivateKeyFormatException extends KeyGenerationException { private static final long serialVersionUID = -3348735256693555408L; /** * Instantiates a new Invalid private key format. diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java index 91650f6a..6a8950c5 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/InvalidPublicKeyFormatException.java @@ -21,10 +21,8 @@ package org.eclipse.tractusx.ssi.lib.exception.key; -import org.eclipse.tractusx.ssi.lib.exception.SSIException; - /** The type Invalid public key format. */ -public class InvalidPublicKeyFormatException extends SSIException { +public class InvalidPublicKeyFormatException extends KeyGenerationException { private static final long serialVersionUID = -8303592321627404757L; /** * Instantiates a new Invalide public key format. diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java index 8c6bf4cd..5724559f 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/key/KeyGenerationException.java @@ -20,6 +20,7 @@ */ package org.eclipse.tractusx.ssi.lib.exception.key; + import org.eclipse.tractusx.ssi.lib.exception.SSIException; /** The type Key Generation Exception */ diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckException.java similarity index 78% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckException.java index 9498059b..f3f21912 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckFailedException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtAudienceCheckException.java @@ -22,10 +22,9 @@ package org.eclipse.tractusx.ssi.lib.exception.proof; import java.util.List; -import org.eclipse.tractusx.ssi.lib.exception.SSIException; /** The type Jwt audience check failed exception. */ -public class JwtAudienceCheckFailedException extends SSIException { +public class JwtAudienceCheckException extends SignatureValidationException { private static final long serialVersionUID = -3258865938704740787L; /** * Instantiates a new Jwt audience check failed exception. @@ -33,7 +32,7 @@ public class JwtAudienceCheckFailedException extends SSIException { * @param expectedAudience the expected audience * @param actualAudience the actual audience */ - public JwtAudienceCheckFailedException(String expectedAudience, List actualAudience) { + public JwtAudienceCheckException(String expectedAudience, List actualAudience) { super( "JWT audience check failed. Expected audience: " + expectedAudience @@ -41,19 +40,19 @@ public JwtAudienceCheckFailedException(String expectedAudience, List act + String.join(", ", actualAudience)); } - public JwtAudienceCheckFailedException(String message) { + public JwtAudienceCheckException(String message) { super(message); } - public JwtAudienceCheckFailedException(String message, Throwable cause) { + public JwtAudienceCheckException(String message, Throwable cause) { super(message, cause); } - public JwtAudienceCheckFailedException(Throwable cause) { + public JwtAudienceCheckException(Throwable cause) { super(cause); } - public JwtAudienceCheckFailedException( + public JwtAudienceCheckException( String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { super(message, cause, enableSuppression, writableStackTrace); } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java index d4d72acc..2208a4c8 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/JwtExpiredException.java @@ -22,11 +22,10 @@ package org.eclipse.tractusx.ssi.lib.exception.proof; import java.util.Date; -import org.eclipse.tractusx.ssi.lib.exception.SSIException; /** The type Jwt expired exception. */ -public class JwtExpiredException extends SSIException { -private static final long serialVersionUID = -1766884006095685877L; +public class JwtExpiredException extends SignatureValidationException { + private static final long serialVersionUID = -1766884006095685877L; /** * Instantiates a new Jwt expired exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java index 25ff3abe..809bc8d9 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/NoVerificationKeyFoundException.java @@ -21,11 +21,10 @@ package org.eclipse.tractusx.ssi.lib.exception.proof; -import org.eclipse.tractusx.ssi.lib.exception.SSIException; - /** NoVerificationKeyFoundExcpetion */ -public class NoVerificationKeyFoundException extends SSIException { -private static final long serialVersionUID = -3859874631952203429L; +public class NoVerificationKeyFoundException extends SignatureVerificationException { + private static final long serialVersionUID = -3859874631952203429L; + public NoVerificationKeyFoundException(String message) { super(message); } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java index d56bc48c..d7fa3f25 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureGenerateFailedException.java @@ -25,7 +25,7 @@ /** The type signature check failed exception. */ public class SignatureGenerateFailedException extends SSIException { -private static final long serialVersionUID = -994642818493030478L; + private static final long serialVersionUID = -994642818493030478L; /** * Instantiates a new signature generate failed exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java index a280bacf..206befae 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureParseException.java @@ -25,7 +25,7 @@ /** The type signature parse exception. */ public class SignatureParseException extends SSIException { -private static final long serialVersionUID = -3875927810143603019L; + private static final long serialVersionUID = -3875927810143603019L; /** * Instantiates a new signature parse exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureValidationException.java similarity index 71% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureValidationException.java index c534d0e7..c4640511 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidWebException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureValidationException.java @@ -19,50 +19,50 @@ * ******************************************************************************* */ -package org.eclipse.tractusx.ssi.lib.exception.resolver; +package org.eclipse.tractusx.ssi.lib.exception.proof; import org.eclipse.tractusx.ssi.lib.exception.SSIException; -/** The type Did web exception. */ -public class DidWebException extends SSIException { -private static final long serialVersionUID = 1101625710675168299L; +/** The type Signature Validation exception. */ +public class SignatureValidationException extends SSIException { + /** - * Instantiates a new Did web exception. + * Instantiates a new signature verification exception. * * @param message the message */ - public DidWebException(String message) { + public SignatureValidationException(String message) { super(message); } /** - * Instantiates a new Did web exception. + * Instantiates a new signature validation exception. * * @param message the message * @param cause the cause */ - public DidWebException(String message, Throwable cause) { + protected SignatureValidationException(String message, Throwable cause) { super(message, cause); } /** - * Instantiates a new Did web exception. + * Instantiates a new signature verification exception. * * @param cause the cause */ - public DidWebException(Throwable cause) { + protected SignatureValidationException(Throwable cause) { super(cause); } /** - * Instantiates a new Did web exception. + * Instantiates a new signature verification exception. * * @param message the message * @param cause the cause * @param enableSuppression the enable suppression * @param writableStackTrace the writable stack trace */ - public DidWebException( + protected SignatureValidationException( String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { super(message, cause, enableSuppression, writableStackTrace); } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationException.java similarity index 82% rename from src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java rename to src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationException.java index 182a03fb..892e2357 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationFailedException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/SignatureVerificationException.java @@ -24,14 +24,14 @@ import org.eclipse.tractusx.ssi.lib.exception.SSIException; /** The type Signature Verification Failed exception. */ -public class SignatureVerificationFailedException extends SSIException { -private static final long serialVersionUID = 7515946489095871265L; +public class SignatureVerificationException extends SSIException { + /** * Instantiates a new signature verification failed exception. * * @param message the message */ - public SignatureVerificationFailedException(String message) { + public SignatureVerificationException(String message) { super(message); } @@ -41,7 +41,7 @@ public SignatureVerificationFailedException(String message) { * @param message the message * @param cause the cause */ - protected SignatureVerificationFailedException(String message, Throwable cause) { + protected SignatureVerificationException(String message, Throwable cause) { super(message, cause); } @@ -50,7 +50,7 @@ protected SignatureVerificationFailedException(String message, Throwable cause) * * @param cause the cause */ - protected SignatureVerificationFailedException(Throwable cause) { + protected SignatureVerificationException(Throwable cause) { super(cause); } @@ -62,7 +62,7 @@ protected SignatureVerificationFailedException(Throwable cause) { * @param enableSuppression the enable suppression * @param writableStackTrace the writable stack trace */ - protected SignatureVerificationFailedException( + protected SignatureVerificationException( String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { super(message, cause, enableSuppression, writableStackTrace); } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java index 4bc944ba..b5b966bb 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java @@ -21,10 +21,8 @@ package org.eclipse.tractusx.ssi.lib.exception.proof; -import org.eclipse.tractusx.ssi.lib.exception.SSIException; - /** The type Unsupported signature type exception. */ -public class UnsupportedSignatureTypeException extends SSIException { +public class UnsupportedSignatureTypeException extends SignatureVerificationException { /** * Instantiates a new unsupported signature type exception. diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java index 9781cac9..7b747d43 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java @@ -22,11 +22,10 @@ package org.eclipse.tractusx.ssi.lib.exception.proof; import lombok.Getter; -import org.eclipse.tractusx.ssi.lib.exception.SSIException; import org.eclipse.tractusx.ssi.lib.model.did.VerificationMethod; /** The type Unsupported verification method exception. */ -public class UnsupportedVerificationMethodException extends SSIException { +public class UnsupportedVerificationMethodException extends SignatureVerificationException { /** The verification method */ @Getter private final VerificationMethod method; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java deleted file mode 100644 index a48a1187..00000000 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/resolver/DidDocumentResolverNotRegisteredException.java +++ /dev/null @@ -1,56 +0,0 @@ -/* - * ****************************************************************************** - * Copyright (c) 2021,2023 Contributors to the Eclipse Foundation - * - * See the NOTICE file(s) distributed with this work for additional - * information regarding copyright ownership. - * - * This program and the accompanying materials are made available under the - * terms of the Apache License, Version 2.0 which is available at - * https://www.apache.org/licenses/LICENSE-2.0. - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT - * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the - * License for the specific language governing permissions and limitations - * under the License. - * - * SPDX-License-Identifier: Apache-2.0 - * ******************************************************************************* - */ - -package org.eclipse.tractusx.ssi.lib.exception.resolver; - -import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; - -/** The type Did document resolver not registered exception. */ -public class DidDocumentResolverNotRegisteredException extends Exception { - - - private static final long serialVersionUID = 1101625710675168299L; - /** - * Instantiates a new Did document resolver not registered exception. - * - * @param didMethod the did method - */ - public DidDocumentResolverNotRegisteredException(DidMethod didMethod) { - super(String.format("No DID document resolver registered for DID method '%s'", didMethod)); - } - - public DidDocumentResolverNotRegisteredException(String message) { - super(message); - } - - public DidDocumentResolverNotRegisteredException(String message, Throwable cause) { - super(message, cause); - } - - public DidDocumentResolverNotRegisteredException(Throwable cause) { - super(cause); - } - - public DidDocumentResolverNotRegisteredException( - String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { - super(message, cause, enableSuppression, writableStackTrace); - } -} diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java index d6f73973..4f22a752 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java @@ -25,7 +25,7 @@ import java.text.ParseException; import java.util.Date; import java.util.List; -import org.eclipse.tractusx.ssi.lib.exception.proof.JwtAudienceCheckFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.JwtAudienceCheckException; import org.eclipse.tractusx.ssi.lib.exception.proof.JwtExpiredException; import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; @@ -46,7 +46,7 @@ public void validateDate(SignedJWT jwt) throws JwtExpiredException, SignaturePar } public void validateAudiences(SignedJWT jwt, String expectedAudience) - throws JwtAudienceCheckFailedException, SignatureParseException { + throws JwtAudienceCheckException, SignatureParseException { List audiences; try { audiences = jwt.getJWTClaimsSet().getAudience(); @@ -55,7 +55,7 @@ public void validateAudiences(SignedJWT jwt, String expectedAudience) } boolean isValidAudience = audiences.stream().anyMatch(x -> x.equals(expectedAudience)); if (!isValidAudience) { - throw new JwtAudienceCheckFailedException(expectedAudience, audiences); + throw new JwtAudienceCheckException(expectedAudience, audiences); } } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java index 4bb33776..46ee3c69 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java @@ -28,15 +28,15 @@ import com.nimbusds.jose.util.Base64URL; import com.nimbusds.jwt.JWTClaimsSet; import com.nimbusds.jwt.SignedJWT; -import java.security.SignatureException; import java.text.ParseException; import java.util.List; import lombok.RequiredArgsConstructor; import org.bouncycastle.crypto.params.Ed25519PublicKeyParameters; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolver; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; -import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationException; import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedVerificationMethodException; import org.eclipse.tractusx.ssi.lib.model.MultibaseString; import org.eclipse.tractusx.ssi.lib.model.did.Did; @@ -63,18 +63,19 @@ public class SignedJwtVerifier { * @throws DidParseException * @throws SignatureException * @throws DidResolverException - * @throws SignatureVerificationFailedException + * @throws SignatureVerificationException * @throws UnsupportedVerificationMethodException + * @throws SignatureParseException */ public boolean verify(SignedJWT jwt) - throws DidParseException, SignatureException, DidResolverException, - SignatureVerificationFailedException, UnsupportedVerificationMethodException { + throws DidParseException, DidResolverException, SignatureVerificationException, + UnsupportedVerificationMethodException, SignatureParseException { JWTClaimsSet jwtClaimsSet; try { jwtClaimsSet = jwt.getJWTClaimsSet(); } catch (ParseException e) { - throw new SignatureException(e.getMessage()); + throw new SignatureParseException(e.getMessage()); } final String issuer = jwtClaimsSet.getIssuer(); @@ -100,7 +101,7 @@ public boolean verify(SignedJWT jwt) return true; } } catch (JOSEException e) { - throw new SignatureVerificationFailedException(e.getMessage()); + throw new SignatureVerificationException(e.getMessage()); } } else { throw new UnsupportedVerificationMethodException( @@ -121,7 +122,7 @@ public boolean verify(SignedJWT jwt) return true; } } catch (JOSEException e) { - throw new SignatureVerificationFailedException(e.getMessage()); + throw new SignatureVerificationException(e.getMessage()); } } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/IVerifier.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/IVerifier.java index b1512b75..640b2dee 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/IVerifier.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/IVerifier.java @@ -26,9 +26,8 @@ import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureGenerateFailedException; import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; -import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationException; import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; -import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable; import org.eclipse.tractusx.ssi.lib.model.verifiable.credential.VerifiableCredential; import org.eclipse.tractusx.ssi.lib.proof.hash.HashedLinkedData; @@ -46,13 +45,12 @@ public interface IVerifier { * @throws SignatureParseException * @throws InvalidPublicKeyFormatException * @throws SignatureGenerateFailedException - * @throws SignatureVerificationFailedException + * @throws SignatureVerificationException * @throws DidParseException - * @throws DidDocumentResolverNotRegisteredException * @throws NoVerificationKeyFoundException */ public boolean verify(HashedLinkedData hashedLinkedData, Verifiable verifiable) throws SignatureParseException, DidParseException, InvalidPublicKeyFormatException, - SignatureVerificationFailedException, UnsupportedSignatureTypeException, - NoVerificationKeyFoundException, DidDocumentResolverNotRegisteredException; + SignatureVerificationException, UnsupportedSignatureTypeException, + NoVerificationKeyFoundException; } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java index 2c9ff6fa..d312703d 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java @@ -31,9 +31,8 @@ import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; -import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationException; import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; -import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable.VerifiableType; import org.eclipse.tractusx.ssi.lib.model.verifiable.credential.VerifiableCredential; @@ -86,7 +85,7 @@ public static LinkedDataProofValidation newInstance(DidResolver didResolver) { * @throws UnsupportedSignatureTypeException * @throws DidDocumentResolverNotRegisteredException * @throws NoVerificationKeyFoundException - * @throws SignatureVerificationFailedException + * @throws SignatureVerificationException * @throws InvalidPublicKeyFormatException * @throws DidParseException * @throws SignatureParseException @@ -94,9 +93,8 @@ public static LinkedDataProofValidation newInstance(DidResolver didResolver) { */ public boolean verify(Verifiable verifiable) throws UnsupportedSignatureTypeException, SignatureParseException, DidParseException, - InvalidPublicKeyFormatException, SignatureVerificationFailedException, - NoVerificationKeyFoundException, DidDocumentResolverNotRegisteredException, - TransformJsonLdException { + InvalidPublicKeyFormatException, SignatureVerificationException, + NoVerificationKeyFoundException, TransformJsonLdException { var type = verifiable.getProof().getType(); IVerifier verifier = null; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofVerifier.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofVerifier.java index 5936161a..716b9ae6 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofVerifier.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/ed25519/Ed25519ProofVerifier.java @@ -31,12 +31,11 @@ import org.eclipse.tractusx.ssi.lib.crypt.IPublicKey; import org.eclipse.tractusx.ssi.lib.crypt.x21559.x21559PublicKey; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolver; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; -import org.eclipse.tractusx.ssi.lib.exception.resolver.DidDocumentResolverNotRegisteredException; import org.eclipse.tractusx.ssi.lib.model.MultibaseString; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; @@ -57,8 +56,7 @@ public class Ed25519ProofVerifier implements IVerifier { @SneakyThrows({DidResolverException.class}) public boolean verify(HashedLinkedData hashedLinkedData, Verifiable verifiable) throws UnsupportedSignatureTypeException, InvalidPublicKeyFormatException, - NoVerificationKeyFoundException, DidParseException, - DidDocumentResolverNotRegisteredException { + NoVerificationKeyFoundException, DidParseException { final Proof proof = verifiable.getProof(); final Ed25519Signature2020 ed25519Signature2020 = new Ed25519Signature2020(proof); @@ -75,9 +73,8 @@ public boolean verify(HashedLinkedData hashedLinkedData, Verifiable verifiable) } private IPublicKey discoverPublicKey(Ed25519Signature2020 signature) - throws DidDocumentResolverNotRegisteredException, UnsupportedSignatureTypeException, - InvalidPublicKeyFormatException, NoVerificationKeyFoundException, DidResolverException, - DidParseException { + throws UnsupportedSignatureTypeException, InvalidPublicKeyFormatException, + NoVerificationKeyFoundException, DidResolverException, DidParseException { final Did issuer = DidParser.parse(signature.getVerificationMethod()); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofVerifier.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofVerifier.java index 7888c294..de3a617e 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofVerifier.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/types/jws/JWSProofVerifier.java @@ -35,12 +35,12 @@ import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.crypt.IPublicKey; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolver; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; -import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; import org.eclipse.tractusx.ssi.lib.model.did.DidParser; @@ -60,7 +60,7 @@ public class JWSProofVerifier implements IVerifier { @SneakyThrows({DidResolverException.class}) public boolean verify(HashedLinkedData hashedLinkedData, Verifiable document) throws SignatureParseException, DidParseException, InvalidPublicKeyFormatException, - SignatureVerificationFailedException { + SignatureVerificationException { final Proof proof = document.getProof(); if (!proof.getType().equals(JWSSignature2020.JWS_VERIFICATION_KEY_2020)) { @@ -97,7 +97,7 @@ public boolean verify(HashedLinkedData hashedLinkedData, Verifiable document) try { return jws.verify(verifier); } catch (JOSEException e) { - throw new SignatureVerificationFailedException(e.getMessage()); + throw new SignatureVerificationException(e.getMessage()); } } @@ -136,11 +136,11 @@ private OctetKeyPair discoverOctectKey(JWSSignature2020 signature) * @param publicKey the public key * @return the boolean * @throws SignatureParseException - * @throws SignatureVerificationFailedException + * @throws SignatureVerificationException * @throws InvalidPublicKeyFormatException */ public boolean verify(HashedLinkedData hashedLinkedData, byte[] signature, IPublicKey publicKey) - throws SignatureParseException, SignatureVerificationFailedException, + throws SignatureParseException, SignatureVerificationException, InvalidPublicKeyFormatException { var keyPair = @@ -162,7 +162,7 @@ public boolean verify(HashedLinkedData hashedLinkedData, byte[] signature, IPubl try { return jws.verify(verifier); } catch (JOSEException e) { - throw new SignatureVerificationFailedException(e.getMessage()); + throw new SignatureVerificationException(e.getMessage()); } } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java index c8a75cd2..db8420ed 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java @@ -82,14 +82,11 @@ private void validateJsonLd(JsonLdObject jsonLdObject) throws InvalidJsonLdExcep findUndefinedTerms(jsonObject); } catch (JsonLdError ex) { - throw new InvalidJsonLdException( - String.format( - "Json LD validation failed for json: %s", jsonLdObject.toJsonObject().toString()), - ex); + throw new InvalidJsonLdException(ex.getCode().toMessage()); } } - private static void findUndefinedTerms(JsonArray jsonArray) { + private static void findUndefinedTerms(JsonArray jsonArray) throws InvalidJsonLdException { for (JsonValue entry : jsonArray) { if (entry instanceof JsonObject) { findUndefinedTerms((JsonObject) entry); @@ -97,11 +94,11 @@ private static void findUndefinedTerms(JsonArray jsonArray) { } } - private static void findUndefinedTerms(JsonObject jsonObject) { + private static void findUndefinedTerms(JsonObject jsonObject) throws InvalidJsonLdException { for (Map.Entry entry : jsonObject.entrySet()) { if (entry.getKey().startsWith(UNDEFINED_TERM_URI)) { - throw new RuntimeException( + throw new InvalidJsonLdException( "Undefined JSON-LD term: " + entry.getKey().substring(UNDEFINED_TERM_URI.length())); } diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolverTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolverTest.java index 83afa40c..8a5c471c 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolverTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/CompositeDidResolverTest.java @@ -34,6 +34,7 @@ import static org.mockito.Mockito.when; import lombok.SneakyThrows; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidUniResolverIT.java b/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidUniResolverIT.java index 6b0495a2..5e3bc595 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidUniResolverIT.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/did/resolver/DidUniResolverIT.java @@ -27,6 +27,8 @@ import java.net.MalformedURLException; import java.net.URISyntaxException; import java.net.http.HttpClient; +import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; @@ -84,9 +86,10 @@ public void initEach() throws MalformedURLException, URISyntaxException { * Should resolve valid did. * * @throws DidResolverException the did resolver exception + * @throws DidParseException */ @Test - public void shouldResolveValidDid() throws DidResolverException { + public void shouldResolveValidDid() throws DidResolverException, DidParseException { Did validDidWeb = new Did( new DidMethod("key"), diff --git a/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverTest.java b/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverTest.java index 9a2f91a2..a04e70fe 100644 --- a/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverTest.java +++ b/src/test/java/org/eclipse/tractusx/ssi/lib/did/web/DidWebResolverTest.java @@ -33,8 +33,8 @@ import java.net.http.HttpClient; import java.net.http.HttpResponse; import lombok.SneakyThrows; -import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException; import org.eclipse.tractusx.ssi.lib.did.web.util.DidWebParser; +import org.eclipse.tractusx.ssi.lib.exception.did.DidResolverException; import org.eclipse.tractusx.ssi.lib.model.did.Did; import org.eclipse.tractusx.ssi.lib.model.did.DidDocument; import org.eclipse.tractusx.ssi.lib.model.did.DidMethod; From ce0109fa749ed0c78f6878d206ae05b1455c2377 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B6rn=20Arnold?= Date: Fri, 3 Nov 2023 11:43:28 +0100 Subject: [PATCH 04/12] Fix: Removed duplicate JsonLdValidator classes --- .../lib/proof/LinkedDataProofValidation.java | 33 ++++------- .../lib/validation/JsonLdValidatorImpl.java | 58 ++++++++++--------- 2 files changed, 41 insertions(+), 50 deletions(-) diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java index d312703d..7c57c066 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java @@ -24,14 +24,9 @@ import java.util.logging.Logger; import lombok.AccessLevel; import lombok.RequiredArgsConstructor; +import lombok.SneakyThrows; import org.eclipse.tractusx.ssi.lib.did.resolver.DidResolver; -import org.eclipse.tractusx.ssi.lib.exception.did.DidParseException; import org.eclipse.tractusx.ssi.lib.exception.json.InvalidJsonLdException; -import org.eclipse.tractusx.ssi.lib.exception.json.TransformJsonLdException; -import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; -import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; -import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; -import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationException; import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable; import org.eclipse.tractusx.ssi.lib.model.verifiable.Verifiable.VerifiableType; @@ -82,20 +77,12 @@ public static LinkedDataProofValidation newInstance(DidResolver didResolver) { * * @param verifiable the verifiable * @return the boolean - * @throws UnsupportedSignatureTypeException - * @throws DidDocumentResolverNotRegisteredException - * @throws NoVerificationKeyFoundException - * @throws SignatureVerificationException - * @throws InvalidPublicKeyFormatException - * @throws DidParseException - * @throws SignatureParseException - * @throws TransformJsonLdException */ - public boolean verify(Verifiable verifiable) - throws UnsupportedSignatureTypeException, SignatureParseException, DidParseException, - InvalidPublicKeyFormatException, SignatureVerificationException, - NoVerificationKeyFoundException, TransformJsonLdException { - + @SneakyThrows + public boolean verify(Verifiable verifiable) { + if (verifiable.getProof() == null) { + throw new UnsupportedSignatureTypeException("Proof can't be empty"); + } var type = verifiable.getProof().getType(); IVerifier verifier = null; @@ -132,8 +119,8 @@ public boolean verify(Verifiable verifiable) * @return * @throws UnsupportedSignatureTypeException */ - private Boolean validateVerificationMethodOfVC(Verifiable verifiable) - throws UnsupportedSignatureTypeException { + @SneakyThrows + private Boolean validateVerificationMethodOfVC(Verifiable verifiable) { // Verifiable Presentation doesn't have an Issuer if (verifiable.getType() == VerifiableType.VP) { return true; @@ -152,8 +139,8 @@ private Boolean validateVerificationMethodOfVC(Verifiable verifiable) * @return * @throws UnsupportedSignatureTypeException */ - private String getVerificationMethod(Verifiable verifiable) - throws UnsupportedSignatureTypeException { + @SneakyThrows + private String getVerificationMethod(Verifiable verifiable) { try { return (String) verifiable.getProof().get("verificationMethod"); } catch (Exception e) { diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java index db8420ed..cc4ff4b8 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java @@ -41,8 +41,8 @@ /** The type Json ld validator. */ public class JsonLdValidatorImpl implements JsonLdValidator { - static final Logger LOG = Logger.getLogger(JsonLdValidatorImpl.class.getName()); private static final String UNDEFINED_TERM_URI = "urn:UNDEFINEDTERM"; + static final Logger LOG = Logger.getLogger(JsonLdValidatorImpl.class.getName()); public void validate(Verifiable verifiable) throws InvalidJsonLdException { if (verifiable instanceof VerifiableCredential) { @@ -60,32 +60,6 @@ public void validate(Verifiable verifiable) throws InvalidJsonLdException { } } - private void validateJsonLd(JsonLdObject jsonLdObject) throws InvalidJsonLdException { - try { - - var documentLoader = RemoteDocumentLoader.getInstance(); - documentLoader.setEnableHttps(true); - documentLoader.setHttpsContexts(jsonLdObject.getContext()); - - final JsonObject expandContext = - Json.createObjectBuilder().add("@vocab", Json.createValue(UNDEFINED_TERM_URI)).build(); - - final JsonDocument jsonDocument = - JsonDocument.of(MediaType.JSON_LD, jsonLdObject.toJsonObject()); - - final JsonLdOptions jsonLdOptions = new JsonLdOptions(); - jsonLdOptions.setDocumentLoader(documentLoader); - jsonLdOptions.setExpandContext(expandContext); - - final JsonArray jsonArray = ExpansionProcessor.expand(jsonDocument, jsonLdOptions, false); - JsonObject jsonObject = jsonArray.getJsonObject(0); - - findUndefinedTerms(jsonObject); - } catch (JsonLdError ex) { - throw new InvalidJsonLdException(ex.getCode().toMessage()); - } - } - private static void findUndefinedTerms(JsonArray jsonArray) throws InvalidJsonLdException { for (JsonValue entry : jsonArray) { if (entry instanceof JsonObject) { @@ -110,4 +84,34 @@ private static void findUndefinedTerms(JsonObject jsonObject) throws InvalidJson } } } + + private void validateJsonLd(JsonLdObject jsonLdObject) throws InvalidJsonLdException { + try { + + var documentLoader = RemoteDocumentLoader.getInstance(); + documentLoader.setEnableHttps(true); + documentLoader.setHttpsContexts(jsonLdObject.getContext()); + documentLoader.setEnableFile(true); + + final JsonObject expandContext = + Json.createObjectBuilder().add("@vocab", Json.createValue(UNDEFINED_TERM_URI)).build(); + + final JsonDocument jsonDocument = + JsonDocument.of(MediaType.JSON_LD, jsonLdObject.toJsonObject()); + + final JsonLdOptions jsonLdOptions = new JsonLdOptions(); + jsonLdOptions.setDocumentLoader(documentLoader); + jsonLdOptions.setExpandContext(expandContext); + + final JsonArray jsonArray = ExpansionProcessor.expand(jsonDocument, jsonLdOptions, false); + JsonObject jsonObject = jsonArray.getJsonObject(0); + + findUndefinedTerms(jsonObject); + } catch (JsonLdError ex) { + throw new InvalidJsonLdException( + String.format( + "Json LD validation failed for json: %s", jsonLdObject.toJsonObject().toString()), + ex); + } + } } From fd5fbb0ddcccee4d34f66b7795fe08681c5c1bfd Mon Sep 17 00:00:00 2001 From: Koptan Date: Fri, 19 Jan 2024 08:37:00 +0100 Subject: [PATCH 05/12] fix: Throw exception and log in validation step --- .../lib/proof/LinkedDataProofValidation.java | 2 ++ .../lib/validation/JsonLdValidatorImpl.java | 35 ++++++++++--------- 2 files changed, 20 insertions(+), 17 deletions(-) diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java index 7c57c066..cf296555 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/proof/LinkedDataProofValidation.java @@ -22,6 +22,8 @@ package org.eclipse.tractusx.ssi.lib.proof; import java.util.logging.Logger; +// import org.eclipse.tractusx.ssi.lib.serialization.jsonLd.JsonLdValidator; +// import org.eclipse.tractusx.ssi.lib.serialization.jsonLd.JsonLdValidatorImpl; import lombok.AccessLevel; import lombok.RequiredArgsConstructor; import lombok.SneakyThrows; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java index cc4ff4b8..e32c36c1 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/validation/JsonLdValidatorImpl.java @@ -41,24 +41,8 @@ /** The type Json ld validator. */ public class JsonLdValidatorImpl implements JsonLdValidator { - private static final String UNDEFINED_TERM_URI = "urn:UNDEFINEDTERM"; static final Logger LOG = Logger.getLogger(JsonLdValidatorImpl.class.getName()); - - public void validate(Verifiable verifiable) throws InvalidJsonLdException { - if (verifiable instanceof VerifiableCredential) { - validateJsonLd(verifiable); - } else if (verifiable instanceof VerifiablePresentation) { - VerifiablePresentation verifiablePresentation = (VerifiablePresentation) verifiable; - for (VerifiableCredential verifiableCredential : - verifiablePresentation.getVerifiableCredentials()) { - validate(verifiableCredential); - } - } else { - LOG.warning("Unsupported Verifiable type: " + verifiable.getClass().getName()); - throw new InvalidJsonLdException( - String.format("Unsupported Verifiable type: %s", verifiable.getClass().getName())); - } - } + private static final String UNDEFINED_TERM_URI = "urn:UNDEFINEDTERM"; private static void findUndefinedTerms(JsonArray jsonArray) throws InvalidJsonLdException { for (JsonValue entry : jsonArray) { @@ -114,4 +98,21 @@ private void validateJsonLd(JsonLdObject jsonLdObject) throws InvalidJsonLdExcep ex); } } + + public void validate(Verifiable verifiable) throws InvalidJsonLdException { + if (verifiable instanceof VerifiableCredential) { + validateJsonLd(verifiable); + } else if (verifiable instanceof VerifiablePresentation) { + VerifiablePresentation verifiablePresentation = (VerifiablePresentation) verifiable; + for (VerifiableCredential verifiableCredential : + verifiablePresentation.getVerifiableCredentials()) { + validate(verifiableCredential); + } + } else { + LOG.warning("Unsupported Verifiable type: " + verifiable.getClass().getName()); + throw new InvalidJsonLdException( + String.format( + "Verifiable type %s is not supported", verifiable.getClass().getSimpleName())); + } + } } From 9d6053aeebaed5dfd18bb43223827733ee2b0188 Mon Sep 17 00:00:00 2001 From: Koptan Date: Tue, 7 Nov 2023 12:11:01 +0100 Subject: [PATCH 06/12] feat: new Exception system BREAKING CHANGE: a lot of Exception has been added and removed --- .../tractusx/ssi/examples/ResolveDIDDoc.java | 1 + .../tractusx/ssi/examples/Verification.java | 8 ++++-- .../ssi/lib/crypt/x21559/x21559Generator.java | 15 +++++++++--- .../ssi/lib/exception/SSIException.class | Bin 0 -> 561 bytes .../ssi/lib/exception/SSIException.java | 2 -- ...SignatureVerificationFailedException.java} | 23 +++++++++--------- .../UnsupportedSignatureTypeException.class | Bin 0 -> 1121 bytes .../UnsupportedSignatureTypeException.java | 2 ++ ...nsupportedVerificationMethodException.java | 2 ++ .../ssi/lib/jwt/SignedJwtValidator.java | 2 +- .../ssi/lib/jwt/SignedJwtVerifier.java | 1 + 11 files changed, 36 insertions(+), 20 deletions(-) create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.class rename src/main/java/org/eclipse/tractusx/ssi/lib/{did/resolver/DidResolverException.java => exception/proof/SignatureVerificationFailedException.java} (69%) create mode 100644 src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.class diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java b/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java index 4f673fbb..0f0d8dd5 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/ResolveDIDDoc.java @@ -37,6 +37,7 @@ public class ResolveDIDDoc { * * @param didUrl the did url * @return the did document + * @throws org.eclipse.tractusx.ssi.lib.did.resolver.DidResolverException * @throws DidDocumentResolverNotRegisteredException the did document resolver not registered * exception */ diff --git a/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java b/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java index 7d87273a..f3818c6d 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java +++ b/src/main/java/org/eclipse/tractusx/ssi/examples/Verification.java @@ -33,6 +33,7 @@ import org.eclipse.tractusx.ssi.lib.exception.proof.NoVerificationKeyFoundException; import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureParseException; import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationException; +import org.eclipse.tractusx.ssi.lib.exception.proof.SignatureVerificationFailedException; import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedSignatureTypeException; import org.eclipse.tractusx.ssi.lib.exception.proof.UnsupportedVerificationMethodException; import org.eclipse.tractusx.ssi.lib.jwt.SignedJwtVerifier; @@ -79,11 +80,13 @@ public static void verifyJWT(SignedJWT jwt) * @throws DidParseException * @throws SignatureParseException * @throws UnsupportedSignatureTypeException + * @throws SignatureVerificationFailedException */ public static boolean verifyED21559LD(VerifiableCredential verifiableCredential) throws UnsupportedSignatureTypeException, SignatureParseException, DidParseException, InvalidPublicKeyFormatException, SignatureVerificationException, - NoVerificationKeyFoundException, TransformJsonLdException { + NoVerificationKeyFoundException, TransformJsonLdException, + SignatureVerificationFailedException { // DID Resolver constructor params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); @@ -97,7 +100,8 @@ public static boolean verifyED21559LD(VerifiableCredential verifiableCredential) public static boolean verifyJWSLD(VerifiableCredential verifiableCredential) throws UnsupportedSignatureTypeException, SignatureParseException, DidParseException, InvalidPublicKeyFormatException, SignatureVerificationException, - NoVerificationKeyFoundException, TransformJsonLdException { + NoVerificationKeyFoundException, TransformJsonLdException, + SignatureVerificationFailedException { // DID Resolver constructor params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java index 7428488c..d0416108 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/crypt/x21559/x21559Generator.java @@ -29,6 +29,8 @@ import org.bouncycastle.crypto.params.Ed25519PublicKeyParameters; import org.eclipse.tractusx.ssi.lib.crypt.IKeyGenerator; import org.eclipse.tractusx.ssi.lib.crypt.KeyPair; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPrivateKeyFormatException; +import org.eclipse.tractusx.ssi.lib.exception.key.InvalidPublicKeyFormatException; import org.eclipse.tractusx.ssi.lib.exception.key.KeyGenerationException; /** X21559 key generator. */ @@ -47,10 +49,17 @@ public KeyPair generateKey() throws KeyGenerationException { Ed25519PublicKeyParameters publicKey = (Ed25519PublicKeyParameters) keyPair.getPublic(); x21559PrivateKey x21559PrivateKey; - x21559PrivateKey = new x21559PrivateKey(privateKey.getEncoded()); - + try { + x21559PrivateKey = new x21559PrivateKey(privateKey.getEncoded()); + } catch (InvalidPrivateKeyFormatException e) { + throw new KeyGenerationException(e.getCause()); + } x21559PublicKey x21559PublicKey; - x21559PublicKey = new x21559PublicKey(publicKey.getEncoded()); + try { + x21559PublicKey = new x21559PublicKey(publicKey.getEncoded()); + } catch (InvalidPublicKeyFormatException e) { + throw new KeyGenerationException(e.getCause()); + } return new KeyPair(x21559PublicKey, x21559PrivateKey); } } diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.class b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/SSIException.class new file mode 100644 index 0000000000000000000000000000000000000000..0fad65c92a91357e57e275f05d7a5063f079dd71 GIT binary patch literal 561 zcmZvY%}T>S6ot>UX=7_OR*krEp@P^nI16><52z>z#Z5{V-6e5|Q({t*RQp=40xo<2 zA4LmVz8DFCC%_9iQio>6oqV6$vO2>lP8-mzzMVs_3i@PhF9e-s4cb-yjI7TWyixE+RB5OIsKK78Vs7xNx_F!Oz>&jj%8q(+3ZXa{>0z# zsR<8$fFEVN(=Kr-jk=qinLBgNy>srp`}5c34*;)Fo}np`#RQTJ_fNeOUQ@E|nNPwT z(MlUn8qHAJs2_W0p6h$E>o!a%WVc$rxs^d0j)Tc8ZXv_)RE1raw|x<4?wZhRo1Q** zwHB@~S}s3t^S}rt-9}^g-Ic+Rekr6duNmgX1wF7avNpgpLuCvicB|%5sJ?nFpI6HR zTF%n)4D)f?C}_rlW*N5Pph)sq--n0g0|#>q`~N972$lNcew4Zw1S&MV(-2+hnO?}7 z7XgoDB3V-%&XB7M$@hDwEgm+l8iq_m^};sa5!NXE)6=%C9Yg+&Qbto9f<11IR7dC1 zc$C2+mK;2`El^-6{wcGNXX=DU)gE@m4wX=a7YyIx$%%kNr|&)4@wqP6l{)DK)mX-E z=I|QPY99mt9P{v@bmgyGdmtS~IbGE&f2$t@U)@S?yNvb$39u;zPO zbM0V_VeN+OacUf_Gc5fbO8q;Oj%D1XR<%zO%>EEG-Xm)r33`F4%H}0)p^wyeGU@lD zF*7(?rMWmDO-H0vD$fL+JC)6?KBh(qPbkv%fRK*}D^ZkmWwVdlqxfe?;rReR8{tc| sld>0}0E=_UKJJWiYNX*UU1FY42`u0N&6C7_NZ&G6EtghBl(2z?-@z0lcK`qY literal 0 HcmV?d00001 diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java index b5b966bb..a63b7241 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedSignatureTypeException.java @@ -24,6 +24,8 @@ /** The type Unsupported signature type exception. */ public class UnsupportedSignatureTypeException extends SignatureVerificationException { + private static final long serialVersionUID = 6406987797507777929L; + /** * Instantiates a new unsupported signature type exception. * diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java index 7b747d43..04f81b7a 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/exception/proof/UnsupportedVerificationMethodException.java @@ -27,6 +27,8 @@ /** The type Unsupported verification method exception. */ public class UnsupportedVerificationMethodException extends SignatureVerificationException { + private static final long serialVersionUID = 6406987797507777929L; + /** The verification method */ @Getter private final VerificationMethod method; diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java index 4f22a752..9cae9c47 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtValidator.java @@ -46,7 +46,7 @@ public void validateDate(SignedJWT jwt) throws JwtExpiredException, SignaturePar } public void validateAudiences(SignedJWT jwt, String expectedAudience) - throws JwtAudienceCheckException, SignatureParseException { + throws SignatureParseException, JwtAudienceCheckException { List audiences; try { audiences = jwt.getJWTClaimsSet().getAudience(); diff --git a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java index 46ee3c69..715ead43 100644 --- a/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java +++ b/src/main/java/org/eclipse/tractusx/ssi/lib/jwt/SignedJwtVerifier.java @@ -28,6 +28,7 @@ import com.nimbusds.jose.util.Base64URL; import com.nimbusds.jwt.JWTClaimsSet; import com.nimbusds.jwt.SignedJWT; +import java.security.SignatureException; import java.text.ParseException; import java.util.List; import lombok.RequiredArgsConstructor; From 74aeffa4fb85cb5a971eb7397ec022870cf56c27 Mon Sep 17 00:00:00 2001 From: Koptan Date: Thu, 1 Feb 2024 10:35:16 +0100 Subject: [PATCH 07/12] Fix: Resolving comment review --- .github/workflows/build.yaml | 2 +- .github/workflows/publish-maven.yaml | 2 +- .github/workflows/publish-snapshot-maven.yaml | 2 +- docs/NOTICE.md | 2 +- docs/README.md | 10 +++--- docs/scripts/generateDoc.sh | 2 +- docs/scripts/generateImages.sh | 2 +- pom.xml | 2 +- settings.xml | 2 +- ...BuildDIDDocEd25519VerificationKey2020.java | 6 ++-- .../examples/BuildDIDDocJsonWebKey2020.java | 10 +++--- .../tractusx/ssi/examples/ResolveDIDDoc.java | 2 +- .../org/eclipse/tractusx/ssi/examples/VC.java | 10 +++--- .../org/eclipse/tractusx/ssi/examples/VP.java | 2 +- .../tractusx/ssi/examples/Validation.java | 2 +- .../tractusx/ssi/examples/Verification.java | 6 ++-- .../eclipse/tractusx/ssi/lib/SsiLibrary.java | 2 +- .../eclipse/tractusx/ssi/lib/crypt/IKey.java | 2 +- .../tractusx/ssi/lib/crypt/IKeyGenerator.java | 2 +- .../tractusx/ssi/lib/crypt/IPrivateKey.java | 2 +- .../tractusx/ssi/lib/crypt/IPublicKey.java | 2 +- .../tractusx/ssi/lib/crypt/KeyPair.java | 2 +- .../ssi/lib/crypt/jwk/JsonWebKey.java | 2 +- .../lib/crypt/octet/OctetKeyPairFactory.java | 2 +- .../x25519Generator.java} | 18 +++++----- .../x25519PrivateKey.java} | 18 +++++----- .../x25519PublicKey.java} | 18 +++++----- .../did/resolver/CompositeDidResolver.java | 2 +- .../lib/did/resolver/DidDocumentResolver.java | 2 +- .../ssi/lib/did/resolver/DidResolver.java | 2 +- .../ssi/lib/did/resolver/DidUniResolver.java | 2 +- .../ssi/lib/did/web/DidWebFactory.java | 2 +- .../ssi/lib/did/web/DidWebResolver.java | 2 +- .../ssi/lib/did/web/util/Constants.java | 2 +- .../ssi/lib/did/web/util/DidWebParser.java | 2 +- .../did/web/util/Ed25519PublicKeyParser.java | 2 +- .../ssi/lib/exception/SSIException.java | 2 +- .../lib/exception/did/DidParseException.java | 3 +- .../exception/did/DidResolverException.java | 2 +- .../json/InvalidJsonLdException.java | 2 +- .../json/TransformJsonLdException.java | 2 +- .../key/InvalidPrivateKeyFormatException.java | 2 +- .../key/InvalidPublicKeyFormatException.java | 2 +- .../exception/key/KeyGenerationException.java | 2 +- .../key/KeyTransformationException.java | 2 +- .../proof/JwtAudienceCheckException.java | 2 +- .../exception/proof/JwtExpiredException.java | 2 +- .../NoVerificationKeyFoundException.java | 2 +- .../SignatureGenerateFailedException.java | 2 +- .../proof/SignatureParseException.java | 2 +- .../proof/SignatureValidationException.java | 2 +- .../proof/SignatureVerificationException.java | 2 +- .../SignatureVerificationFailedException.java | 2 +- .../UnsupportedSignatureTypeException.java | 2 +- ...nsupportedVerificationMethodException.java | 2 +- .../ssi/lib/jwt/SignedJwtFactory.java | 2 +- .../ssi/lib/jwt/SignedJwtValidator.java | 2 +- .../ssi/lib/jwt/SignedJwtVerifier.java | 2 +- .../tractusx/ssi/lib/jwt/SigningMethod.java | 2 +- .../tractusx/ssi/lib/model/JsonLdObject.java | 2 +- .../ssi/lib/model/MultibaseString.java | 2 +- .../ssi/lib/model/RemoteDocumentLoader.java | 2 +- .../ssi/lib/model/base/Base58Bitcoin.java | 2 +- .../ssi/lib/model/base/Base58Flickr.java | 2 +- .../tractusx/ssi/lib/model/base/Base64.java | 2 +- .../ssi/lib/model/base/Base64WithPadding.java | 2 +- .../ssi/lib/model/base/EncodeType.java | 2 +- .../ssi/lib/model/base/MultibaseFactory.java | 2 +- .../tractusx/ssi/lib/model/did/Did.java | 2 +- .../ssi/lib/model/did/DidDocument.java | 2 +- .../ssi/lib/model/did/DidDocumentBuilder.java | 2 +- .../tractusx/ssi/lib/model/did/DidMethod.java | 2 +- .../lib/model/did/DidMethodIdentifier.java | 2 +- .../tractusx/ssi/lib/model/did/DidParser.java | 2 +- .../model/did/Ed25519VerificationMethod.java | 2 +- .../did/Ed25519VerificationMethodBuilder.java | 2 +- .../lib/model/did/JWKVerificationMethod.java | 2 +- .../did/JWKVerificationMethodBuilder.java | 2 +- .../ssi/lib/model/did/VerificationMethod.java | 2 +- .../tractusx/ssi/lib/model/proof/Proof.java | 2 +- .../Ed25519Signature2020.java | 4 +-- .../Ed25519Signature2020Builder.java | 4 +-- .../lib/model/proof/jws/JWSSignature2020.java | 2 +- .../proof/jws/JWSSignature2020Builder.java | 2 +- .../ssi/lib/model/verifiable/Verifiable.java | 2 +- .../credential/VerifiableCredential.java | 2 +- .../VerifiableCredentialBuilder.java | 2 +- .../VerifiableCredentialStatus.java | 2 +- ...rifiableCredentialStatusList2021Entry.java | 2 +- .../VerifiableCredentialSubject.java | 2 +- .../credential/VerifiableCredentialType.java | 2 +- .../credential/VerifiableCredentials.java | 2 +- .../presentation/VerifiablePresentation.java | 2 +- .../VerifiablePresentationBuilder.java | 2 +- .../VerifiablePresentationType.java | 2 +- .../tractusx/ssi/lib/proof/ISigner.java | 2 +- .../tractusx/ssi/lib/proof/IVerifier.java | 2 +- .../lib/proof/LinkedDataProofGenerator.java | 10 +++--- .../lib/proof/LinkedDataProofValidation.java | 4 +-- .../tractusx/ssi/lib/proof/SignatureType.java | 6 ++-- .../ssi/lib/proof/hash/HashedLinkedData.java | 2 +- .../ssi/lib/proof/hash/LinkedDataHasher.java | 2 +- .../transform/LinkedDataTransformer.java | 2 +- .../transform/TransformedLinkedData.java | 2 +- .../types/ed25519/Ed25519ProofSigner.java | 2 +- .../types/ed25519/Ed25519ProofVerifier.java | 8 ++--- .../lib/proof/types/jws/JWSProofSigner.java | 2 +- .../lib/proof/types/jws/JWSProofVerifier.java | 2 +- .../ssi/lib/serialization/SerializeUtil.java | 2 +- .../jsonLd/JsonLdSerializer.java | 2 +- .../jsonLd/JsonLdSerializerImpl.java | 2 +- .../jwt/SerializedJwtPresentationFactory.java | 2 +- .../SerializedJwtPresentationFactoryImpl.java | 2 +- .../jwt/SerializedVerifiableCredential.java | 2 +- .../jwt/SerializedVerifiablePresentation.java | 2 +- .../jwt/VerifiableCredentialSerializer.java | 2 +- .../ssi/lib/validation/JsonLdValidator.java | 2 +- .../lib/validation/JsonLdValidatorImpl.java | 2 +- .../ssi/lib/base/Base58BitcoinTest.java | 2 +- .../tractusx/ssi/lib/base/Base64Test.java | 2 +- .../ssi/lib/base/Base64WithPaddingTest.java | 2 +- ...d21559KeyTest.java => ED25519KeyTest.java} | 34 +++++++++---------- .../resolver/CompositeDidResolverTest.java | 2 +- .../lib/did/resolver/DidUniResolverIT.java | 2 +- .../did/web/AbstractDidWebResolverTest.java | 2 +- .../ssi/lib/did/web/DidWebFactoryTest.java | 2 +- .../ssi/lib/did/web/DidWebResolverIT.java | 2 +- .../ssi/lib/did/web/DidWebResolverTest.java | 2 +- .../lib/did/web/util/DidWebParserTest.java | 2 +- .../ssi/lib/model/did/DidDocumentTest.java | 2 +- .../tractusx/ssi/lib/model/did/DidTest.java | 2 +- .../model/did/JsonWebKey2020BuilderTest.java | 10 +++--- .../VerifiableCredentialStatusTest.java | 2 +- .../credential/VerifiableCredentialTest.java | 2 +- .../VerifiablePresentationTest.java | 2 +- ...inkedDataProofValidationComponentTest.java | 18 +++++----- .../lib/proof/LinkedDataTransformerTest.java | 2 +- .../ssi/lib/proof/SignAndVerifyTest.java | 2 +- .../proof/LinkedDataTransformerTest.java | 2 +- .../lib/serialization/SerializeUtilTest.java | 2 +- ...ializedJwtPresentationFactoryImplTest.java | 2 +- .../ssi/lib/util/TestResourceUtil.java | 2 +- .../ssi/lib/util/identity/TestDidFactory.java | 2 +- .../lib/util/identity/TestDidResolver.java | 2 +- .../ssi/lib/util/identity/TestIdentity.java | 2 +- .../util/identity/TestIdentityFactory.java | 6 ++-- .../lib/util/identity/TestIdentityTest.java | 2 +- .../lib/util/vc/TestVerifiableFactory.java | 4 +-- .../lib/validation/JsonLdValidatorTest.java | 2 +- .../verifiable/VerifiableCredentialTest.java | 2 +- .../VerifiablePresentationTest.java | 2 +- 151 files changed, 234 insertions(+), 235 deletions(-) rename src/main/java/org/eclipse/tractusx/ssi/lib/crypt/{x21559/x21559Generator.java => x25519/x25519Generator.java} (83%) rename src/main/java/org/eclipse/tractusx/ssi/lib/crypt/{x21559/x21559PrivateKey.java => x25519/x25519PrivateKey.java} (88%) rename src/main/java/org/eclipse/tractusx/ssi/lib/crypt/{x21559/x21559PublicKey.java => x25519/x25519PublicKey.java} (88%) rename src/main/java/org/eclipse/tractusx/ssi/lib/model/proof/{ed21559 => ed25519}/Ed25519Signature2020.java (96%) rename src/main/java/org/eclipse/tractusx/ssi/lib/model/proof/{ed21559 => ed25519}/Ed25519Signature2020Builder.java (96%) rename src/test/java/org/eclipse/tractusx/ssi/lib/cypto/ed21995/{ed21559KeyTest.java => ED25519KeyTest.java} (78%) diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index 7e99174f..cb9621a3 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -1,5 +1,5 @@ ################################################################################ -# Copyright (c) 2021,2023 Contributors to the Eclipse Foundation +# Copyright (c) 2021,2024 Contributors to the Eclipse Foundation # # See the NOTICE file(s) distributed with this work for additional # information regarding copyright ownership. diff --git a/.github/workflows/publish-maven.yaml b/.github/workflows/publish-maven.yaml index eb4cb0bc..3b8e5ab4 100644 --- a/.github/workflows/publish-maven.yaml +++ b/.github/workflows/publish-maven.yaml @@ -1,5 +1,5 @@ ################################################################################ -# Copyright (c) 2021,2023 Contributors to the Eclipse Foundation +# Copyright (c) 2021,2024 Contributors to the Eclipse Foundation # # See the NOTICE file(s) distributed with this work for additional # information regarding copyright ownership. diff --git a/.github/workflows/publish-snapshot-maven.yaml b/.github/workflows/publish-snapshot-maven.yaml index 76c99009..1a3ae72c 100644 --- a/.github/workflows/publish-snapshot-maven.yaml +++ b/.github/workflows/publish-snapshot-maven.yaml @@ -1,5 +1,5 @@ ################################################################################ -# Copyright (c) 2021,2023 Contributors to the Eclipse Foundation +# Copyright (c) 2021,2024 Contributors to the Eclipse Foundation # # See the NOTICE file(s) distributed with this work for additional # information regarding copyright ownership. diff --git a/docs/NOTICE.md b/docs/NOTICE.md index 1ba4c6f1..5b397757 100644 --- a/docs/NOTICE.md +++ b/docs/NOTICE.md @@ -3,5 +3,5 @@ This work is licensed under the [Apache-2.0](https://www.apache.org/licenses/LICENSE-2.0). - SPDX-License-Identifier: Apache-2.0 -- SPDX-FileCopyrightText: 2021,2023 Contributors to the Eclipse Foundation +- SPDX-FileCopyrightText: 2021,2024 Contributors to the Eclipse Foundation - Source URL: https://github.com/eclipse-tractusx/SSI-agent-lib diff --git a/docs/README.md b/docs/README.md index ca87e188..203914e7 100644 --- a/docs/README.md +++ b/docs/README.md @@ -184,7 +184,7 @@ public static VerifiableCredential createVCWithoutProof() { ``` -5. To Generate VerifiableCredential with ED21559/JWS proof: +5. To Generate VerifiableCredential with ED25519/JWS proof: ```java @@ -202,7 +202,7 @@ import org.eclipse.tractusx.ssi.lib.model.verifiable.credential.VerifiableCreden import org.eclipse.tractusx.ssi.lib.proof.LinkedDataProofGenerator; - public static VerifiableCredential createVCWithED21559Proof( + public static VerifiableCredential createVCWithED25519Proof( VerifiableCredential credential, byte[] privateKey, Did issuer) { // VC Builder @@ -217,7 +217,7 @@ import org.eclipse.tractusx.ssi.lib.proof.LinkedDataProofGenerator; .type(credential.getTypes()); // Ed25519 Proof Builder - final LinkedDataProofGenerator generator = LinkedDataProofGenerator.newInstance(SignatureType.ED21559); + final LinkedDataProofGenerator generator = LinkedDataProofGenerator.newInstance(SignatureType.ED25519); final Ed25519Signature2020 proof = (Ed25519Signature2020) generator.createProof( builder.build(), URI.create(issuer + "#key-1"), privateKey); @@ -370,7 +370,7 @@ import org.eclipse.tractusx.ssi.lib.proof.LinkedDataProofValidation; import org.eclipse.tractusx.ssi.lib.resolver.DidDocumentResolverRegistryImpl; import org.eclipse.tractusx.ssi.lib.model.proof.jws.JWSSignature2020; - public static boolean verifyED21559LD(VerifiableCredential verifiableCredential) { + public static boolean verifyED25519LD(VerifiableCredential verifiableCredential) { // DID Resolver Constracture params DidWebParser didParser = new DidWebParser(); var httpClient = HttpClient.newHttpClient(); @@ -381,7 +381,7 @@ import org.eclipse.tractusx.ssi.lib.model.proof.jws.JWSSignature2020; new DidWebDocumentResolver(httpClient, didParser, enforceHttps)); LinkedDataProofValidation proofValidation = - LinkedDataProofValidation.newInstance(SignatureType.ED21559,didDocumentResolverRegistry); + LinkedDataProofValidation.newInstance(SignatureType.ED25519,didDocumentResolverRegistry); return proofValidation.verify(verifiableCredential); } diff --git a/docs/scripts/generateDoc.sh b/docs/scripts/generateDoc.sh index e09e9362..80ef1300 100755 --- a/docs/scripts/generateDoc.sh +++ b/docs/scripts/generateDoc.sh @@ -1,7 +1,7 @@ #!/bin/bash # # ******************************************************************************* -# Copyright (c) 2021,2023 Contributors to the Eclipse Foundation +# Copyright (c) 2021,2024 Contributors to the Eclipse Foundation # # See the NOTICE file(s) distributed with this work for additional # information regarding copyright ownership. diff --git a/docs/scripts/generateImages.sh b/docs/scripts/generateImages.sh index 5895a2f0..707ca8e9 100644 --- a/docs/scripts/generateImages.sh +++ b/docs/scripts/generateImages.sh @@ -1,7 +1,7 @@ #!/bin/bash # # ******************************************************************************* -# Copyright (c) 2021,2023 Contributors to the Eclipse Foundation +# Copyright (c) 2021,2024 Contributors to the Eclipse Foundation # # See the NOTICE file(s) distributed with this work for additional # information regarding copyright ownership. diff --git a/pom.xml b/pom.xml index 849938bd..c853b80f 100644 --- a/pom.xml +++ b/pom.xml @@ -1,6 +1,6 @@