Test Name | fapi1-advanced-final-brazildcr-happy-flow-variant |
---|---|
Variant | client_auth_type=private_key_jwt, fapi_auth_request_method=pushed, fapi_profile=openbanking_brazil, fapi_response_mode=jarm |
Test ID | DzBqno4IOwbfIC9 https://www.certification.openid.net/log-detail.html?public=true&log=DzBqno4IOwbfIC9 |
Created | 2022-01-29T19:06:37.718666Z |
Description | NBRS SCD S.A. Open Finance |
Test Version | 4.1.39 |
Test Owner | 112635894686881875468 https://accounts.google.com |
Plan ID | ZanZ0ifQzZBax https://www.certification.openid.net/plan-detail.html?public=true&plan=ZanZ0ifQzZBax |
Exported From | https://www.certification.openid.net |
Exported By | 102984098359120213727 https://accounts.google.com |
Suite Version | 4.1.39 |
Exported | 2022-01-31 18:32:43 (UTC) |
Status: FINISHED Result: PASSED |
SUCCESS 183 FAILURE 0 WARNING 0 REVIEW 0 INFO 8 |
2022-01-29 19:06:37 |
INFO
|
TEST-RUNNER
Test instance DzBqno4IOwbfIC9 created
|
||||||||||||||
|
2022-01-29 19:06:37 |
SUCCESS
|
CreateRedirectUri
Created redirect URI
|
||
|
2022-01-29 19:06:37 |
|
GetDynamicServerConfiguration
HTTP request
|
||||||||
|
2022-01-29 19:06:37 |
RESPONSE
|
GetDynamicServerConfiguration
HTTP response
|
||||||||
|
2022-01-29 19:06:37 |
SUCCESS
|
GetDynamicServerConfiguration
Successfully parsed server configuration
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
2022-01-29 19:06:37 | SUCCESS |
AddMTLSEndpointAliasesToEnvironment
Added mtls_endpoint_aliases to environment
|
|
2022-01-29 19:06:37 |
SUCCESS
|
CheckServerConfiguration
Found required server configuration keys
|
||
|
2022-01-29 19:06:37 |
|
FetchServerKeys
Fetching server key
|
||
|
2022-01-29 19:06:37 |
|
FetchServerKeys
HTTP request
|
||||||||
|
2022-01-29 19:06:38 |
RESPONSE
|
FetchServerKeys
HTTP response
|
||||||||
|
2022-01-29 19:06:38 |
|
FetchServerKeys
Found JWK set string
|
||
|
2022-01-29 19:06:38 |
SUCCESS
|
FetchServerKeys
Found server JWK set
|
||
|
2022-01-29 19:06:38 |
SUCCESS
|
CheckServerKeysIsValid
Server JWKs is valid
|
||
|
2022-01-29 19:06:38 | SUCCESS |
ValidateServerJWKs
Valid server JWKs: keys are valid JSON, contain the required fields and are correctly encoded using unpadded base64url
|
|
2022-01-29 19:06:38 | SUCCESS |
CheckForKeyIdInServerJWKs
All keys contain kids
|
|
2022-01-29 19:06:38 | SUCCESS |
EnsureServerJwksDoesNotContainPrivateOrSymmetricKeys
Jwks does not contain any private or symmetric keys
|
|
2022-01-29 19:06:38 | SUCCESS |
FAPIEnsureMinimumServerKeyLength
Validated minimum key lengths for server_jwks
|
||
|
2022-01-29 19:06:38 |
SUCCESS
|
ValidateMTLSCertificatesHeader
MTLS certificates header is valid
|
|
2022-01-29 19:06:38 |
SUCCESS
|
ExtractMTLSCertificatesFromConfiguration
Mutual TLS authentication credentials loaded
|
||||||
|
2022-01-29 19:06:38 |
SUCCESS
|
ExtractJWKSDirectFromClientConfiguration
Extracted client JWK
|
||||
|
2022-01-29 19:06:38 | SUCCESS |
CheckDistinctKeyIdValueInClientJWKs
Distinct 'kid' value in all keys of client_jwks
|
||
|
Obtain access token for directory and retrieve a software statement |
2022-01-29 19:06:38 |
SUCCESS
|
ExtractDirectoryConfiguration
Extracted directory configuration parameters
|
||||
|
2022-01-29 19:06:38 | SUCCESS |
FAPIBrazilCheckDirectoryDiscoveryUrl
Directory Discovery URL matches the Brazil directory.
|
||
|
2022-01-29 19:06:38 | SUCCESS |
FAPIBrazilCheckDirectoryApiBase
Directory API base matches the Brazil directory.
|
||
|
2022-01-29 19:06:38 |
|
GetDynamicServerConfiguration
HTTP request
|
||||||||||
|
2022-01-29 19:06:38 |
RESPONSE
|
GetDynamicServerConfiguration
HTTP response
|
||||||||
|
2022-01-29 19:06:38 |
SUCCESS
|
GetDynamicServerConfiguration
Successfully parsed server configuration
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
2022-01-29 19:06:38 | SUCCESS |
AddMTLSEndpointAliasesToEnvironment
Added mtls_endpoint_aliases to environment
|
|
2022-01-29 19:06:38 |
|
CreateTokenEndpointRequestForClientCredentialsGrant
Leaving off 'scope' parameter from token request
|
|
2022-01-29 19:06:38 |
SUCCESS
|
CreateTokenEndpointRequestForClientCredentialsGrant
|
||
|
2022-01-29 19:06:38 |
SUCCESS
|
SetDirectorySoftwareScopeOnTokenEndpointRequest
Set scope parameter to 'directory:software'
|
||||
|
2022-01-29 19:06:38 |
|
AddClientIdToTokenEndpointRequest
|
||||||
|
2022-01-29 19:06:38 |
|
CallTokenEndpoint
HTTP request
|
||||||||||
|
2022-01-29 19:06:38 |
RESPONSE
|
CallTokenEndpoint
HTTP response
|
||||||||
|
2022-01-29 19:06:38 |
|
CallTokenEndpoint
Token endpoint response
|
||
|
2022-01-29 19:06:38 |
SUCCESS
|
CallTokenEndpoint
Parsed token endpoint response
|
||||||||
|
2022-01-29 19:06:38 |
SUCCESS
|
CheckIfTokenEndpointResponseError
No error from token endpoint
|
|
2022-01-29 19:06:38 |
SUCCESS
|
CheckForAccessTokenValue
Found an access token
|
||
|
2022-01-29 19:06:38 |
SUCCESS
|
ExtractAccessTokenFromTokenResponse
Extracted the access token
|
||||
|
2022-01-29 19:06:38 | SUCCESS |
AddMTLSEndpointAliasesToEnvironment
Added mtls_endpoint_aliases to environment
|
|
2022-01-29 19:06:38 |
SUCCESS
|
FAPIBrazilExtractClientMTLSCertificateSubject
Extracted subject from MTLS certificate
|
||||||
|
2022-01-29 19:06:38 |
|
FAPIBrazilCallDirectorySoftwareStatementEndpointWithBearerToken
HTTP request
|
||||||||||
|
2022-01-29 19:06:39 |
RESPONSE
|
FAPIBrazilCallDirectorySoftwareStatementEndpointWithBearerToken
HTTP response
|
||||||||
|
2022-01-29 19:06:39 |
|
FAPIBrazilCallDirectorySoftwareStatementEndpointWithBearerToken
software statement endpoint response
|
||
|
2022-01-29 19:06:39 |
SUCCESS
|
FAPIBrazilCallDirectorySoftwareStatementEndpointWithBearerToken
Parsed assertion endpoint response
|
||||||
|
Perform Dynamic Client Registration |
2022-01-29 19:06:39 |
|
StoreOriginalClientConfiguration
Created original_client_config object from the client configuration.
|
||||||
|
2022-01-29 19:06:39 |
|
ExtractClientNameFromStoredConfig
Extracted client_name from stored client configuration.
|
||
|
2022-01-29 19:06:39 | SUCCESS |
FAPIBrazilExtractJwksUriFromSoftwareStatement
Extracted JWKS URI from software statement
|
||
|
2022-01-29 19:06:39 |
|
CreateEmptyDynamicRegistrationRequest
Created empty dynamic registration request
|
|
2022-01-29 19:06:39 |
|
AddAuthorizationCodeGrantTypeToDynamicRegistrationRequest
Added 'authorization_code' to 'grant_types'
|
||
|
2022-01-29 19:06:39 |
|
AddRefreshTokenGrantTypeToDynamicRegistrationRequest
Added 'refresh_token' to 'grant_types'
|
||
|
2022-01-29 19:06:39 |
|
AddClientCredentialsGrantTypeToDynamicRegistrationRequest
Added 'client_credentials' to 'grant_types'
|
||
|
2022-01-29 19:06:39 |
|
AddJwksUriToDynamicRegistrationRequest
Added jwks_uri to dynamic registration request
|
||
|
2022-01-29 19:06:39 |
|
AddTokenEndpointAuthMethodToDynamicRegistrationRequestFromEnvironment
Added token endpoint auth method to dynamic registration request
|
||
|
2022-01-29 19:06:39 |
|
SetResponseTypeCodeInDynamicRegistrationRequest
Added response_type 'code' to dynamic registration request
|
||
|
2022-01-29 19:06:39 |
|
FapiBrazilVerifyRedirectUriContainedInSoftwareStatement
Required redirect_uri is present in the software statement
|
||||
|
2022-01-29 19:06:39 |
|
AddRedirectUriToDynamicRegistrationRequest
Added redirect_uris array to dynamic registration request
|
||
|
2022-01-29 19:06:39 |
|
AddSoftwareStatementToDynamicRegistrationRequest
Added software_statement to dynamic registration request
|
||
|
2022-01-29 19:06:39 |
|
ReorderGrantTypesInDynamicRegistrationRequest
Reversed 'grant_types' array in dynamic registration request
|
||
|
2022-01-29 19:06:39 |
|
AddScopeToDynamicRegistrationRequest
Added scope from client configuration to dynamic registration request
|
||
|
2022-01-29 19:06:39 |
|
CallDynamicRegistrationEndpoint
HTTP request
|
||||||||||
|
2022-01-29 19:06:39 |
RESPONSE
|
CallDynamicRegistrationEndpoint
HTTP response
|
||||||||
|
2022-01-29 19:06:39 |
|
CallDynamicRegistrationEndpoint
Parsed registration endpoint response
|
||||||||||
|
2022-01-29 19:06:39 | SUCCESS |
EnsureContentTypeJson
endpoint_response Content-Type: header is application/json
|
|
2022-01-29 19:06:39 | SUCCESS |
EnsureHttpStatusCodeIs201
dynamic registration endpoint returned the expected http status
|
||||
|
2022-01-29 19:06:39 | SUCCESS |
CheckNoErrorFromDynamicRegistrationEndpoint
Dynamic registration endpoint did not return an error.
|
|
2022-01-29 19:06:39 | SUCCESS |
ExtractDynamicRegistrationResponse
Extracted client from dynamic registration response
|
||
|
2022-01-29 19:06:39 | SUCCESS |
ExtractClientManagementCredentials
Extracted dynamic registration management credentials
|
||||
|
2022-01-29 19:06:39 | SUCCESS |
ClientManagementEndpointAndAccessTokenRequired
Client management endpoint and access token were provided by the authorization server.
|
||||
|
2022-01-29 19:06:39 | SUCCESS |
CheckScopesFromDynamicRegistrationEndpointContainRequiredScopes
'scope' in dynamic registration response contains the scopes specified in the test configuration.
|
||||
|
2022-01-29 19:06:39 |
|
CopyScopeFromDynamicRegistrationTemplateToClientConfiguration
Copied scope from original_client_config to client configuration
|
||
|
2022-01-29 19:06:39 |
|
CopyOrgJwksFromDynamicRegistrationTemplateToClientConfiguration
Copied org_jwks from original_client_config to client configuration
|
||
|
2022-01-29 19:06:39 | SUCCESS |
CheckScopesFromDynamicRegistrationEndpointDoNotExceedRequestedScopes
'scope' in dynamic registration response contains only scopes that were requested.
|
||||
|
2022-01-29 19:06:39 |
SUCCESS
|
GetResourceEndpointConfiguration
Found a resource endpoint object
|
||||||||||
|
2022-01-29 19:06:39 |
SUCCESS
|
SetProtectedResourceUrlToSingleResourceEndpoint
Set protected resource URL
|
||
|
2022-01-29 19:06:39 |
SUCCESS
|
ExtractTLSTestValuesFromResourceConfiguration
Extracted TLS information from resource endpoint
|
||
|
2022-01-29 19:06:39 |
SUCCESS
|
ExtractTLSTestValuesFromOBResourceConfiguration
Extracted TLS information from resource endpoint
|
||||
|
2022-01-29 19:06:39 |
|
fapi1-advanced-final-brazildcr-happy-flow-variant
Setup Done
|
|
2022-01-29 19:06:39 |
|
fapi1-advanced-final-brazildcr-happy-flow-variant
Payments scope present - protected resource assumed to be a payments endpoint
|
|
2022-01-29 19:06:39 |
SUCCESS
|
FAPIBrazilSetPaymentDateToToday
Successfully added current date ('2022-01-29') to payment consent payload
|
||||||||||||
|
Use client_credentials grant to obtain Brazil consent |
2022-01-29 19:06:39 |
SUCCESS
|
CreateTokenEndpointRequestForClientCredentialsGrant
|
||||
|
2022-01-29 19:06:39 |
SUCCESS
|
SetPaymentsScopeOnTokenEndpointRequest
Set scope parameter to 'payments'
|
||||
|
2022-01-29 19:06:39 |
SUCCESS
|
CreateClientAuthenticationAssertionClaims
Created client assertion claims
|
||||||||||||
|
2022-01-29 19:06:39 |
SUCCESS
|
SignClientAuthenticationAssertion
Signed the client assertion
|
||
|
2022-01-29 19:06:39 |
|
AddClientAssertionToTokenEndpointRequest
Added client assertion
|
||||||||
|
2022-01-29 19:06:39 |
|
CallTokenEndpoint
HTTP request
|
||||||||||
|
2022-01-29 19:06:40 |
RESPONSE
|
CallTokenEndpoint
HTTP response
|
||||||||
|
2022-01-29 19:06:40 |
|
CallTokenEndpoint
Token endpoint response
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
CallTokenEndpoint
Parsed token endpoint response
|
||||||||
|
2022-01-29 19:06:40 |
SUCCESS
|
CheckIfTokenEndpointResponseError
No error from token endpoint
|
|
2022-01-29 19:06:40 |
SUCCESS
|
CheckForAccessTokenValue
Found an access token
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
ExtractAccessTokenFromTokenResponse
Extracted the access token
|
||||
|
2022-01-29 19:06:40 | SUCCESS |
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
|
||
|
2022-01-29 19:06:40 | SUCCESS |
ValidateExpiresIn
expires_in passed all validation checks
|
||
|
2022-01-29 19:06:40 |
|
CreateEmptyResourceEndpointRequestHeaders
Created empty headers
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
AddFAPIAuthDateToResourceEndpointRequest
Added x-fapi-auth-date to resource endpoint request headers
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
CreateIdempotencyKey
Created idempotency key
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
AddIdempotencyKeyHeader
Added x-idempotency-key to resource endpoint request headers
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
FAPIBrazilCreatePaymentConsentRequest
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
FAPIBrazilExtractClientMTLSCertificateSubject
Extracted subject from MTLS certificate
|
||||||
|
2022-01-29 19:06:40 | SUCCESS |
AddAudAsPaymentConsentUriToRequestObject
Added aud to request object claims
|
||
|
2022-01-29 19:06:40 |
|
AddIssAsCertificateOuToRequestObject
Added iss value based on TLS certificate organizational unit to request object claims
|
||
|
2022-01-29 19:06:40 | SUCCESS |
AddJtiAsUuidToRequestObject
Added jti to request object claims
|
||
|
2022-01-29 19:06:40 | SUCCESS |
AddIatToRequestObject
Added iat to request object claims
|
||
|
2022-01-29 19:06:40 |
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-01-29 19:06:40 |
SUCCESS
|
FAPIBrazilSignPaymentConsentRequest
Signed the request
|
||||||||
|
2022-01-29 19:06:40 |
|
FAPIBrazilCallPaymentConsentEndpointWithBearerToken
HTTP request
|
||||||||||
|
2022-01-29 19:06:40 |
RESPONSE
|
FAPIBrazilCallPaymentConsentEndpointWithBearerToken
HTTP response
|
||||||||
|
2022-01-29 19:06:40 |
SUCCESS
|
FAPIBrazilCallPaymentConsentEndpointWithBearerToken
Consent endpoint response
|
||||||||
|
2022-01-29 19:06:40 | SUCCESS |
EnsureContentTypeApplicationJwt
endpoint_response Content-Type: header is application/jwt
|
|
2022-01-29 19:06:40 |
SUCCESS
|
EnsureHttpStatusCodeIs201
payment consent endpoint returned the expected http status
|
||||
|
2022-01-29 19:06:40 | SUCCESS |
ExtractSignedJwtFromResourceResponse
Found and parsed the JWT from payment consent endpoint
|
||||||
|
2022-01-29 19:06:40 | SUCCESS |
FAPIBrazilValidateResourceResponseSigningAlg
Response was signed with PS256
|
||
|
2022-01-29 19:06:40 | SUCCESS |
FAPIBrazilValidateResourceResponseTyp
'typ' is the header of the JWT returned in the API response is 'JWT'
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
FAPIBrazilGetKeystoreJwksUri
Determined organisation jwks uri
|
||
|
2022-01-29 19:06:40 |
|
FetchServerKeys
Fetching server key
|
||
|
2022-01-29 19:06:40 |
|
FetchServerKeys
HTTP request
|
||||||||||
|
2022-01-29 19:06:40 |
RESPONSE
|
FetchServerKeys
HTTP response
|
||||||||
|
2022-01-29 19:06:40 |
|
FetchServerKeys
Found JWK set string
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
FetchServerKeys
Found server JWK set
|
||
|
2022-01-29 19:06:40 | SUCCESS |
ValidateResourceResponseSignature
endpoint_response_jwt signature validated
|
||
|
2022-01-29 19:06:40 | SUCCESS |
ValidateResourceResponseJwtClaims
Resource endpoint response JWS iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
|
|
2022-01-29 19:06:40 |
SUCCESS
|
ExtractConsentIdFromConsentEndpointResponse
Extracted the consent id
|
||
|
2022-01-29 19:06:40 | SUCCESS |
CheckForFAPIInteractionIdInResourceResponse
Found x-fapi-interaction-id
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
FAPIBrazilAddConsentIdToClientScope
Added scope of 'openid payments consent:urn:numbrs:d3a0ca16-f3d2-4b79-aded-8899a007c0de' to client's scope
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Make request to authorization endpoint |
2022-01-29 19:06:40 |
SUCCESS
|
CreateAuthorizationEndpointRequestFromClientInformation
Created authorization endpoint request
|
||||||
|
2022-01-29 19:06:40 |
|
CreateRandomStateValue
Created state value
|
||||
|
2022-01-29 19:06:40 |
SUCCESS
|
AddStateToAuthorizationEndpointRequest
Added state parameter to request
|
||||||||
|
2022-01-29 19:06:40 |
|
CreateRandomNonceValue
Created nonce value
|
||||
|
2022-01-29 19:06:40 |
SUCCESS
|
AddNonceToAuthorizationEndpointRequest
Added nonce parameter to request
|
||||||||||
|
2022-01-29 19:06:40 |
SUCCESS
|
SetAuthorizationEndpointRequestResponseTypeToCode
Added response_type parameter to request
|
||||||||||||
|
2022-01-29 19:06:40 |
SUCCESS
|
SetAuthorizationEndpointRequestResponseModeToJWT
Added response_mode parameter to request
|
||||||||||||||
|
2022-01-29 19:06:40 |
|
CreateRandomCodeVerifier
Created code_verifier value
|
||
|
2022-01-29 19:06:40 |
|
CreateS256CodeChallenge
Created code_challenge value
|
||
|
2022-01-29 19:06:40 | SUCCESS |
AddCodeChallengeToAuthorizationEndpointRequest
Added code_challenge and code_challenge_method parameters to request
|
||||||||||||||||||
|
2022-01-29 19:06:40 |
SUCCESS
|
ConvertAuthorizationEndpointRequestToRequestObject
Created request object claims
|
||
|
2022-01-29 19:06:40 | SUCCESS |
AddNbfToRequestObject
Added nbf to request object claims
|
||
|
2022-01-29 19:06:40 | SUCCESS |
AddExpToRequestObject
Added exp to request object claims
|
||
|
2022-01-29 19:06:40 | SUCCESS |
AddAudToRequestObject
Added aud to request object claims
|
||
|
2022-01-29 19:06:40 | SUCCESS |
AddIssToRequestObject
Added iss to request object claims
|
||
|
2022-01-29 19:06:40 | SUCCESS |
AddClientIdToRequestObject
Added client_id to request object claims
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
SignRequestObject
Signed the request object
|
||||||||
|
2022-01-29 19:06:40 |
SUCCESS
|
BuildRequestObjectPostToPAREndpoint
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
CreateClientAuthenticationAssertionClaims
Created client assertion claims
|
||||||||||||
|
2022-01-29 19:06:40 | SUCCESS |
UpdateClientAuthenticationAssertionClaimsWithISSAud
Updated audience in client assertion claims
|
||||||||||||
|
2022-01-29 19:06:40 |
SUCCESS
|
SignClientAuthenticationAssertion
Signed the client assertion
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
AddClientAssertionToPAREndpointParameters
Added client assertion to request
|
||
|
2022-01-29 19:06:40 |
|
CallPAREndpoint
HTTP request
|
||||||||||
|
2022-01-29 19:06:40 |
RESPONSE
|
CallPAREndpoint
HTTP response
|
||||||||
|
2022-01-29 19:06:40 | SUCCESS |
CallPAREndpoint
Storing pushed_authorization_endpoint_response_http_status 201
|
|
2022-01-29 19:06:40 | SUCCESS |
CallPAREndpoint
Parsed pushed authorization request endpoint response
|
||||
|
2022-01-29 19:06:40 | SUCCESS |
CheckIfPAREndpointResponseError
pushed authorization request endpoint correct response.
|
|
2022-01-29 19:06:40 | SUCCESS |
CheckForRequestUriValue
Found valid request_uri
|
||
|
2022-01-29 19:06:40 | SUCCESS |
CheckForPARResponseExpiresIn
Found expires_in
|
||
|
2022-01-29 19:06:40 |
SUCCESS
|
ExtractRequestUriFromPARResponse
Extracted the request_uri: urn:ietf:params:oauth:request_uri:jU3YrK_pgP2BtgkOM8Yf1
|
|
2022-01-29 19:06:40 | SUCCESS |
EnsureMinimumRequestUriEntropy
Calculated shannon entropy seems sufficient
|
||||||
|
2022-01-29 19:06:40 | SUCCESS |
BuildRequestObjectByReferenceRedirectToAuthorizationEndpoint
Sending to authorization endpoint
|
||
|
2022-01-29 19:06:40 |
REDIRECT
|
fapi1-advanced-final-brazildcr-happy-flow-variant
Redirecting to authorization endpoint
|
||
|
2022-01-29 19:06:45 |
INCOMING
|
fapi1-advanced-final-brazildcr-happy-flow-variant
Incoming HTTP request to /test/a/numbrs/callback
|
||||||||||||||||||||
|
2022-01-29 19:06:45 |
SUCCESS
|
CreateRandomImplicitSubmitUrl
Created random implicit submission URL
|
||
|
2022-01-29 19:06:45 |
OUTGOING
|
fapi1-advanced-final-brazildcr-happy-flow-variant
Response to HTTP request to test instance DzBqno4IOwbfIC9
|
||||
|
2022-01-29 19:06:46 |
INCOMING
|
fapi1-advanced-final-brazildcr-happy-flow-variant
Incoming HTTP request to /test/a/numbrs/implicit/jwyhS1BDf9thX24Kvn2v
|
||||||||||||||||||||
|
2022-01-29 19:06:46 |
OUTGOING
|
fapi1-advanced-final-brazildcr-happy-flow-variant
Response to HTTP request to test instance DzBqno4IOwbfIC9
|
||||||||
|
2022-01-29 19:06:46 |
SUCCESS
|
ExtractImplicitHashToCallbackResponse
implicit_hash is empty
|
|
2022-01-29 19:06:46 |
REDIRECT-IN
|
fapi1-advanced-final-brazildcr-happy-flow-variant
Authorization endpoint response captured
|
||||||||||
|
Verify authorization endpoint response |
2022-01-29 19:06:46 | SUCCESS |
ExtractJARMFromURLQuery
Found and parsed the jarm_response from callback_query_params
|
||||||
|
2022-01-29 19:06:46 | SUCCESS |
RejectNonJarmResponsesInUrlQuery
Authorization endpoint response only includes the JARM JWT.
|
|
2022-01-29 19:06:46 |
SUCCESS
|
ExtractAuthorizationEndpointResponseFromJARMResponse
Extracted the authorization response
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateJARMResponse
JARM response standard JWT claims are valid
|
|
2022-01-29 19:06:46 | SUCCESS |
ValidateJARMExpRecommendations
JARM response 'exp' is less than 10 minutes
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateJARMSignatureUsingKid
jarm_response signature validated
|
||
|
2022-01-29 19:06:46 | SUCCESS |
RejectAuthCodeInUrlQuery
Authorization code is not present in URL query returned from authorization endpoint
|
|
2022-01-29 19:06:46 |
SUCCESS
|
CheckMatchingCallbackParameters
Callback parameters successfully verified
|
|
2022-01-29 19:06:46 | SUCCESS |
RejectStateInUrlQueryForHybridFlow
state is correctly not present in URL query returned from authorization endpoint (as in the hybrid flow it must be returned in the URL fragment/hash only)
|
|
2022-01-29 19:06:46 |
SUCCESS
|
CheckIfAuthorizationEndpointError
No error from authorization endpoint
|
|
2022-01-29 19:06:46 |
SUCCESS
|
ValidateSuccessfulJARMResponseFromAuthorizationEndpoint
authorization endpoint response does not include unexpected parameters
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
CheckStateInAuthorizationResponse
State in response correctly returned
|
||
|
2022-01-29 19:06:46 |
|
ValidateIssInAuthorizationResponse
No 'iss' value in authorization response.
|
|
2022-01-29 19:06:46 |
SUCCESS
|
ExtractAuthorizationCodeFromAuthorizationResponse
Found authorization code
|
||
|
2022-01-29 19:06:46 | SUCCESS |
EnsureMinimumAuthorizationCodeLength
Authorization code is of sufficient length
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
EnsureMinimumAuthorizationCodeEntropy
Calculated shannon entropy seems sufficient
|
||||||
|
Call token endpoint |
2022-01-29 19:06:46 |
SUCCESS
|
CreateTokenEndpointRequestForAuthorizationCodeGrant
|
||||||
|
2022-01-29 19:06:46 |
SUCCESS
|
CreateClientAuthenticationAssertionClaims
Created client assertion claims
|
||||||||||||
|
2022-01-29 19:06:46 |
SUCCESS
|
SignClientAuthenticationAssertion
Signed the client assertion
|
||
|
2022-01-29 19:06:46 |
|
AddClientAssertionToTokenEndpointRequest
Added client assertion
|
||||||||||
|
2022-01-29 19:06:46 |
|
AddCodeVerifierToTokenEndpointRequest
|
||||||||||||
|
2022-01-29 19:06:46 |
|
CallTokenEndpoint
HTTP request
|
||||||||||
|
2022-01-29 19:06:46 |
RESPONSE
|
CallTokenEndpoint
HTTP response
|
||||||||
|
2022-01-29 19:06:46 |
|
CallTokenEndpoint
Token endpoint response
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
CallTokenEndpoint
Parsed token endpoint response
|
||||||||||||
|
Verify token endpoint response |
2022-01-29 19:06:46 |
SUCCESS
|
CheckIfTokenEndpointResponseError
No error from token endpoint
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckForAccessTokenValue
Found an access token
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
ExtractAccessTokenFromTokenResponse
Extracted the access token
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
|
||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateExpiresIn
expires_in passed all validation checks
|
||
|
2022-01-29 19:06:46 | SUCCESS |
FAPIBrazilValidateExpiresIn
expires_in no greater than 900 seconds and no less than 300 seconds
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
CheckForRefreshTokenValue
Found a refresh token
|
||
|
2022-01-29 19:06:46 | SUCCESS |
EnsureMinimumRefreshTokenLength
Refresh token is of sufficient length
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
EnsureMinimumRefreshTokenEntropy
Calculated shannon entropy seems sufficient
|
||||||
|
2022-01-29 19:06:46 | SUCCESS |
EnsureMinimumAccessTokenLength
Access token is of sufficient length
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
EnsureMinimumAccessTokenEntropy
Calculated shannon entropy seems sufficient
|
||||||
|
2022-01-29 19:06:46 | SUCCESS |
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
|
||||||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
|
|
2022-01-29 19:06:46 | SUCCESS |
EnsureIdTokenContainsKid
kid was found in the ID token header
|
||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateIdTokenNonce
Nonce values match
|
||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
|
|
2022-01-29 19:06:46 | SUCCESS |
ValidateIdTokenSignature
id_token signature validated
|
||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateIdTokenSignatureUsingKid
id_token signature validated
|
||
|
2022-01-29 19:06:46 | SUCCESS |
CheckForSubjectInIdToken
Found 'sub' in id_token
|
||
|
2022-01-29 19:06:46 | SUCCESS |
FAPIBrazilValidateIdTokenSigningAlg
id_token was signed with a permitted algorithm
|
||||
|
2022-01-29 19:06:46 | INFO |
FAPIValidateIdTokenEncryptionAlg
Skipped evaluation due to missing required element: id_token jwe_header
|
||||||
|
2022-01-29 19:06:46 | INFO |
FAPIValidateEncryptedIdTokenHasKid
Skipped evaluation due to missing required element: id_token jwe_header
|
||||||
|
2022-01-29 19:06:46 | INFO |
ExtractCHash
Couldn't find c_hash in ID token
|
|
2022-01-29 19:06:46 | INFO |
ExtractSHash
Couldn't find s_hash in ID token
|
|
2022-01-29 19:06:46 | SUCCESS |
ExtractAtHash
Extracted at_hash from ID Token
|
||||
|
2022-01-29 19:06:46 | INFO |
ValidateCHash
Skipped evaluation due to missing required object: c_hash
|
||||
|
2022-01-29 19:06:46 | INFO |
ValidateSHash
Skipped evaluation due to missing required object: s_hash
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateAtHash
at_hash validated successfully
|
||||||
|
Resource server endpoint tests |
2022-01-29 19:06:46 |
|
CreateEmptyResourceEndpointRequestHeaders
Created empty headers
|
||
|
2022-01-29 19:06:46 | SUCCESS |
AddFAPIAuthDateToResourceEndpointRequest
Added x-fapi-auth-date to resource endpoint request headers
|
||
|
2022-01-29 19:06:46 |
|
AddIpV4FapiCustomerIpAddressToResourceEndpointRequest
Added x-fapi-customer-ip-address containing IPv4 address to resource endpoint request headers
|
||
|
2022-01-29 19:06:46 |
|
CreateRandomFAPIInteractionId
Created interaction ID
|
||
|
2022-01-29 19:06:46 | SUCCESS |
AddFAPIInteractionIdToResourceEndpointRequest
Added x-fapi-interaction-id to resource endpoint request headers
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
CreateIdempotencyKey
Created idempotency key
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
AddIdempotencyKeyHeader
Added x-idempotency-key to resource endpoint request headers
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
SetApplicationJwtContentTypeHeaderForResourceEndpointRequest
Set Content-Type header
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
SetApplicationJwtAcceptHeaderForResourceEndpointRequest
Set Accept header
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
SetResourceMethodToPost
Set protected resource access method to POST
|
|
2022-01-29 19:06:46 |
SUCCESS
|
CreatePaymentRequestEntityClaims
|
||
|
2022-01-29 19:06:46 | SUCCESS |
AddAudAsPaymentInitiationUriToRequestObject
Added aud to request object claims
|
||
|
2022-01-29 19:06:46 |
|
AddIssAsCertificateOuToRequestObject
Added iss value based on TLS certificate organizational unit to request object claims
|
||
|
2022-01-29 19:06:46 | SUCCESS |
AddJtiAsUuidToRequestObject
Added jti to request object claims
|
||
|
2022-01-29 19:06:46 | SUCCESS |
AddIatToRequestObject
Added iat to request object claims
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
FAPIBrazilSignPaymentInitiationRequest
Signed the request
|
||||||||
|
2022-01-29 19:06:46 |
|
CallProtectedResourceWithBearerTokenAndCustomHeaders
HTTP request
|
||||||||||
|
2022-01-29 19:06:46 |
RESPONSE
|
CallProtectedResourceWithBearerTokenAndCustomHeaders
HTTP response
|
||||||||
|
2022-01-29 19:06:46 | SUCCESS |
CallProtectedResourceWithBearerTokenAndCustomHeaders
Got a response from the resource endpoint
|
||||||||
|
2022-01-29 19:06:46 | SUCCESS |
CheckForDateHeaderInResourceResponse
Date header present and validated
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
CheckForFAPIInteractionIdInResourceResponse
Found x-fapi-interaction-id
|
||
|
2022-01-29 19:06:46 | SUCCESS |
EnsureMatchingFAPIInteractionId
Interaction ID matched
|
||
|
2022-01-29 19:06:46 | SUCCESS |
EnsureContentTypeApplicationJwt
endpoint_response Content-Type: header is application/jwt
|
|
2022-01-29 19:06:46 |
SUCCESS
|
EnsureHttpStatusCodeIs201
resource endpoint returned the expected http status
|
||||
|
2022-01-29 19:06:46 | SUCCESS |
ExtractSignedJwtFromResourceResponse
Found and parsed the JWT from payment consent endpoint
|
||||||
|
2022-01-29 19:06:46 | SUCCESS |
FAPIBrazilValidateResourceResponseSigningAlg
Response was signed with PS256
|
||
|
2022-01-29 19:06:46 | SUCCESS |
FAPIBrazilValidateResourceResponseTyp
'typ' is the header of the JWT returned in the API response is 'JWT'
|
||
|
2022-01-29 19:06:46 |
|
FetchServerKeys
Fetching server key
|
||
|
2022-01-29 19:06:46 |
|
FetchServerKeys
HTTP request
|
||||||||||
|
2022-01-29 19:06:46 |
RESPONSE
|
FetchServerKeys
HTTP response
|
||||||||
|
2022-01-29 19:06:46 |
|
FetchServerKeys
Found JWK set string
|
||
|
2022-01-29 19:06:46 |
SUCCESS
|
FetchServerKeys
Found server JWK set
|
||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateResourceResponseSignature
endpoint_response_jwt signature validated
|
||
|
2022-01-29 19:06:46 | SUCCESS |
ValidateResourceResponseJwtClaims
Resource endpoint response JWS iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
|
|
Retrieve client configuration (twice) |
2022-01-29 19:06:46 |
|
CallClientConfigurationEndpoint
HTTP request
|
||||||||||
|
2022-01-29 19:06:46 |
RESPONSE
|
CallClientConfigurationEndpoint
HTTP response
|
||||||||
|
2022-01-29 19:06:46 | SUCCESS |
CallClientConfigurationEndpoint
Called registration_client_uri
|
||||||||||
|
2022-01-29 19:06:46 | SUCCESS |
CheckRegistrationClientEndpointContentTypeHttpStatus200
registration_client_endpoint_response http status code was 200
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckRegistrationClientEndpointContentType
registration_client_endpoint_response Content-Type: header is application/json
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckClientIdFromClientConfigurationEndpoint
Client configuration endpoint returned correct client_id.
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckRedirectUrisFromClientConfigurationEndpoint
Client configuration endpoint returned correct redirect_uris.
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckClientConfigurationUriFromClientConfigurationEndpoint
Client configuration endpoint returned correct registration_client_uri.
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckClientConfigurationAccessTokenFromClientConfigurationEndpoint
Client configuration endpoint returned same registration_access_token as previously.
|
|
2022-01-29 19:06:46 |
|
CallClientConfigurationEndpoint
HTTP request
|
||||||||||
|
2022-01-29 19:06:46 |
RESPONSE
|
CallClientConfigurationEndpoint
HTTP response
|
||||||||
|
2022-01-29 19:06:46 | SUCCESS |
CallClientConfigurationEndpoint
Called registration_client_uri
|
||||||||||
|
2022-01-29 19:06:46 | SUCCESS |
CheckRegistrationClientEndpointContentTypeHttpStatus200
registration_client_endpoint_response http status code was 200
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckRegistrationClientEndpointContentType
registration_client_endpoint_response Content-Type: header is application/json
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckClientIdFromClientConfigurationEndpoint
Client configuration endpoint returned correct client_id.
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckRedirectUrisFromClientConfigurationEndpoint
Client configuration endpoint returned correct redirect_uris.
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckClientConfigurationUriFromClientConfigurationEndpoint
Client configuration endpoint returned correct registration_client_uri.
|
|
2022-01-29 19:06:46 | SUCCESS |
CheckClientConfigurationAccessTokenFromClientConfigurationEndpoint
Client configuration endpoint returned same registration_access_token as previously.
|
|
Delete client |
2022-01-29 19:06:46 |
|
UnregisterDynamicallyRegisteredClient
HTTP request
|
||||||||||
|
2022-01-29 19:06:46 |
RESPONSE
|
UnregisterDynamicallyRegisteredClient
HTTP response
|
||||||||
|
2022-01-29 19:06:46 | SUCCESS |
UnregisterDynamicallyRegisteredClient
Client successfully unregistered
|
|
2022-01-29 19:06:47 |
FINISHED
|
fapi1-advanced-final-brazildcr-happy-flow-variant
Test has run to completion
|
||
|
Unregister dynamically registered client |
2022-01-29 19:06:47 |
INFO
|
UnregisterDynamicallyRegisteredClient
Skipped evaluation due to missing required string: registration_client_uri
|
||
|
2022-01-29 19:06:47 |
|
TEST-RUNNER
Alias has now been claimed by another test
|
||||
|