Test Name | fapi1-advanced-final-ensure-matching-key-in-authorization-request |
---|---|
Variant | client_auth_type=mtls, fapi_auth_request_method=by_value, fapi_profile=openbanking_brazil, fapi_response_mode=plain_response |
Test ID | zqvXUYmY7LOH4Z2 https://www.certification.openid.net/log-detail.html?public=true&log=zqvXUYmY7LOH4Z2 |
Created | 2022-02-01T21:07:28.422781Z |
Description | brasilcard 2021 mtls |
Test Version | 4.1.39 |
Test Owner | 114653801010283873317 https://accounts.google.com |
Plan ID | hOLeRD7GDswwP https://www.certification.openid.net/plan-detail.html?public=true&plan=hOLeRD7GDswwP |
Exported From | https://www.certification.openid.net |
Exported By | 114653801010283873317 https://accounts.google.com |
Suite Version | 4.1.39 |
Exported | 2022-02-01 21:21:30 (UTC) |
Status: FINISHED Result: REVIEW |
SUCCESS 79 FAILURE 0 WARNING 0 REVIEW 1 INFO 1 |
2022-02-01 21:07:29 |
INFO
|
TEST-RUNNER
Test instance zqvXUYmY7LOH4Z2 created
|
||||||||||||||
|
2022-02-01 21:07:29 |
SUCCESS
|
CreateRedirectUri
Created redirect URI
|
||
|
2022-02-01 21:07:29 |
|
GetDynamicServerConfiguration
HTTP request
|
||||||||
|
2022-02-01 21:07:29 |
RESPONSE
|
GetDynamicServerConfiguration
HTTP response
|
||||||||
|
2022-02-01 21:07:29 |
SUCCESS
|
GetDynamicServerConfiguration
Successfully parsed server configuration
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
2022-02-01 21:07:29 | SUCCESS |
AddMTLSEndpointAliasesToEnvironment
Added mtls_endpoint_aliases to environment
|
|
2022-02-01 21:07:29 |
SUCCESS
|
CheckServerConfiguration
Found required server configuration keys
|
||
|
2022-02-01 21:07:29 |
|
FetchServerKeys
Fetching server key
|
||
|
2022-02-01 21:07:29 |
|
FetchServerKeys
HTTP request
|
||||||||
|
2022-02-01 21:07:30 |
RESPONSE
|
FetchServerKeys
HTTP response
|
||||||||
|
2022-02-01 21:07:30 |
|
FetchServerKeys
Found JWK set string
|
||
|
2022-02-01 21:07:30 |
SUCCESS
|
FetchServerKeys
Found server JWK set
|
||
|
2022-02-01 21:07:30 |
SUCCESS
|
CheckServerKeysIsValid
Server JWKs is valid
|
||
|
2022-02-01 21:07:30 | SUCCESS |
ValidateServerJWKs
Valid server JWKs: keys are valid JSON, contain the required fields and are correctly encoded using unpadded base64url
|
|
2022-02-01 21:07:30 | SUCCESS |
CheckForKeyIdInServerJWKs
All keys contain kids
|
|
2022-02-01 21:07:30 | SUCCESS |
EnsureServerJwksDoesNotContainPrivateOrSymmetricKeys
Jwks does not contain any private or symmetric keys
|
|
2022-02-01 21:07:30 | SUCCESS |
FAPIEnsureMinimumServerKeyLength
Validated minimum key lengths for server_jwks
|
||
|
2022-02-01 21:07:30 |
SUCCESS
|
GetStaticClientConfiguration
Found a static client object
|
||||||||
|
2022-02-01 21:07:30 |
SUCCESS
|
ValidateMTLSCertificatesHeader
MTLS certificates header is valid
|
|
2022-02-01 21:07:30 |
SUCCESS
|
ExtractMTLSCertificatesFromConfiguration
Mutual TLS authentication credentials loaded
|
||||||
|
2022-02-01 21:07:30 | SUCCESS |
ValidateClientJWKsPrivatePart
Valid client JWKs: keys are valid JSON, contain the required fields, the private/public exponents match and are correctly encoded using unpadded base64url
|
|
2022-02-01 21:07:30 |
SUCCESS
|
ExtractJWKsFromStaticClientConfiguration
Extracted client JWK
|
||||
|
2022-02-01 21:07:30 | SUCCESS |
CheckForKeyIdInClientJWKs
All keys contain kids
|
|
2022-02-01 21:07:30 | SUCCESS |
CheckDistinctKeyIdValueInClientJWKs
Distinct 'kid' value in all keys of client_jwks
|
||
|
2022-02-01 21:07:30 | SUCCESS |
FAPIBrazilCheckKeyAlgInClientJWKs
Keys in client JWKS all have permitted 'alg'
|
||
|
2022-02-01 21:07:30 | SUCCESS |
FAPIEnsureMinimumClientKeyLength
Validated minimum key lengths for client_jwks
|
||
|
2022-02-01 21:07:30 |
SUCCESS
|
ValidateMTLSCertificatesAsX509
Mutual TLS authentication cert validated as X.509
|
|
Verify configuration of second client |
2022-02-01 21:07:30 |
SUCCESS
|
GetStaticClient2Configuration
Found a static second client object
|
||||||||
|
2022-02-01 21:07:30 |
SUCCESS
|
ValidateMTLSCertificates2Header
MTLS certificates header is valid
|
|
2022-02-01 21:07:30 |
SUCCESS
|
ExtractMTLSCertificates2FromConfiguration
Mutual TLS authentication credentials loaded
|
||||||
|
2022-02-01 21:07:30 | SUCCESS |
ValidateClientJWKsPrivatePart
Valid client JWKs: keys are valid JSON, contain the required fields, the private/public exponents match and are correctly encoded using unpadded base64url
|
|
2022-02-01 21:07:30 |
SUCCESS
|
ExtractJWKsFromStaticClientConfiguration
Extracted client JWK
|
||||
|
2022-02-01 21:07:30 | SUCCESS |
CheckForKeyIdInClientJWKs
All keys contain kids
|
|
2022-02-01 21:07:30 | SUCCESS |
CheckDistinctKeyIdValueInClientJWKs
Distinct 'kid' value in all keys of client_jwks
|
||
|
2022-02-01 21:07:30 | SUCCESS |
FAPIBrazilCheckKeyAlgInClientJWKs
Keys in client JWKS all have permitted 'alg'
|
||
|
2022-02-01 21:07:30 | SUCCESS |
FAPIEnsureMinimumClientKeyLength
Validated minimum key lengths for client_jwks
|
||
|
2022-02-01 21:07:30 |
SUCCESS
|
ValidateMTLSCertificatesAsX509
Mutual TLS authentication cert validated as X.509
|
|
2022-02-01 21:07:30 |
SUCCESS
|
ValidateClientPrivateKeysAreDifferent
Client signing JWKs have different thumbprints
|
||||
|
2022-02-01 21:07:30 |
SUCCESS
|
GetResourceEndpointConfiguration
Found a resource endpoint object
|
||||||||||||||
|
2022-02-01 21:07:30 |
SUCCESS
|
SetProtectedResourceUrlToSingleResourceEndpoint
Set protected resource URL
|
||
|
2022-02-01 21:07:30 |
SUCCESS
|
ExtractTLSTestValuesFromResourceConfiguration
Extracted TLS information from resource endpoint
|
||
|
2022-02-01 21:07:30 |
SUCCESS
|
ExtractTLSTestValuesFromOBResourceConfiguration
Extracted TLS information from resource endpoint
|
||||
|
2022-02-01 21:07:30 |
|
fapi1-advanced-final-ensure-matching-key-in-authorization-request
Setup Done
|
|
2022-02-01 21:07:30 |
|
fapi1-advanced-final-ensure-matching-key-in-authorization-request
Payments scope present - protected resource assumed to be a payments endpoint
|
|
2022-02-01 21:07:30 |
SUCCESS
|
FAPIBrazilSetPaymentDateToToday
Successfully added current date ('2022-02-01') to payment consent payload
|
||||||||||||
|
Use client_credentials grant to obtain Brazil consent |
2022-02-01 21:07:30 |
SUCCESS
|
CreateTokenEndpointRequestForClientCredentialsGrant
|
||||
|
2022-02-01 21:07:30 |
SUCCESS
|
SetPaymentsScopeOnTokenEndpointRequest
Set scope parameter to 'payments'
|
||||
|
2022-02-01 21:07:30 |
|
AddClientIdToTokenEndpointRequest
|
||||||
|
2022-02-01 21:07:30 |
|
CallTokenEndpoint
HTTP request
|
||||||||||
|
2022-02-01 21:07:31 |
RESPONSE
|
CallTokenEndpoint
HTTP response
|
||||||||
|
2022-02-01 21:07:31 |
|
CallTokenEndpoint
Token endpoint response
|
||
|
2022-02-01 21:07:31 |
SUCCESS
|
CallTokenEndpoint
Parsed token endpoint response
|
||||||
|
2022-02-01 21:07:31 |
SUCCESS
|
CheckIfTokenEndpointResponseError
No error from token endpoint
|
|
2022-02-01 21:07:31 |
SUCCESS
|
CheckForAccessTokenValue
Found an access token
|
||
|
2022-02-01 21:07:31 |
SUCCESS
|
ExtractAccessTokenFromTokenResponse
Extracted the access token
|
||||
|
2022-02-01 21:07:31 | SUCCESS |
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
|
||
|
2022-02-01 21:07:31 | SUCCESS |
ValidateExpiresIn
expires_in passed all validation checks
|
||
|
2022-02-01 21:07:31 |
|
CreateEmptyResourceEndpointRequestHeaders
Created empty headers
|
||
|
2022-02-01 21:07:31 |
SUCCESS
|
AddFAPIAuthDateToResourceEndpointRequest
Added x-fapi-auth-date to resource endpoint request headers
|
||
|
2022-02-01 21:07:31 |
SUCCESS
|
CreateIdempotencyKey
Created idempotency key
|
||
|
2022-02-01 21:07:31 |
SUCCESS
|
AddIdempotencyKeyHeader
Added x-idempotency-key to resource endpoint request headers
|
||
|
2022-02-01 21:07:31 |
SUCCESS
|
FAPIBrazilCreatePaymentConsentRequest
|
||
|
2022-02-01 21:07:31 |
SUCCESS
|
FAPIBrazilExtractClientMTLSCertificateSubject
Extracted subject from MTLS certificate
|
||||||
|
2022-02-01 21:07:31 | SUCCESS |
AddAudAsPaymentConsentUriToRequestObject
Added aud to request object claims
|
||
|
2022-02-01 21:07:31 |
|
AddIssAsCertificateOuToRequestObject
Added iss value based on TLS certificate organizational unit to request object claims
|
||
|
2022-02-01 21:07:31 | SUCCESS |
AddJtiAsUuidToRequestObject
Added jti to request object claims
|
||
|
2022-02-01 21:07:31 | SUCCESS |
AddIatToRequestObject
Added iat to request object claims
|
||
|
2022-02-01 21:07:31 |
SUCCESS
|
ValidateOrganizationJWKsPrivatePart
Valid organization JWKs: keys are valid JSON, contain the required fields, the private/public exponents match and are correctly encoded using unpadded base64url
|
|
2022-02-01 21:07:31 |
SUCCESS
|
FAPIBrazilSignPaymentConsentRequest
Signed the request
|
||||||||
|
2022-02-01 21:07:31 |
|
FAPIBrazilCallPaymentConsentEndpointWithBearerToken
HTTP request
|
||||||||||
|
2022-02-01 21:07:34 |
RESPONSE
|
FAPIBrazilCallPaymentConsentEndpointWithBearerToken
HTTP response
|
||||||||
|
2022-02-01 21:07:34 |
SUCCESS
|
FAPIBrazilCallPaymentConsentEndpointWithBearerToken
Consent endpoint response
|
||||||||
|
2022-02-01 21:07:34 | SUCCESS |
EnsureContentTypeApplicationJwt
endpoint_response Content-Type: header is application/jwt
|
|
2022-02-01 21:07:34 |
SUCCESS
|
EnsureHttpStatusCodeIs201
payment consent endpoint returned the expected http status
|
||||
|
2022-02-01 21:07:34 | SUCCESS |
ExtractSignedJwtFromResourceResponse
Found and parsed the JWT from payment consent endpoint
|
||||||
|
2022-02-01 21:07:34 | SUCCESS |
FAPIBrazilValidateResourceResponseSigningAlg
Response was signed with PS256
|
||
|
2022-02-01 21:07:34 | SUCCESS |
FAPIBrazilValidateResourceResponseTyp
'typ' is the header of the JWT returned in the API response is 'JWT'
|
||
|
2022-02-01 21:07:34 |
SUCCESS
|
FAPIBrazilGetKeystoreJwksUri
Determined organisation jwks uri
|
||
|
2022-02-01 21:07:34 |
|
FetchServerKeys
Fetching server key
|
||
|
2022-02-01 21:07:34 |
|
FetchServerKeys
HTTP request
|
||||||||||
|
2022-02-01 21:07:34 |
RESPONSE
|
FetchServerKeys
HTTP response
|
||||||||
|
2022-02-01 21:07:34 |
|
FetchServerKeys
Found JWK set string
|
||
|
2022-02-01 21:07:34 |
SUCCESS
|
FetchServerKeys
Found server JWK set
|
||
|
2022-02-01 21:07:34 | SUCCESS |
ValidateResourceResponseSignature
endpoint_response_jwt signature validated
|
||
|
2022-02-01 21:07:34 | SUCCESS |
ValidateResourceResponseJwtClaims
Resource endpoint response JWS iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
|
|
2022-02-01 21:07:34 |
SUCCESS
|
ExtractConsentIdFromConsentEndpointResponse
Extracted the consent id
|
||
|
2022-02-01 21:07:34 | SUCCESS |
CheckForFAPIInteractionIdInResourceResponse
Found x-fapi-interaction-id
|
||
|
2022-02-01 21:07:34 |
SUCCESS
|
FAPIBrazilAddConsentIdToClientScope
Added scope of 'openid payments consent consent:urn:BCRD:pix-8ee29f90-8ee5-4998-8286-fa819f6d7074' to client's scope
|
||||||||
|
Make request to authorization endpoint |
2022-02-01 21:07:34 |
SUCCESS
|
CreateAuthorizationEndpointRequestFromClientInformation
Created authorization endpoint request
|
||||||
|
2022-02-01 21:07:34 |
|
CreateRandomStateValue
Created state value
|
||||
|
2022-02-01 21:07:34 |
SUCCESS
|
AddStateToAuthorizationEndpointRequest
Added state parameter to request
|
||||||||
|
2022-02-01 21:07:34 |
|
CreateRandomNonceValue
Created nonce value
|
||||
|
2022-02-01 21:07:34 |
SUCCESS
|
AddNonceToAuthorizationEndpointRequest
Added nonce parameter to request
|
||||||||||
|
2022-02-01 21:07:34 |
SUCCESS
|
SetAuthorizationEndpointRequestResponseTypeToCodeIdtoken
Added response_type parameter to request
|
||||||||||||
|
Sign request object containing client_id for client 1 using JWK for client 2 |
2022-02-01 21:07:34 |
SUCCESS
|
ConvertAuthorizationEndpointRequestToRequestObject
Created request object claims
|
||
|
2022-02-01 21:07:34 | SUCCESS |
AddNbfToRequestObject
Added nbf to request object claims
|
||
|
2022-02-01 21:07:34 | SUCCESS |
AddExpToRequestObject
Added exp to request object claims
|
||
|
2022-02-01 21:07:34 | SUCCESS |
AddAudToRequestObject
Added aud to request object claims
|
||
|
2022-02-01 21:07:34 | SUCCESS |
AddIssToRequestObject
Added iss to request object claims
|
||
|
2022-02-01 21:07:34 | SUCCESS |
AddClientIdToRequestObject
Added client_id to request object claims
|
||
|
2022-02-01 21:07:34 |
SUCCESS
|
SignRequestObject
Signed the request object
|
||||||||
|
2022-02-01 21:07:34 |
|
FAPIBrazilEncryptRequestObject
Encrypted the request object
|
||||||
|
2022-02-01 21:07:34 |
SUCCESS
|
BuildRequestObjectByValueRedirectToAuthorizationEndpoint
Sending to authorization endpoint
|
||
|
2022-02-01 21:07:34 |
REDIRECT
|
fapi1-advanced-final-ensure-matching-key-in-authorization-request
Redirecting to authorization endpoint
|
||
|
2022-02-01 21:07:34 | REVIEW IMAGE |
ExpectRequestObjectUnverifiableErrorPage
Show request error page
|
||||
|
2022-02-01 21:08:37 |
FINISHED
|
fapi1-advanced-final-ensure-matching-key-in-authorization-request
Test has run to completion
|
||
|
2022-02-01 21:08:46 |
|
TEST-RUNNER
Alias has now been claimed by another test
|
||||
|