com.webauthn4j.util.Base64UrlUtil Java Examples
The following examples show how to use
com.webauthn4j.util.Base64UrlUtil.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: TokenBindingValidator.java From webauthn4j with Apache License 2.0 | 6 votes |
public void validate(TokenBinding clientDataTokenBinding, byte[] serverTokenBindingId) { if (clientDataTokenBinding == null) { // nop } else { byte[] clientDataTokenBindingId; if (clientDataTokenBinding.getId() == null) { clientDataTokenBindingId = null; } else { clientDataTokenBindingId = Base64UrlUtil.decode(clientDataTokenBinding.getId()); } switch (clientDataTokenBinding.getStatus()) { case NOT_SUPPORTED: break; case SUPPORTED: break; case PRESENT: if (!Arrays.equals(clientDataTokenBindingId, serverTokenBindingId)) { throw new TokenBindingException("TokenBinding id does not match"); } } } }
Example #2
Source File: TPMAuthenticator.java From webauthn4j with Apache License 2.0 | 6 votes |
private TPMTPublic createTPMTPublic(PublicKey credentialPublicKey) { TPMIAlgPublic type = null; TPMIAlgHash nameAlg = TPMIAlgHash.TPM_ALG_SHA256; TPMAObject objectAttributes = new TPMAObject(394354); byte[] authPolicy = Base64UrlUtil.decode("nf_L82w4OuaZ-5ho3G3LidcVOIS-KAOSLBJBWL-tIq4"); TPMUPublicId unique = null; TPMUPublicParms parameters = null; if (credentialPublicKey instanceof ECPublicKey) { ECPublicKey ecPublicKey = (ECPublicKey) credentialPublicKey; EllipticCurve curve = ecPublicKey.getParams().getCurve(); parameters = new TPMSECCParms( new byte[2], new byte[2], TPMEccCurve.create(curve), new byte[2] ); type = TPMIAlgPublic.TPM_ALG_ECDSA; ECPoint ecPoint = ecPublicKey.getW(); byte[] x = ecPoint.getAffineX().toByteArray(); byte[] y = ecPoint.getAffineY().toByteArray(); unique = new ECCUnique(x, y); } return new TPMTPublic(type, nameAlg, objectAttributes, authPolicy, parameters, unique); }
Example #3
Source File: TPMAuthenticator.java From webauthn4j with Apache License 2.0 | 6 votes |
private TPMSAttest createTPMSAttest(AttestationStatementRequest attestationStatementRequest, COSEAlgorithmIdentifier alg, TPMTPublic pubArea) { TPMGenerated magic = TPMGenerated.TPM_GENERATED_VALUE; TPMISTAttest type = TPMISTAttest.TPM_ST_ATTEST_CERTIFY; byte[] qualifiedSigner = Base64UrlUtil.decode("AAu8WfTf2aakLcO4Zq_y3w0Zgmu_AUtnqwrW67F2MGuABw"); String messageDigestJcaName; try { SignatureAlgorithm signatureAlgorithm = SignatureAlgorithm.create(alg); messageDigestJcaName = signatureAlgorithm.getMessageDigestJcaName(); } catch (IllegalArgumentException e) { throw new WebAuthnModelException("alg is not signature algorithm", e); } byte[] extraData = MessageDigestUtil.createMessageDigest(messageDigestJcaName).digest(attestationStatementRequest.getSignedData()); BigInteger clock = BigInteger.valueOf(7270451399L); long resetCount = 1749088739L; long restartCount = 3639844613L; TPMSClockInfo clockInfo = new TPMSClockInfo(clock, resetCount, restartCount, true); BigInteger firmwareVersion = new BigInteger("12241000001210926099"); byte[] nameDigest = MessageDigestUtil.createSHA256().digest(pubArea.getBytes()); TPMTHA name = new TPMTHA(TPMIAlgHash.TPM_ALG_SHA256, nameDigest); byte[] qualifiedNameDigest = Base64UrlUtil.decode("AVI0eQ_AAZjNvrhUEMK2q4wxuwIFOnHIDF0Qljhf47Q"); TPMTHA qualifiedName = new TPMTHA(TPMIAlgHash.TPM_ALG_SHA256, qualifiedNameDigest); TPMUAttest attested = new TPMSCertifyInfo(name, qualifiedName); return new TPMSAttest(magic, type, qualifiedSigner, extraData, clockInfo, firmwareVersion, attested); }
Example #4
Source File: AuthenticatorDataConverterTest.java From webauthn4j with Apache License 2.0 | 6 votes |
@Test void convert_test() { //Given //noinspection SpellCheckingInspection String input = "SZYN5YgOjGh0NBcPZHZgW4_krrmihjLHmVzzuoMdl2MBAAABRQ"; //When AuthenticatorData<RegistrationExtensionAuthenticatorOutput<?>> result = new AuthenticatorDataConverter(objectConverter).convert(Base64UrlUtil.decode(input)); //Then assertThat(result.getRpIdHash()).isNotNull(); assertThat(result.getRpIdHash()).hasSize(32); assertThat(result.getFlags()).isEqualTo(BIT_UP); assertThat(result.getSignCount()).isEqualTo(325); assertThat(result.getAttestedCredentialData()).isNull(); assertThat(result.getExtensions()).isEmpty(); }
Example #5
Source File: PackedAttestationStatementValidatorTest.java From webauthn4j with Apache License 2.0 | 6 votes |
private void validate(byte[] clientDataBytes, AttestationObject attestationObject) { byte[] attestationObjectBytes = new AttestationObjectConverter(objectConverter).convertToBytes(attestationObject); Origin origin = new Origin(originUrl); Challenge challenge = (Challenge) () -> Base64UrlUtil.decode(challengeString); CollectedClientData collectedClientData = new CollectedClientDataConverter(objectConverter).convert(clientDataBytes); Set<AuthenticatorTransport> transports = Collections.emptySet(); AuthenticationExtensionsClientOutputs<RegistrationExtensionClientOutput<?>> authenticationExtensionsClientOutputs = new AuthenticationExtensionsClientOutputs<>(); RegistrationObject registrationObject = new RegistrationObject( attestationObject, attestationObjectBytes, collectedClientData, clientDataBytes, authenticationExtensionsClientOutputs, transports, new ServerProperty(origin, rpId, challenge, tokenBindingId) ); validator.validate(registrationObject); }
Example #6
Source File: AttestationObjectDeserializerTest.java From webauthn4j with Apache License 2.0 | 6 votes |
@Test void test() { ObjectConverter objectConverter = new ObjectConverter(); CborConverter cborConverter = objectConverter.getCborConverter(); //Given //noinspection SpellCheckingInspection String input = "v2hhdXRoRGF0YVi6AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABBAAAAAQAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAv2ExYTJhMvZhMyZhNPZhNfZiLTEBYi0yWCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGItM1ggAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABhMQL_Z2F0dFN0bXS_Y3g1Y4FZAsswggLHMIIBr6ADAgECAhAg92PAQYOxBTfb6FBqIlDyMA0GCSqGSIb3DQEBCwUAMEoxEjAQBgNVBAoMCVNoYXJwTGFiLjE0MDIGA1UEAwwrc3ByaW5nLXNlY3VyaXR5LXdlYmF1dGhuIDJ0aWVyIHRlc3Qgcm9vdCBDQTAgFw0xODA1MjAwNzA5NTVaGA8yMTE4MDQyNjA3MDk1NVowfTELMAkGA1UEBhMCSlAxEjAQBgNVBAoMCVNoYXJwTGFiLjEgMB4GA1UECwwXQXR0ZXN0YXRpb24gQ2VydGlmaWNhdGUxODA2BgNVBAMML3dlYmF1dGhuNGogdGVzdCAydGllciBhdXRoZW50aWNhdG9yIGF0dGVzdGF0aW9uMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEYOdbrImOAgjZN3Xb8unfHHhJDINdIykolt-ypGxcrop4KwbujX2zvoRGZvdoQ9mu-rwjAZt4H3SMsSxPvB8z8KM_MD0wDAYDVR0TAQH_BAIwADAOBgNVHQ8BAf8EBAMCB4AwHQYDVR0OBBYEFNDrzrNaaa7sdMR9uzsvO8OohdjhMA0GCSqGSIb3DQEBCwUAA4IBAQCtHcryqNSHDyszLtIByc5AzPam37vl0AVchb0qOxLFbmdUu4Nhzk-87YdA_VZuvVLInsIGaCwkP3rdqGAFY1HllglMnmWIoG2sKjmT3vpJydlDODaha9F_fVG7cq2i5Zx2KMTeUtuTkNdZDjocUUHXYVShgNnggoUWkVeLBG1ckzK1tAkbUwyChWMv4PDmIUBNv6DwkYI9oBSCSAJHpUzyxzMvCRbAFAICwPl3g-SQEUeiNlnzJuGXHnHxu-DB6JD2b0hPeYD6XxWPuI0Pq1G_6hGQmsNv3SF2ye2y_HOKnw3L-fzRHl5ksOdVZbpy9xXzTdIBUpvTmFuwcBo4HwRMY3NpZ1ggAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD_Y2ZtdGhmaWRvLXUyZv8"; //When AttestationObject result = cborConverter.readValue(Base64UrlUtil.decode(input), AttestationObject.class); //Then assertAll( () -> assertThat(result).isNotNull(), () -> assertThat(result.getAuthenticatorData()).isNotNull(), () -> assertThat(result.getFormat()).isEqualTo("fido-u2f"), () -> assertThat(result.getAttestationStatement()).isNotNull(), () -> assertThat(result.getAttestationStatement()).isInstanceOf(FIDOU2FAttestationStatement.class) ); }
Example #7
Source File: AuthenticatorDataConverterTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void extractSignCount_test() { //Given //noinspection SpellCheckingInspection String input = "SZYN5YgOjGh0NBcPZHZgW4_krrmihjLHmVzzuoMdl2NBAAAARlUOS1SqR0CfmpUat2wTATEAIHEiziyGohCFUc_hJJZGdtSu9ThnEb74K6NZC3U-KbwgpQECAyYgASFYICw4xPmHIvquDRz2KUzyyQlZFhZMbi-mc_YylL1o55jPIlggGQI5ESYAOfR8QM6quTQSoyhjZET806A3yOoCUe2AWJE"; //When long signCount = new AuthenticatorDataConverter(objectConverter).extractSignCount(Base64UrlUtil.decode(input)); assertThat(signCount).isEqualTo(70); }
Example #8
Source File: WebAuthnRegistrationRequestValidatorTest.java From webauthn4j-spring-security with Apache License 2.0 | 5 votes |
@Test public void validate_test() { WebAuthnRegistrationRequestValidator target = new WebAuthnRegistrationRequestValidator( webAuthnManager, serverPropertyProvider ); ServerProperty serverProperty = mock(ServerProperty.class); when(serverPropertyProvider.provide(any())).thenReturn(serverProperty); CollectedClientData collectedClientData = mock(CollectedClientData.class); AttestationObject attestationObject = mock(AttestationObject.class); AuthenticationExtensionsClientOutputs<RegistrationExtensionClientOutput<?>> clientExtensionOutputs = new AuthenticationExtensionsClientOutputs<>(); when(webAuthnManager.validate(any(RegistrationRequest.class), any(RegistrationParameters.class))).thenReturn( new RegistrationData(attestationObject, null, collectedClientData, null, clientExtensionOutputs, null)); MockHttpServletRequest mockHttpServletRequest = new MockHttpServletRequest(); mockHttpServletRequest.setScheme("https"); mockHttpServletRequest.setServerName("example.com"); mockHttpServletRequest.setServerPort(443); String clientDataBase64 = "clientDataBase64"; String attestationObjectBase64 = "attestationObjectBase64"; Set<String> transports = Collections.emptySet(); String clientExtensionsJSON = "clientExtensionsJSON"; target.validate(mockHttpServletRequest, clientDataBase64, attestationObjectBase64, transports, clientExtensionsJSON); ArgumentCaptor<RegistrationRequest> registrationRequestArgumentCaptor = ArgumentCaptor.forClass(RegistrationRequest.class); ArgumentCaptor<RegistrationParameters> registrationParametersArgumentCaptor = ArgumentCaptor.forClass(RegistrationParameters.class); verify(webAuthnManager).validate(registrationRequestArgumentCaptor.capture(), registrationParametersArgumentCaptor.capture()); RegistrationRequest registrationRequest = registrationRequestArgumentCaptor.getValue(); RegistrationParameters registrationParameters = registrationParametersArgumentCaptor.getValue(); assertThat(registrationRequest.getClientDataJSON()).isEqualTo(Base64UrlUtil.decode(clientDataBase64)); assertThat(registrationRequest.getAttestationObject()).isEqualTo(Base64UrlUtil.decode(attestationObjectBase64)); assertThat(registrationRequest.getClientExtensionsJSON()).isEqualTo(clientExtensionsJSON); assertThat(registrationParameters.getServerProperty()).isEqualTo(serverProperty); assertThat(registrationParameters.getExpectedExtensionIds()).isEqualTo(target.getExpectedRegistrationExtensionIds()); }
Example #9
Source File: WithMockWebAuthnUserSecurityContextFactory.java From webauthn4j-spring-security with Apache License 2.0 | 5 votes |
/** * Create a {@link SecurityContext} given an Annotation. * * @param user the {@link WithMockWebAuthnUser} to create the {@link SecurityContext} * from. Cannot be null. * @return the {@link SecurityContext} to use. Cannot be null. */ @Override public SecurityContext createSecurityContext(WithMockWebAuthnUser user) { SecurityContext context = SecurityContextHolder.createEmptyContext(); List<AuthorityEntity> authorities = Arrays.stream(user.authorities()).map((name) -> new AuthorityEntity(null, name)).collect(Collectors.toList()); List<GroupEntity> groups = Arrays.stream(user.groups()).map(GroupEntity::new).collect(Collectors.toList()); List<AuthenticatorEntity> authenticatorEntities = Arrays.stream(user.authenticators()) .map((name) -> { AuthenticatorEntity authenticatorEntity = new AuthenticatorEntity(); authenticatorEntity.setName(name); return authenticatorEntity; }) .collect(Collectors.toList()); UserEntity principal = new UserEntity(); principal.setId(user.id()); principal.setUserHandle(Base64UrlUtil.decode(user.userHandleBase64Url())); principal.setFirstName(user.firstName()); principal.setLastName(user.lastName()); principal.setEmailAddress(user.emailAddress()); principal.setGroups(groups); principal.setAuthorities(authorities); principal.setAuthenticators(authenticatorEntities); principal.setLocked(user.locked()); principal.setSingleFactorAuthenticationAllowed(user.singleFactorAuthenticationAllowed()); WebAuthnAuthenticationRequest request = mock(WebAuthnAuthenticationRequest.class); Authentication auth = new WebAuthnAuthenticationToken(principal, request, principal.getAuthorities()); context.setAuthentication(auth); return context; }
Example #10
Source File: CollectedClientDataConverterTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void convert_deserialization_test() { //noinspection SpellCheckingInspection String clientDataJson = "{\"challenge\":\"tk31UH1ETGGTPj33OhOMzw\",\"origin\":\"http://localhost:8080\",\"tokenBinding\":{\"status\":\"not-supported\"},\"type\":\"webauthn.get\"}"; String clientDataBase64UrlString = Base64UrlUtil.encodeToString(clientDataJson.getBytes(StandardCharsets.UTF_8)); CollectedClientData collectedClientData = target.convert(clientDataBase64UrlString); assertAll( () -> assertThat(collectedClientData.getType()).isEqualTo(ClientDataType.GET), () -> assertThat(collectedClientData.getChallenge()).isEqualTo(new DefaultChallenge("tk31UH1ETGGTPj33OhOMzw")), () -> assertThat(collectedClientData.getOrigin()).isEqualTo(new Origin("http://localhost:8080")) ); }
Example #11
Source File: OptionsProviderImpl.java From webauthn4j-spring-security with Apache License 2.0 | 5 votes |
/** * {@inheritDoc} */ public AttestationOptions getAttestationOptions(HttpServletRequest request, String username, Challenge challenge) { WebAuthnPublicKeyCredentialUserEntity user; Collection<? extends Authenticator> authenticators; try { WebAuthnUserDetails userDetails = userDetailsService.loadUserByUsername(username); authenticators = userDetails.getAuthenticators(); String userHandle = Base64UrlUtil.encodeToString(userDetails.getUserHandle()); user = new WebAuthnPublicKeyCredentialUserEntity(userHandle, username); } catch (UsernameNotFoundException e) { authenticators = Collections.emptyList(); user = null; } List<String> credentials = new ArrayList<>(); for (Authenticator authenticator : authenticators) { String credentialId = Base64UrlUtil.encodeToString(authenticator.getAttestedCredentialData().getCredentialId()); credentials.add(credentialId); } PublicKeyCredentialRpEntity relyingParty = new PublicKeyCredentialRpEntity(getEffectiveRpId(request), rpName, rpIcon); if (challenge == null) { challenge = challengeRepository.loadOrGenerateChallenge(request); } else { challengeRepository.saveChallenge(challenge, request); } return new AttestationOptions(relyingParty, user, challenge, pubKeyCredParams, registrationTimeout, credentials, registrationExtensions); }
Example #12
Source File: OptionsProviderImpl.java From webauthn4j-spring-security with Apache License 2.0 | 5 votes |
public AssertionOptions getAssertionOptions(HttpServletRequest request, String username, Challenge challenge) { Collection<? extends Authenticator> authenticators; try { WebAuthnUserDetails userDetails = userDetailsService.loadUserByUsername(username); authenticators = userDetails.getAuthenticators(); } catch (UsernameNotFoundException e) { authenticators = Collections.emptyList(); } String effectiveRpId = getEffectiveRpId(request); List<String> credentials = new ArrayList<>(); for (Authenticator authenticator : authenticators) { String credentialId = Base64UrlUtil.encodeToString(authenticator.getAttestedCredentialData().getCredentialId()); credentials.add(credentialId); } if (challenge == null) { challenge = challengeRepository.loadOrGenerateChallenge(request); } else { challengeRepository.saveChallenge(challenge, request); } Parameters parameters = new Parameters(usernameParameter, passwordParameter, credentialIdParameter, clientDataJSONParameter, authenticatorDataParameter, signatureParameter, clientExtensionsJSONParameter); return new AssertionOptions(challenge, authenticationTimeout, effectiveRpId, credentials, authenticationExtensions, parameters); }
Example #13
Source File: EC2COSEKeyTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void createFromUncompressedECCKey_test() { byte[] bytes = Base64UrlUtil.decode("BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"); EC2COSEKey key = EC2COSEKey.createFromUncompressedECCKey(bytes); assertThat(key.getX()).isEqualTo(Base64UrlUtil.decode("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA")); assertThat(key.getX()).isEqualTo(Base64UrlUtil.decode("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA")); }
Example #14
Source File: MetadataItemsProviderTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void fetchMetadataStatement() { HttpClient httpClient = mock(HttpClient.class); when(httpClient.fetch(any())).thenReturn("{
    "aaguid": "81303c1a-25cf-4f43-be04-0460df5b6c68",
    "alternativeDescriptions": {
        "ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2 81303c1a-25cf-4f43-be04-0460df5b6c68"
    },
    "assertionScheme": "FIDOV2",
    "attachmentHint": 2,
    "attestationRootCertificates": [
        "MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"
    ],
    "attestationTypes": [
        15879,
        15880
    ],
    "authenticationAlgorithm": 1,
    "authenticatorVersion": 2,
    "cryptoStrength": 128,
    "description": "Virtual Secp256R1 FIDO2 Conformance Testing CTAP2 Authenticator 81303c1a-25cf-4f43-be04-0460df5b6c68",
    "icon": "data:image/png;base64,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",
    "isSecondFactorOnly": false,
    "keyProtection": 10,
    "matcherProtection": 4,
    "operatingEnv": "Secure Element (SE)",
    "protocolFamily": "fido2",
    "publicKeyAlgAndEncoding": 260,
    "tcDisplay": 0,
    "upv": [
        {
            "major": 1,
            "minor": 0
        }
    ],
    "userVerificationDetails": [
        [
            {
                "userVerification": 1
            }
        ]
    ]
}"); FidoMdsMetadataItemsProvider target = new FidoMdsMetadataItemsProvider(objectConverter, httpClient); target.fetchMetadataStatement("dummy", Base64UrlUtil.decode("Sl1MsjaaSHLy2fy6AkhADanzZ6FBA89plTu8rrOAzlc")); }
Example #15
Source File: JsonConverterTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void writeValueAsBytes_test() { ConverterTestDto converterTestDto = new ConverterTestDto(); converterTestDto.setValue("dummy"); byte[] bytes = jsonConverter.writeValueAsBytes(converterTestDto); assertThat(Base64UrlUtil.encodeToString(bytes)).isEqualTo("eyJ2YWx1ZSI6ImR1bW15In0"); }
Example #16
Source File: WebAuthnProcessingFilterTest.java From webauthn4j-spring-security with Apache License 2.0 | 5 votes |
@Test public void attemptAuthentication_test_with_credential() { String credentialId = "AAhdofeLeQWG6Y6gwwytZKNCDFB1WaIgqDsOwVYR5UavKQhAti4ic9_Dz-_CQEPpN0To6hiDRSCvmFHXaG6HK5yvvhm4DJRVJXzSvZiq5NefbXSYIr2uUaKbsoBe1lulhNdL9dRt6Dkkp38uq02YIR5CDaoxD-HQgMsS667aWlhHVKE884Sq0d1VVgGTDb1ds-Py_H7CDqk9SDErb8-XtQ9L"; String clientDataJSON = "eyJjaGFsbGVuZ2UiOiJGT3JHWklmSFJfeURaSklydTVPdXBBIiwiaGFzaEFsZyI6IlMyNTYiLCJvcmlnaW4iOiJsb2NhbGhvc3QifQ"; String authenticatorData = "SZYN5YgOjGh0NBcPZHZgW4_krrmihjLHmVzzuoMdl2MBAAABaQ"; String signature = "MEUCIGBYMUVg2KkMG7V7UEsGxUeKVaO8x587JyVoZkk6FmsgAiEA5XRKxlYe2Vpwn-JYEJhcEVJ3-0nYFG-JfheOk4rA3dc"; String clientExtensionsJSON = ""; ServerProperty serverProperty = mock(ServerProperty.class); //Given mockHttpServletRequest.setMethod("POST"); mockHttpServletRequest.setServerName("example.com"); mockHttpServletRequest.setParameter("credentialId", credentialId); mockHttpServletRequest.setParameter("clientDataJSON", clientDataJSON); mockHttpServletRequest.setParameter("authenticatorData", authenticatorData); mockHttpServletRequest.setParameter("signature", signature); mockHttpServletRequest.setParameter("clientExtensionsJSON", clientExtensionsJSON); when(authenticationManager.authenticate(captor.capture())).thenReturn(null); when(serverPropertyProvider.provide(any())).thenReturn(serverProperty); //When target.attemptAuthentication(mockHttpServletRequest, mockHttpServletResponse); //Then WebAuthnAssertionAuthenticationToken authenticationToken = (WebAuthnAssertionAuthenticationToken) captor.getValue(); verify(serverPropertyProvider).provide(mockHttpServletRequest); assertThat(authenticationToken.getPrincipal()).isNull(); assertThat(authenticationToken.getCredentials()).isInstanceOf(WebAuthnAuthenticationRequest.class); assertThat(authenticationToken.getCredentials().getCredentialId()).isEqualTo(Base64UrlUtil.decode(credentialId)); assertThat(authenticationToken.getCredentials().getClientDataJSON()).isEqualTo(Base64UrlUtil.decode(clientDataJSON)); assertThat(authenticationToken.getCredentials().getAuthenticatorData()).isEqualTo(Base64UrlUtil.decode(authenticatorData)); assertThat(authenticationToken.getCredentials().getSignature()).isEqualTo(Base64UrlUtil.decode(signature)); assertThat(authenticationToken.getCredentials().getClientExtensionsJSON()).isEqualTo(clientExtensionsJSON); assertThat(authenticationToken.getCredentials().getServerProperty()).isEqualTo(serverProperty); }
Example #17
Source File: WebAuthnProcessingFilterTest.java From webauthn4j-spring-security with Apache License 2.0 | 5 votes |
@Test public void attemptAuthentication_test_with_get_method() { String credentialId = "AAhdofeLeQWG6Y6gwwytZKNCDFB1WaIgqDsOwVYR5UavKQhAti4ic9_Dz-_CQEPpN0To6hiDRSCvmFHXaG6HK5yvvhm4DJRVJXzSvZiq5NefbXSYIr2uUaKbsoBe1lulhNdL9dRt6Dkkp38uq02YIR5CDaoxD-HQgMsS667aWlhHVKE884Sq0d1VVgGTDb1ds-Py_H7CDqk9SDErb8-XtQ9L"; String clientDataJSON = "eyJjaGFsbGVuZ2UiOiJGT3JHWklmSFJfeURaSklydTVPdXBBIiwiaGFzaEFsZyI6IlMyNTYiLCJvcmlnaW4iOiJsb2NhbGhvc3QifQ"; String authenticatorData = "SZYN5YgOjGh0NBcPZHZgW4_krrmihjLHmVzzuoMdl2MBAAABaQ"; String signature = "MEUCIGBYMUVg2KkMG7V7UEsGxUeKVaO8x587JyVoZkk6FmsgAiEA5XRKxlYe2Vpwn-JYEJhcEVJ3-0nYFG-JfheOk4rA3dc"; String clientExtensionsJSON = ""; ServerProperty serverProperty = mock(ServerProperty.class); //Given target.setPostOnly(false); mockHttpServletRequest.setMethod("GET"); mockHttpServletRequest.setServerName("example.com"); mockHttpServletRequest.setParameter("credentialId", credentialId); mockHttpServletRequest.setParameter("clientDataJSON", clientDataJSON); mockHttpServletRequest.setParameter("authenticatorData", authenticatorData); mockHttpServletRequest.setParameter("signature", signature); mockHttpServletRequest.setParameter("clientExtensionsJSON", clientExtensionsJSON); when(authenticationManager.authenticate(captor.capture())).thenReturn(null); when(serverPropertyProvider.provide(any())).thenReturn(serverProperty); //When target.attemptAuthentication(mockHttpServletRequest, mockHttpServletResponse); //Then WebAuthnAssertionAuthenticationToken authenticationToken = (WebAuthnAssertionAuthenticationToken) captor.getValue(); verify(serverPropertyProvider).provide(mockHttpServletRequest); assertThat(authenticationToken.getPrincipal()).isNull(); assertThat(authenticationToken.getCredentials()).isInstanceOf(WebAuthnAuthenticationRequest.class); assertThat(authenticationToken.getCredentials().getCredentialId()).isEqualTo(Base64UrlUtil.decode(credentialId)); assertThat(authenticationToken.getCredentials().getClientDataJSON()).isEqualTo(Base64UrlUtil.decode(clientDataJSON)); assertThat(authenticationToken.getCredentials().getAuthenticatorData()).isEqualTo(Base64UrlUtil.decode(authenticatorData)); assertThat(authenticationToken.getCredentials().getSignature()).isEqualTo(Base64UrlUtil.decode(signature)); assertThat(authenticationToken.getCredentials().getClientExtensionsJSON()).isEqualTo(clientExtensionsJSON); assertThat(authenticationToken.getCredentials().getServerProperty()).isEqualTo(serverProperty); }
Example #18
Source File: OptionsProviderImplTest.java From webauthn4j-spring-security with Apache License 2.0 | 5 votes |
@Test public void getAssertionOptions_with_challenge_test() { Challenge challenge = new DefaultChallenge(); byte[] credentialId = new byte[]{0x01, 0x23, 0x45}; WebAuthnUserDetailsService userDetailsService = mock(WebAuthnUserDetailsService.class); WebAuthnUserDetails userDetails = mock(WebAuthnUserDetails.class); Authenticator authenticator = mock(Authenticator.class, RETURNS_DEEP_STUBS); List<Authenticator> authenticators = Collections.singletonList(authenticator); ChallengeRepository challengeRepository = mock(ChallengeRepository.class); MockHttpServletRequest mockRequest = new MockHttpServletRequest(); when(userDetailsService.loadUserByUsername(any())).thenReturn(userDetails); doReturn(new byte[0]).when(userDetails).getUserHandle(); doReturn(authenticators).when(userDetails).getAuthenticators(); when(authenticator.getAttestedCredentialData().getCredentialId()).thenReturn(credentialId); OptionsProvider optionsProvider = new OptionsProviderImpl(userDetailsService, challengeRepository); optionsProvider.setRpId("example.com"); optionsProvider.setRpName("rpName"); AssertionOptions attestationOptions = optionsProvider.getAssertionOptions(mockRequest, "dummy", challenge); assertThat(attestationOptions.getRpId()).isEqualTo("example.com"); assertThat(attestationOptions.getChallenge()).isEqualTo(challenge); assertThat(attestationOptions.getCredentials()).containsExactly(Base64UrlUtil.encodeToString(credentialId)); }
Example #19
Source File: AuthenticatorDataConverterTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void extractAttestedCredentialData_test() { //Given //noinspection SpellCheckingInspection String input = "SZYN5YgOjGh0NBcPZHZgW4_krrmihjLHmVzzuoMdl2NBAAAARlUOS1SqR0CfmpUat2wTATEAIHEiziyGohCFUc_hJJZGdtSu9ThnEb74K6NZC3U-KbwgpQECAyYgASFYICw4xPmHIvquDRz2KUzyyQlZFhZMbi-mc_YylL1o55jPIlggGQI5ESYAOfR8QM6quTQSoyhjZET806A3yOoCUe2AWJE"; //When byte[] result = new AuthenticatorDataConverter(objectConverter).extractAttestedCredentialData(Base64UrlUtil.decode(input)); assertThat(result).isEqualTo(Base64UrlUtil.decode("VQ5LVKpHQJ-alRq3bBMBMQAgcSLOLIaiEIVRz-EklkZ21K71OGcRvvgro1kLdT4pvCClAQIDJiABIVggLDjE-Yci-q4NHPYpTPLJCVkWFkxuL6Zz9jKUvWjnmM8iWCAZAjkRJgA59HxAzqq5NBKjKGNkRPzToDfI6gJR7YBYkQ")); }
Example #20
Source File: AuthenticatorDataConverterTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void deserialize_data_with_surplus_bytes_test() { //noinspection SpellCheckingInspection String input = "SZYN5YgOjGh0NBcPZHZgW4_krrmihjLHmVzzuoMdl2MBAAABRQ"; byte[] data = Base64UrlUtil.decode(input); byte[] bytes = Arrays.copyOf(data, data.length + 1); AuthenticatorDataConverter authenticatorDataConverter = new AuthenticatorDataConverter(objectConverter); //When assertThrows(DataConversionException.class, () -> authenticatorDataConverter.convert(bytes) ); }
Example #21
Source File: AuthenticatorDataConverterTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void convert_too_short_data_test() { //Given //noinspection SpellCheckingInspection byte[] input = Base64UrlUtil.decode("SZYN5YgOjGh0NBcP"); AuthenticatorDataConverter authenticatorDataConverter = new AuthenticatorDataConverter(objectConverter); //When assertThrows(DataConversionException.class, () -> authenticatorDataConverter.convert(input) ); }
Example #22
Source File: TokenBindingTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void constructor_test() { TokenBinding tokenBindingA = new TokenBinding(TokenBindingStatus.SUPPORTED, Base64UrlUtil.encodeToString(new byte[]{0x01, 0x23, 0x45})); TokenBinding tokenBindingB = new TokenBinding(TokenBindingStatus.SUPPORTED, new byte[]{0x01, 0x23, 0x45}); assertThat(tokenBindingA).isEqualTo(tokenBindingB); }
Example #23
Source File: WebAuthnRegistrationRequestValidator.java From webauthn4j-spring-security with Apache License 2.0 | 5 votes |
RegistrationRequest createRegistrationRequest(String clientDataBase64, String attestationObjectBase64, Set<String> transports, String clientExtensionsJSON) { byte[] clientDataBytes = Base64UrlUtil.decode(clientDataBase64); byte[] attestationObjectBytes = Base64UrlUtil.decode(attestationObjectBase64); return new RegistrationRequest( attestationObjectBytes, clientDataBytes, clientExtensionsJSON, transports ); }
Example #24
Source File: TokenBinding.java From webauthn4j with Apache License 2.0 | 5 votes |
public TokenBinding(TokenBindingStatus status, byte[] id) { this.status = status; if (id == null) { this.id = null; } else { this.id = Base64UrlUtil.encodeToString(id); } }
Example #25
Source File: JWSFactory.java From webauthn4j with Apache License 2.0 | 5 votes |
public <T extends Serializable> JWS<T> parse(String value, Class<T> payloadType) { String[] data = value.split("\\."); if (data.length != 3) { throw new IllegalArgumentException("JWS value is not divided by two period."); } String headerString = data[0]; String payloadString = data[1]; String signatureString = data[2]; JWSHeader header = jsonConverter.readValue(new String(Base64UrlUtil.decode(headerString)), JWSHeader.class); T payload = jsonConverter.readValue(new String(Base64UrlUtil.decode(payloadString)), payloadType); byte[] signature = Base64UrlUtil.decode(signatureString); return new JWS<>(header, headerString, payload, payloadString, signature); }
Example #26
Source File: CollectedClientDataConverter.java From webauthn4j with Apache License 2.0 | 5 votes |
/** * Converts from a base64url {@link String} to {@link CollectedClientData}. * * @param base64UrlString the source byte array to convert * @return the converted object */ public CollectedClientData convert(String base64UrlString) { if (base64UrlString == null) { return null; } byte[] bytes = Base64UrlUtil.decode(base64UrlString); return convert(bytes); }
Example #27
Source File: JWSFactory.java From webauthn4j with Apache License 2.0 | 5 votes |
public <T extends Serializable> JWS<T> create(JWSHeader header, T payload, PrivateKey privateKey) { String headerString = Base64UrlUtil.encodeToString(jsonConverter.writeValueAsString(header).getBytes(StandardCharsets.UTF_8)); String payloadString = Base64UrlUtil.encodeToString(jsonConverter.writeValueAsString(payload).getBytes(StandardCharsets.UTF_8)); String signedData = headerString + "." + payloadString; Signature signatureObj = SignatureUtil.createSignature(header.getAlg().getJcaName()); try { signatureObj.initSign(privateKey); signatureObj.update(signedData.getBytes()); byte[] derSignature = signatureObj.sign(); byte[] jwsSignature = JWSSignatureUtil.convertDerSignatureToJwsSignature(derSignature); return new JWS<>(header, headerString, payload, payloadString, jwsSignature); } catch (InvalidKeyException | SignatureException e) { throw new IllegalArgumentException(e); } }
Example #28
Source File: AttestationObjectConverter.java From webauthn4j with Apache License 2.0 | 5 votes |
/** * Converts from a base64url {@link String} to {@link AttestationObject}. * * @param source the source byte array to convert * @return the converted object */ public AttestationObject convert(String source) { if (source == null) { return null; } byte[] value = Base64UrlUtil.decode(source); return convert(value); }
Example #29
Source File: PackedAttestationStatementValidatorTest.java From webauthn4j with Apache License 2.0 | 5 votes |
@Test void validate_with_yubikey_fido2_data_test() { byte[] attestationObjectBytes = Base64UrlUtil.decode("o2NmbXRmcGFja2VkaGF1dGhEYXRhWJRJlg3liA6MaHQ0Fw9kdmBbj-SuuaKGMseZXPO6gx2XY0UAAAADbUS6m_bsLkm5MAyP6SDLcwAQpt-LSNKw2Ni2n3k1ltLMrqUBAgMmIAEhWCA6CWZ7k4UFMb5kynCGxmRhRVTvppyLpwBKmZ1m96qSjiJYID1KElygcTfTMT5RRoU0oAbBoZEfjHUZytXNemDDkuZpZ2F0dFN0bXSjY2FsZyZjc2lnWEYwRAIgTqgNTx1zMoc4L1Eb_dOgyqtouZBVfrQscgsGrgE4lRICICLuRuy1T05B1kv86XzP0dnN0-DzRcU1t9tS0FTktASBY3g1Y4FZAsEwggK9MIIBpaADAgECAgQq52JjMA0GCSqGSIb3DQEBCwUAMC4xLDAqBgNVBAMTI1l1YmljbyBVMkYgUm9vdCBDQSBTZXJpYWwgNDU3MjAwNjMxMCAXDTE0MDgwMTAwMDAwMFoYDzIwNTAwOTA0MDAwMDAwWjBuMQswCQYDVQQGEwJTRTESMBAGA1UECgwJWXViaWNvIEFCMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMScwJQYDVQQDDB5ZdWJpY28gVTJGIEVFIFNlcmlhbCA3MTk4MDcwNzUwWTATBgcqhkjOPQIBBggqhkjOPQMBBwNCAAQqA4ZeYEPZnhH_EKolVFeEvwmvjmseOzIXKSFvVRIajNkQ05ndx2i9_kp7x-PavGLm0kaf9Wdbj_qJDMp0hp4_o2wwajAiBgkrBgEEAYLECgIEFTEuMy42LjEuNC4xLjQxNDgyLjEuMTATBgsrBgEEAYLlHAIBAQQEAwIEMDAhBgsrBgEEAYLlHAEBBAQSBBBtRLqb9uwuSbkwDI_pIMtzMAwGA1UdEwEB_wQCMAAwDQYJKoZIhvcNAQELBQADggEBAHJX0Dzcw-EVaYSQ1vgO-VtTByNz2eZHMmMrEdzcd4rsa9WSbQfhe5xUMHiN4y9OR7RYdv-MVSICm-k4eHlXIzHnJ3AWgopxGznHT9bBJYvR5NnlZtVweQNH2lI1wD8P_kCxQo4FxukXmeR1VHFpAe64i7BXiTWIrYiq0w1xTy8vrDbVTbrXEJxbAnqwyrjPNU7xAIoJCGyghpavDPzbwYOY_N8CMWwmIsle5iK90cAKR4nkocy3SaNUul8nYEIwvv-uBua_AvvAFbzRUd811wqYqOQtykSI_PBxBCGI3-odX3S36niLKvnFFKm6uU_nOJzaGVGQsrEwfb-RGOGpKfg="); byte[] clientDataBytes = Base64UrlUtil.decode("ew0KCSJ0eXBlIiA6ICJ3ZWJhdXRobi5jcmVhdGUiLA0KCSJjaGFsbGVuZ2UiIDogIno5LWxDWmFQUlBtMGFReDlLMnE4a3ciLA0KCSJvcmlnaW4iIDogImh0dHA6Ly9sb2NhbGhvc3Q6ODA4MCIsDQoJInRva2VuQmluZGluZyIgOiANCgl7DQoJCSJzdGF0dXMiIDogInN1cHBvcnRlZCINCgl9DQp9"); AttestationObject attestationObject = new AttestationObjectConverter(objectConverter).convert(attestationObjectBytes); validate(clientDataBytes, attestationObject); }
Example #30
Source File: FidoMdsMetadataItemsProvider.java From webauthn4j with Apache License 2.0 | 5 votes |
MetadataStatement fetchMetadataStatement(String uri, byte[] expectedHash) { String uriWithToken = appendToken(uri, token); String metadataStatementBase64url = httpClient.fetch(uriWithToken); String metadataStatementStr = new String(Base64UrlUtil.decode(metadataStatementBase64url)); byte[] hash = MessageDigestUtil.createSHA256().digest(metadataStatementBase64url.getBytes(StandardCharsets.UTF_8)); if (!Arrays.equals(hash, expectedHash)) { throw new MDSException("Hash of metadataStatement doesn't match"); } MetadataStatement metadataStatement = jsonConverter.readValue(metadataStatementStr, MetadataStatement.class); metadataStatementValidator.validate(metadataStatement); return metadataStatement; }