Test Summary

Test Results

Expand All Collapse All
All times are UTC
2021-03-27 15:39:34 INFO
TEST-RUNNER
Test instance FzzfewOGAxLVkWf created
baseUrl
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client
variant
{
  "client_auth_type": "client_secret_basic",
  "response_type": "code id_token",
  "server_metadata": "discovery",
  "response_mode": "default",
  "client_registration": "dynamic_client"
}
alias
oidc-provider-discovery-dynamic_client
description
PlusAuth Hybrid OP Conformance
planId
aYhO203f84kkW
config
{
  "alias": "oidc-provider-discovery-dynamic_client",
  "server": {
    "discoveryUrl": "https://certification.plusauth.com/.well-known/openid-configuration",
    "login_hint": "bob@example.com"
  },
  "client": {
    "client_name": "first-openid-client"
  },
  "client2": {
    "client_name": "second-openid-client"
  },
  "browser": [
    {
      "match": "https://certification.plusauth.com/oauth/auth*",
      "tasks": [
        {
          "task": "Login",
          "optional": true,
          "match": "https://certification.plusauth.com/signin*",
          "commands": [
            [
              "text",
              "name",
              "username",
              "foo",
              "optional"
            ],
            [
              "text",
              "name",
              "password",
              "bar",
              "optional"
            ],
            [
              "click",
              "class",
              "login-submit"
            ]
          ]
        },
        {
          "task": "Consent",
          "optional": true,
          "match": "https://certification.plusauth.com/signin/consent*",
          "commands": [
            [
              "click",
              "class",
              "login-submit"
            ]
          ]
        },
        {
          "task": "Verify Complete",
          "match": "*/test/*/callback*",
          "commands": [
            [
              "wait",
              "id",
              "submission_complete",
              10
            ]
          ]
        }
      ]
    },
    {
      "match": "https://certification.plusauth.com/logout*",
      "tasks": [
        {
          "task": "Verify Complete",
          "match": "*/test/*/post*"
        }
      ]
    }
  ],
  "description": "PlusAuth Hybrid OP Conformance"
}
testName
oidcc-refresh-token
2021-03-27 15:39:34 SUCCESS
CreateRedirectUri
Created redirect URI
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
2021-03-27 15:39:34
GetDynamicServerConfiguration
HTTP request
request_uri
https://certification.plusauth.com/.well-known/openid-configuration
request_method
GET
request_headers
{
  "accept": "text/plain, application/json, application/cbor, application/*+json, */*",
  "content-length": "0"
}
request_body

                                
2021-03-27 15:39:35 RESPONSE
GetDynamicServerConfiguration
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "vary": "Origin",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "4735",
  "date": "Sat, 27 Mar 2021 15:39:35 GMT",
  "x-envoy-upstream-service-time": "7",
  "server": "istio-envoy"
}
response_body
{"acr_values_supported":["urn:mace:incommon:iap:bronze","urn:mace:incommon:iap:silver"],"authorization_endpoint":"https://certification.plusauth.com/oauth/auth","device_authorization_endpoint":"https://certification.plusauth.com/oauth/device/auth","claims_parameter_supported":true,"claims_supported":["sub","birthdate","family_name","gender","given_name","locale","middle_name","name","username","nickname","picture","preferred_username","profile","updated_at","website","zoneinfo","email","email_verified","address","phone_number","phone_number_verified","metadata","roles","roleGroups","permissions","acr","sid","auth_time","iss","amr"],"code_challenge_methods_supported":["S256"],"end_session_endpoint":"https://certification.plusauth.com/logout","check_session_iframe":"https://certification.plusauth.com/session/check","grant_types_supported":["implicit","authorization_code","refresh_token","client_credentials","urn:ietf:params:oauth:grant-type:device_code","urn:ietf:params:oauth:grant-type:token-exchange"],"id_token_signing_alg_values_supported":["HS256","ES256","EdDSA","PS256","RS256"],"issuer":"https://certification.plusauth.com","jwks_uri":"https://certification.plusauth.com/.well-known/jwks.json","registration_endpoint":"https://certification.plusauth.com/oauth/reg","response_modes_supported":["form_post","fragment","query","web_message","jwt","query.jwt","fragment.jwt","form_post.jwt","web_message.jwt"],"response_types_supported":["code id_token token","code id_token","code token","code","token","id_token token","id_token","none"],"scopes_supported":["openid","offline_access","profile","email","address","phone","metadata","rbac"],"subject_types_supported":["public","pairwise"],"token_endpoint_auth_methods_supported":["none","client_secret_basic","client_secret_jwt","client_secret_post","private_key_jwt","tls_client_auth","self_signed_tls_client_auth"],"token_endpoint_auth_signing_alg_values_supported":["HS256","RS256","PS256","ES256","EdDSA"],"token_endpoint":"https://certification.plusauth.com/oauth/token","pushed_authorization_request_endpoint":"https://certification.plusauth.com/oauth/request","request_object_signing_alg_values_supported":["HS256","RS256","PS256","ES256","EdDSA"],"request_parameter_supported":true,"request_uri_parameter_supported":true,"require_request_uri_registration":true,"userinfo_endpoint":"https://certification.plusauth.com/me","userinfo_signing_alg_values_supported":["HS256","ES256","EdDSA","PS256","RS256"],"authorization_signing_alg_values_supported":["HS256","ES256","EdDSA","PS256","RS256"],"introspection_endpoint":"https://certification.plusauth.com/oauth/introspect","introspection_endpoint_auth_methods_supported":["none","client_secret_basic","client_secret_jwt","client_secret_post","private_key_jwt","tls_client_auth","self_signed_tls_client_auth"],"introspection_endpoint_auth_signing_alg_values_supported":["HS256","RS256","PS256","ES256","EdDSA"],"introspection_signing_alg_values_supported":["HS256","ES256","EdDSA","PS256","RS256"],"revocation_endpoint":"https://certification.plusauth.com/oauth/token/revocation","revocation_endpoint_auth_methods_supported":["none","client_secret_basic","client_secret_jwt","client_secret_post","private_key_jwt","tls_client_auth","self_signed_tls_client_auth"],"revocation_endpoint_auth_signing_alg_values_supported":["HS256","RS256","PS256","ES256","EdDSA"],"id_token_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"id_token_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"userinfo_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"userinfo_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"introspection_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"introspection_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"authorization_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"authorization_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"request_object_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"request_object_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"backchannel_logout_supported":true,"backchannel_logout_session_supported":true,"frontchannel_logout_supported":true,"frontchannel_logout_session_supported":true,"tls_client_certificate_bound_access_tokens":true,"claim_types_supported":["normal"]}
2021-03-27 15:39:35
GetDynamicServerConfiguration
Downloaded server configuration
server_config_string
{"acr_values_supported":["urn:mace:incommon:iap:bronze","urn:mace:incommon:iap:silver"],"authorization_endpoint":"https://certification.plusauth.com/oauth/auth","device_authorization_endpoint":"https://certification.plusauth.com/oauth/device/auth","claims_parameter_supported":true,"claims_supported":["sub","birthdate","family_name","gender","given_name","locale","middle_name","name","username","nickname","picture","preferred_username","profile","updated_at","website","zoneinfo","email","email_verified","address","phone_number","phone_number_verified","metadata","roles","roleGroups","permissions","acr","sid","auth_time","iss","amr"],"code_challenge_methods_supported":["S256"],"end_session_endpoint":"https://certification.plusauth.com/logout","check_session_iframe":"https://certification.plusauth.com/session/check","grant_types_supported":["implicit","authorization_code","refresh_token","client_credentials","urn:ietf:params:oauth:grant-type:device_code","urn:ietf:params:oauth:grant-type:token-exchange"],"id_token_signing_alg_values_supported":["HS256","ES256","EdDSA","PS256","RS256"],"issuer":"https://certification.plusauth.com","jwks_uri":"https://certification.plusauth.com/.well-known/jwks.json","registration_endpoint":"https://certification.plusauth.com/oauth/reg","response_modes_supported":["form_post","fragment","query","web_message","jwt","query.jwt","fragment.jwt","form_post.jwt","web_message.jwt"],"response_types_supported":["code id_token token","code id_token","code token","code","token","id_token token","id_token","none"],"scopes_supported":["openid","offline_access","profile","email","address","phone","metadata","rbac"],"subject_types_supported":["public","pairwise"],"token_endpoint_auth_methods_supported":["none","client_secret_basic","client_secret_jwt","client_secret_post","private_key_jwt","tls_client_auth","self_signed_tls_client_auth"],"token_endpoint_auth_signing_alg_values_supported":["HS256","RS256","PS256","ES256","EdDSA"],"token_endpoint":"https://certification.plusauth.com/oauth/token","pushed_authorization_request_endpoint":"https://certification.plusauth.com/oauth/request","request_object_signing_alg_values_supported":["HS256","RS256","PS256","ES256","EdDSA"],"request_parameter_supported":true,"request_uri_parameter_supported":true,"require_request_uri_registration":true,"userinfo_endpoint":"https://certification.plusauth.com/me","userinfo_signing_alg_values_supported":["HS256","ES256","EdDSA","PS256","RS256"],"authorization_signing_alg_values_supported":["HS256","ES256","EdDSA","PS256","RS256"],"introspection_endpoint":"https://certification.plusauth.com/oauth/introspect","introspection_endpoint_auth_methods_supported":["none","client_secret_basic","client_secret_jwt","client_secret_post","private_key_jwt","tls_client_auth","self_signed_tls_client_auth"],"introspection_endpoint_auth_signing_alg_values_supported":["HS256","RS256","PS256","ES256","EdDSA"],"introspection_signing_alg_values_supported":["HS256","ES256","EdDSA","PS256","RS256"],"revocation_endpoint":"https://certification.plusauth.com/oauth/token/revocation","revocation_endpoint_auth_methods_supported":["none","client_secret_basic","client_secret_jwt","client_secret_post","private_key_jwt","tls_client_auth","self_signed_tls_client_auth"],"revocation_endpoint_auth_signing_alg_values_supported":["HS256","RS256","PS256","ES256","EdDSA"],"id_token_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"id_token_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"userinfo_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"userinfo_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"introspection_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"introspection_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"authorization_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"authorization_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"request_object_encryption_alg_values_supported":["A128KW","A256KW","ECDH-ES","ECDH-ES+A128KW","ECDH-ES+A256KW","RSA-OAEP"],"request_object_encryption_enc_values_supported":["A128CBC-HS256","A128GCM","A256CBC-HS512","A256GCM"],"backchannel_logout_supported":true,"backchannel_logout_session_supported":true,"frontchannel_logout_supported":true,"frontchannel_logout_session_supported":true,"tls_client_certificate_bound_access_tokens":true,"claim_types_supported":["normal"]}
2021-03-27 15:39:35 SUCCESS
GetDynamicServerConfiguration
Successfully parsed server configuration
acr_values_supported
[
  "urn:mace:incommon:iap:bronze",
  "urn:mace:incommon:iap:silver"
]
authorization_endpoint
https://certification.plusauth.com/oauth/auth
device_authorization_endpoint
https://certification.plusauth.com/oauth/device/auth
claims_parameter_supported
true
claims_supported
[
  "sub",
  "birthdate",
  "family_name",
  "gender",
  "given_name",
  "locale",
  "middle_name",
  "name",
  "username",
  "nickname",
  "picture",
  "preferred_username",
  "profile",
  "updated_at",
  "website",
  "zoneinfo",
  "email",
  "email_verified",
  "address",
  "phone_number",
  "phone_number_verified",
  "metadata",
  "roles",
  "roleGroups",
  "permissions",
  "acr",
  "sid",
  "auth_time",
  "iss",
  "amr"
]
code_challenge_methods_supported
[
  "S256"
]
end_session_endpoint
https://certification.plusauth.com/logout
check_session_iframe
https://certification.plusauth.com/session/check
grant_types_supported
[
  "implicit",
  "authorization_code",
  "refresh_token",
  "client_credentials",
  "urn:ietf:params:oauth:grant-type:device_code",
  "urn:ietf:params:oauth:grant-type:token-exchange"
]
id_token_signing_alg_values_supported
[
  "HS256",
  "ES256",
  "EdDSA",
  "PS256",
  "RS256"
]
issuer
https://certification.plusauth.com
jwks_uri
https://certification.plusauth.com/.well-known/jwks.json
registration_endpoint
https://certification.plusauth.com/oauth/reg
response_modes_supported
[
  "form_post",
  "fragment",
  "query",
  "web_message",
  "jwt",
  "query.jwt",
  "fragment.jwt",
  "form_post.jwt",
  "web_message.jwt"
]
response_types_supported
[
  "code id_token token",
  "code id_token",
  "code token",
  "code",
  "token",
  "id_token token",
  "id_token",
  "none"
]
scopes_supported
[
  "openid",
  "offline_access",
  "profile",
  "email",
  "address",
  "phone",
  "metadata",
  "rbac"
]
subject_types_supported
[
  "public",
  "pairwise"
]
token_endpoint_auth_methods_supported
[
  "none",
  "client_secret_basic",
  "client_secret_jwt",
  "client_secret_post",
  "private_key_jwt",
  "tls_client_auth",
  "self_signed_tls_client_auth"
]
token_endpoint_auth_signing_alg_values_supported
[
  "HS256",
  "RS256",
  "PS256",
  "ES256",
  "EdDSA"
]
token_endpoint
https://certification.plusauth.com/oauth/token
pushed_authorization_request_endpoint
https://certification.plusauth.com/oauth/request
request_object_signing_alg_values_supported
[
  "HS256",
  "RS256",
  "PS256",
  "ES256",
  "EdDSA"
]
request_parameter_supported
true
request_uri_parameter_supported
true
require_request_uri_registration
true
userinfo_endpoint
https://certification.plusauth.com/me
userinfo_signing_alg_values_supported
[
  "HS256",
  "ES256",
  "EdDSA",
  "PS256",
  "RS256"
]
authorization_signing_alg_values_supported
[
  "HS256",
  "ES256",
  "EdDSA",
  "PS256",
  "RS256"
]
introspection_endpoint
https://certification.plusauth.com/oauth/introspect
introspection_endpoint_auth_methods_supported
[
  "none",
  "client_secret_basic",
  "client_secret_jwt",
  "client_secret_post",
  "private_key_jwt",
  "tls_client_auth",
  "self_signed_tls_client_auth"
]
introspection_endpoint_auth_signing_alg_values_supported
[
  "HS256",
  "RS256",
  "PS256",
  "ES256",
  "EdDSA"
]
introspection_signing_alg_values_supported
[
  "HS256",
  "ES256",
  "EdDSA",
  "PS256",
  "RS256"
]
revocation_endpoint
https://certification.plusauth.com/oauth/token/revocation
revocation_endpoint_auth_methods_supported
[
  "none",
  "client_secret_basic",
  "client_secret_jwt",
  "client_secret_post",
  "private_key_jwt",
  "tls_client_auth",
  "self_signed_tls_client_auth"
]
revocation_endpoint_auth_signing_alg_values_supported
[
  "HS256",
  "RS256",
  "PS256",
  "ES256",
  "EdDSA"
]
id_token_encryption_alg_values_supported
[
  "A128KW",
  "A256KW",
  "ECDH-ES",
  "ECDH-ES+A128KW",
  "ECDH-ES+A256KW",
  "RSA-OAEP"
]
id_token_encryption_enc_values_supported
[
  "A128CBC-HS256",
  "A128GCM",
  "A256CBC-HS512",
  "A256GCM"
]
userinfo_encryption_alg_values_supported
[
  "A128KW",
  "A256KW",
  "ECDH-ES",
  "ECDH-ES+A128KW",
  "ECDH-ES+A256KW",
  "RSA-OAEP"
]
userinfo_encryption_enc_values_supported
[
  "A128CBC-HS256",
  "A128GCM",
  "A256CBC-HS512",
  "A256GCM"
]
introspection_encryption_alg_values_supported
[
  "A128KW",
  "A256KW",
  "ECDH-ES",
  "ECDH-ES+A128KW",
  "ECDH-ES+A256KW",
  "RSA-OAEP"
]
introspection_encryption_enc_values_supported
[
  "A128CBC-HS256",
  "A128GCM",
  "A256CBC-HS512",
  "A256GCM"
]
authorization_encryption_alg_values_supported
[
  "A128KW",
  "A256KW",
  "ECDH-ES",
  "ECDH-ES+A128KW",
  "ECDH-ES+A256KW",
  "RSA-OAEP"
]
authorization_encryption_enc_values_supported
[
  "A128CBC-HS256",
  "A128GCM",
  "A256CBC-HS512",
  "A256GCM"
]
request_object_encryption_alg_values_supported
[
  "A128KW",
  "A256KW",
  "ECDH-ES",
  "ECDH-ES+A128KW",
  "ECDH-ES+A256KW",
  "RSA-OAEP"
]
request_object_encryption_enc_values_supported
[
  "A128CBC-HS256",
  "A128GCM",
  "A256CBC-HS512",
  "A256GCM"
]
backchannel_logout_supported
true
backchannel_logout_session_supported
true
frontchannel_logout_supported
true
frontchannel_logout_session_supported
true
tls_client_certificate_bound_access_tokens
true
claim_types_supported
[
  "normal"
]
2021-03-27 15:39:35 SUCCESS
CheckServerConfiguration
Found required server configuration keys
required
[
  "authorization_endpoint",
  "token_endpoint",
  "issuer"
]
2021-03-27 15:39:35 SUCCESS
ExtractTLSTestValuesFromServerConfiguration
Extracted TLS information from authorization server configuration
registration_endpoint
{
  "testHost": "certification.plusauth.com",
  "testPort": 443
}
authorization_endpoint
{
  "testHost": "certification.plusauth.com",
  "testPort": 443
}
token_endpoint
{
  "testHost": "certification.plusauth.com",
  "testPort": 443
}
userinfo_endpoint
{
  "testHost": "certification.plusauth.com",
  "testPort": 443
}
2021-03-27 15:39:35
FetchServerKeys
Fetching server key
jwks_uri
https://certification.plusauth.com/.well-known/jwks.json
2021-03-27 15:39:35
FetchServerKeys
HTTP request
request_uri
https://certification.plusauth.com/.well-known/jwks.json
request_method
GET
request_headers
{
  "accept": "text/plain, application/json, application/cbor, application/*+json, */*",
  "content-length": "0"
}
request_body

                                
2021-03-27 15:39:36 RESPONSE
FetchServerKeys
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "vary": "Origin",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "2810",
  "date": "Sat, 27 Mar 2021 15:39:35 GMT",
  "x-envoy-upstream-service-time": "7",
  "server": "istio-envoy"
}
response_body
{"keys":[{"crv":"P-256","x":"pus2plcFzciOvQRrAfwm45u2NHw-IhjZe0gk55vO--o","y":"McjUvdFc5nd2YEk9PLYw1HoHkYBBL42jtSoqAe4dCzM","kty":"EC","kid":"atDaXCMyhIUMZISEtmnBRX_C4BT7GoJUD4CMYWGbi_o","use":"sig"},{"crv":"P-256","x":"I8yVbnSd4WJjYH3age2eLK_S9sBtP8djG9y50X13yT0","y":"29Jzh2o85AU1LOzK-SamLLHpXT0O439upvRMvvaeMQA","kty":"EC","kid":"g6MupPz7xKWQ0tKtZLcjBlnA2JAv1VH1NWYtPbsDa2o","use":"enc"},{"crv":"secp256k1","x":"65X_LqUa4XNR3ShA8hLtG-1YDKXEdWHagihJkSspdSQ","y":"Mc8XQxxJnjSJjfcrd7hhlZMyQtHU4gANSFBzr1GsKKA","kty":"EC","kid":"cUJPqrATv3GVASHuCADHyW8p8C4wR5H_nTyaf5adzy0","use":"sig"},{"crv":"P-384","x":"rPUdhjvgdhRCox2456G0CIoKaTwZ8GnbYxwjf42QsT3VtPXi3p1c2RVs8XiDutrI","y":"B_lZyUrqzwwiGHRIf5rGIXwzSgrRCoN2Hv01PPnMMeMzHVExMQCpIlkZrXO9bDKm","kty":"EC","kid":"6JVT-_BVPkvO-MljZhfaMeYC-LmZjlWj0SlzJLRA4yk","use":"sig"},{"crv":"P-384","x":"cIPV-GMwYobrMFKUHmgzvaliMUtDwO73Ht7X1AQPIpfBDIS7ovnZkt90DzcPn59P","y":"4V2b3W7jRNZqANOc60LacK1pb62GVF5Dyn2Ra4wzbhRLGDVdD_UoazOW56TZ5tsl","kty":"EC","kid":"mIw-fa5LyZnypKpbddViJjWMjl8B5A-I5A31H_igCd8","use":"enc"},{"crv":"P-521","x":"AWyeRdPc35GRFdiu2dYhFgwcSJoUPw38qmUgG0VZSgsbdWWJxUv_iWWIux9hJono6f_qF-lq2At3xdGVBLR7BF5f","y":"AY7WKdsbjyaMZ4Wh8o8Uy5Bju9WxD6N1A7r5_8o5OFIeqD_hej9FxuQDWC4rxU7Ls84yVVtPRG81TaXRoKBxr5XZ","kty":"EC","kid":"w1A1G94s-hK5YrIqWgmV30gtOZ85yQCP3ZMOPTzbc-0","use":"sig"},{"crv":"Ed25519","x":"kAdD9v4ErkCNxQdNMrf4IIplW6YUYBMWkECnLxnZ2tk","kty":"OKP","kid":"ONnNDJq5ZuIAcJyRHpZyZSDcVFf78F1eRhoElXlYEr8","use":"sig"},{"crv":"P-521","x":"AErKX164tyXiv5BwPMyrjoUGyXJ5hX1X7sRgvI0mnbfZhCRnKL67-q5PmTP31OkzA4xQGmAOyBIZvNSJ1p8txIQ3","y":"ALRaE4Q3SLQPNAW_AXIOke34SFwXq2a5FiMHWY9zpJcmCQk9VJH7bG3AnHY_hxu2R-zC5caLy6TPcSzr9Dy4F0DX","kty":"EC","kid":"xKnQ0Rm1_EMwHefKR9UOt0IwCspmyr93L_GDMO_xqq8","use":"enc"},{"crv":"Ed448","x":"sNcFa_zimfHYOSQNS52N-nOX-CYG4dFXoTeuWHnulTj6Fn3heSObBl2NY5ifB9qyP4MHgnAtiboA","kty":"OKP","kid":"MCsSgS9d92FbCGRyBo91MYcXOtXF9qoOeXz65UR5EF8","use":"sig"},{"e":"AQAB","n":"q18zoa2EagO8rzK9svtdY3U2T7DiyZ6F6RUQcpF0AvUK1z4mANLlfhtasJ01BKSP25xLbO8xF72bOd07sQazQUMumKNuU1p8kzYH5yvXNRrFPg-G6r6NWzhT3qx5ov1jkdc2zqa8yj25DfXP6btFFYqfQoPBaFwSXxHLDOXLBfa5wuLnJFL8Yt6qm5aKaOOEJ_X8CfwKH_ajBUD4MhospWZbe9gyt7gKO28sdo8VdNFCq-OG9FWWCwDgS9AYfXOHIHMNvim6sOSsT__6ETkDqUxqYYPgsANARfASBYZs7FiJMv88Hjpa5BH60gbbdYWrCkq1vGh8u1nu0R6WfsxX6w","kty":"RSA","kid":"9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4","use":"sig"},{"e":"AQAB","n":"xU_pU1APQpq581Q760Nd3UwDwKqjN62NPoXyPWxkTD15H2QDYkPMhbzY5J1TizMGGdegbeN--tnhBxMzIRxqcf83UBKvakYYJBr49dvXQSWqdpn8yG6STmO9kpG94vDQP49VBJ8YmXh6A5104_G2qXfQKe33cexKpJPKNedtDhUGUjOLzhYHjRIAGmWBsaLq5Dcbg1UtLEonzEznjKYPDUGhpE7Ao4eVeVEh0ZlFE3aocORW3xkT7uJFPq0pWBCHwD5PDPHtUQczDbbP4xn4Gr8r-vTHrxhv1WYH0NH61-YHqgG_csDat5ef3m0pJbzx7euitxxcr1bDuesB5g4fCQ","kty":"RSA","kid":"OVJpBKI4nfn-A3ZuYX6xkjNc7KhugIIm-y5Douaj6Sg","use":"enc"}]}
2021-03-27 15:39:36
FetchServerKeys
Found JWK set string
jwk_string
{"keys":[{"crv":"P-256","x":"pus2plcFzciOvQRrAfwm45u2NHw-IhjZe0gk55vO--o","y":"McjUvdFc5nd2YEk9PLYw1HoHkYBBL42jtSoqAe4dCzM","kty":"EC","kid":"atDaXCMyhIUMZISEtmnBRX_C4BT7GoJUD4CMYWGbi_o","use":"sig"},{"crv":"P-256","x":"I8yVbnSd4WJjYH3age2eLK_S9sBtP8djG9y50X13yT0","y":"29Jzh2o85AU1LOzK-SamLLHpXT0O439upvRMvvaeMQA","kty":"EC","kid":"g6MupPz7xKWQ0tKtZLcjBlnA2JAv1VH1NWYtPbsDa2o","use":"enc"},{"crv":"secp256k1","x":"65X_LqUa4XNR3ShA8hLtG-1YDKXEdWHagihJkSspdSQ","y":"Mc8XQxxJnjSJjfcrd7hhlZMyQtHU4gANSFBzr1GsKKA","kty":"EC","kid":"cUJPqrATv3GVASHuCADHyW8p8C4wR5H_nTyaf5adzy0","use":"sig"},{"crv":"P-384","x":"rPUdhjvgdhRCox2456G0CIoKaTwZ8GnbYxwjf42QsT3VtPXi3p1c2RVs8XiDutrI","y":"B_lZyUrqzwwiGHRIf5rGIXwzSgrRCoN2Hv01PPnMMeMzHVExMQCpIlkZrXO9bDKm","kty":"EC","kid":"6JVT-_BVPkvO-MljZhfaMeYC-LmZjlWj0SlzJLRA4yk","use":"sig"},{"crv":"P-384","x":"cIPV-GMwYobrMFKUHmgzvaliMUtDwO73Ht7X1AQPIpfBDIS7ovnZkt90DzcPn59P","y":"4V2b3W7jRNZqANOc60LacK1pb62GVF5Dyn2Ra4wzbhRLGDVdD_UoazOW56TZ5tsl","kty":"EC","kid":"mIw-fa5LyZnypKpbddViJjWMjl8B5A-I5A31H_igCd8","use":"enc"},{"crv":"P-521","x":"AWyeRdPc35GRFdiu2dYhFgwcSJoUPw38qmUgG0VZSgsbdWWJxUv_iWWIux9hJono6f_qF-lq2At3xdGVBLR7BF5f","y":"AY7WKdsbjyaMZ4Wh8o8Uy5Bju9WxD6N1A7r5_8o5OFIeqD_hej9FxuQDWC4rxU7Ls84yVVtPRG81TaXRoKBxr5XZ","kty":"EC","kid":"w1A1G94s-hK5YrIqWgmV30gtOZ85yQCP3ZMOPTzbc-0","use":"sig"},{"crv":"Ed25519","x":"kAdD9v4ErkCNxQdNMrf4IIplW6YUYBMWkECnLxnZ2tk","kty":"OKP","kid":"ONnNDJq5ZuIAcJyRHpZyZSDcVFf78F1eRhoElXlYEr8","use":"sig"},{"crv":"P-521","x":"AErKX164tyXiv5BwPMyrjoUGyXJ5hX1X7sRgvI0mnbfZhCRnKL67-q5PmTP31OkzA4xQGmAOyBIZvNSJ1p8txIQ3","y":"ALRaE4Q3SLQPNAW_AXIOke34SFwXq2a5FiMHWY9zpJcmCQk9VJH7bG3AnHY_hxu2R-zC5caLy6TPcSzr9Dy4F0DX","kty":"EC","kid":"xKnQ0Rm1_EMwHefKR9UOt0IwCspmyr93L_GDMO_xqq8","use":"enc"},{"crv":"Ed448","x":"sNcFa_zimfHYOSQNS52N-nOX-CYG4dFXoTeuWHnulTj6Fn3heSObBl2NY5ifB9qyP4MHgnAtiboA","kty":"OKP","kid":"MCsSgS9d92FbCGRyBo91MYcXOtXF9qoOeXz65UR5EF8","use":"sig"},{"e":"AQAB","n":"q18zoa2EagO8rzK9svtdY3U2T7DiyZ6F6RUQcpF0AvUK1z4mANLlfhtasJ01BKSP25xLbO8xF72bOd07sQazQUMumKNuU1p8kzYH5yvXNRrFPg-G6r6NWzhT3qx5ov1jkdc2zqa8yj25DfXP6btFFYqfQoPBaFwSXxHLDOXLBfa5wuLnJFL8Yt6qm5aKaOOEJ_X8CfwKH_ajBUD4MhospWZbe9gyt7gKO28sdo8VdNFCq-OG9FWWCwDgS9AYfXOHIHMNvim6sOSsT__6ETkDqUxqYYPgsANARfASBYZs7FiJMv88Hjpa5BH60gbbdYWrCkq1vGh8u1nu0R6WfsxX6w","kty":"RSA","kid":"9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4","use":"sig"},{"e":"AQAB","n":"xU_pU1APQpq581Q760Nd3UwDwKqjN62NPoXyPWxkTD15H2QDYkPMhbzY5J1TizMGGdegbeN--tnhBxMzIRxqcf83UBKvakYYJBr49dvXQSWqdpn8yG6STmO9kpG94vDQP49VBJ8YmXh6A5104_G2qXfQKe33cexKpJPKNedtDhUGUjOLzhYHjRIAGmWBsaLq5Dcbg1UtLEonzEznjKYPDUGhpE7Ao4eVeVEh0ZlFE3aocORW3xkT7uJFPq0pWBCHwD5PDPHtUQczDbbP4xn4Gr8r-vTHrxhv1WYH0NH61-YHqgG_csDat5ef3m0pJbzx7euitxxcr1bDuesB5g4fCQ","kty":"RSA","kid":"OVJpBKI4nfn-A3ZuYX6xkjNc7KhugIIm-y5Douaj6Sg","use":"enc"}]}
2021-03-27 15:39:36 SUCCESS
FetchServerKeys
Found server JWK set
server_jwks
{
  "keys": [
    {
      "crv": "P-256",
      "x": "pus2plcFzciOvQRrAfwm45u2NHw-IhjZe0gk55vO--o",
      "y": "McjUvdFc5nd2YEk9PLYw1HoHkYBBL42jtSoqAe4dCzM",
      "kty": "EC",
      "kid": "atDaXCMyhIUMZISEtmnBRX_C4BT7GoJUD4CMYWGbi_o",
      "use": "sig"
    },
    {
      "crv": "P-256",
      "x": "I8yVbnSd4WJjYH3age2eLK_S9sBtP8djG9y50X13yT0",
      "y": "29Jzh2o85AU1LOzK-SamLLHpXT0O439upvRMvvaeMQA",
      "kty": "EC",
      "kid": "g6MupPz7xKWQ0tKtZLcjBlnA2JAv1VH1NWYtPbsDa2o",
      "use": "enc"
    },
    {
      "crv": "secp256k1",
      "x": "65X_LqUa4XNR3ShA8hLtG-1YDKXEdWHagihJkSspdSQ",
      "y": "Mc8XQxxJnjSJjfcrd7hhlZMyQtHU4gANSFBzr1GsKKA",
      "kty": "EC",
      "kid": "cUJPqrATv3GVASHuCADHyW8p8C4wR5H_nTyaf5adzy0",
      "use": "sig"
    },
    {
      "crv": "P-384",
      "x": "rPUdhjvgdhRCox2456G0CIoKaTwZ8GnbYxwjf42QsT3VtPXi3p1c2RVs8XiDutrI",
      "y": "B_lZyUrqzwwiGHRIf5rGIXwzSgrRCoN2Hv01PPnMMeMzHVExMQCpIlkZrXO9bDKm",
      "kty": "EC",
      "kid": "6JVT-_BVPkvO-MljZhfaMeYC-LmZjlWj0SlzJLRA4yk",
      "use": "sig"
    },
    {
      "crv": "P-384",
      "x": "cIPV-GMwYobrMFKUHmgzvaliMUtDwO73Ht7X1AQPIpfBDIS7ovnZkt90DzcPn59P",
      "y": "4V2b3W7jRNZqANOc60LacK1pb62GVF5Dyn2Ra4wzbhRLGDVdD_UoazOW56TZ5tsl",
      "kty": "EC",
      "kid": "mIw-fa5LyZnypKpbddViJjWMjl8B5A-I5A31H_igCd8",
      "use": "enc"
    },
    {
      "crv": "P-521",
      "x": "AWyeRdPc35GRFdiu2dYhFgwcSJoUPw38qmUgG0VZSgsbdWWJxUv_iWWIux9hJono6f_qF-lq2At3xdGVBLR7BF5f",
      "y": "AY7WKdsbjyaMZ4Wh8o8Uy5Bju9WxD6N1A7r5_8o5OFIeqD_hej9FxuQDWC4rxU7Ls84yVVtPRG81TaXRoKBxr5XZ",
      "kty": "EC",
      "kid": "w1A1G94s-hK5YrIqWgmV30gtOZ85yQCP3ZMOPTzbc-0",
      "use": "sig"
    },
    {
      "crv": "Ed25519",
      "x": "kAdD9v4ErkCNxQdNMrf4IIplW6YUYBMWkECnLxnZ2tk",
      "kty": "OKP",
      "kid": "ONnNDJq5ZuIAcJyRHpZyZSDcVFf78F1eRhoElXlYEr8",
      "use": "sig"
    },
    {
      "crv": "P-521",
      "x": "AErKX164tyXiv5BwPMyrjoUGyXJ5hX1X7sRgvI0mnbfZhCRnKL67-q5PmTP31OkzA4xQGmAOyBIZvNSJ1p8txIQ3",
      "y": "ALRaE4Q3SLQPNAW_AXIOke34SFwXq2a5FiMHWY9zpJcmCQk9VJH7bG3AnHY_hxu2R-zC5caLy6TPcSzr9Dy4F0DX",
      "kty": "EC",
      "kid": "xKnQ0Rm1_EMwHefKR9UOt0IwCspmyr93L_GDMO_xqq8",
      "use": "enc"
    },
    {
      "crv": "Ed448",
      "x": "sNcFa_zimfHYOSQNS52N-nOX-CYG4dFXoTeuWHnulTj6Fn3heSObBl2NY5ifB9qyP4MHgnAtiboA",
      "kty": "OKP",
      "kid": "MCsSgS9d92FbCGRyBo91MYcXOtXF9qoOeXz65UR5EF8",
      "use": "sig"
    },
    {
      "e": "AQAB",
      "n": "q18zoa2EagO8rzK9svtdY3U2T7DiyZ6F6RUQcpF0AvUK1z4mANLlfhtasJ01BKSP25xLbO8xF72bOd07sQazQUMumKNuU1p8kzYH5yvXNRrFPg-G6r6NWzhT3qx5ov1jkdc2zqa8yj25DfXP6btFFYqfQoPBaFwSXxHLDOXLBfa5wuLnJFL8Yt6qm5aKaOOEJ_X8CfwKH_ajBUD4MhospWZbe9gyt7gKO28sdo8VdNFCq-OG9FWWCwDgS9AYfXOHIHMNvim6sOSsT__6ETkDqUxqYYPgsANARfASBYZs7FiJMv88Hjpa5BH60gbbdYWrCkq1vGh8u1nu0R6WfsxX6w",
      "kty": "RSA",
      "kid": "9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4",
      "use": "sig"
    },
    {
      "e": "AQAB",
      "n": "xU_pU1APQpq581Q760Nd3UwDwKqjN62NPoXyPWxkTD15H2QDYkPMhbzY5J1TizMGGdegbeN--tnhBxMzIRxqcf83UBKvakYYJBr49dvXQSWqdpn8yG6STmO9kpG94vDQP49VBJ8YmXh6A5104_G2qXfQKe33cexKpJPKNedtDhUGUjOLzhYHjRIAGmWBsaLq5Dcbg1UtLEonzEznjKYPDUGhpE7Ao4eVeVEh0ZlFE3aocORW3xkT7uJFPq0pWBCHwD5PDPHtUQczDbbP4xn4Gr8r-vTHrxhv1WYH0NH61-YHqgG_csDat5ef3m0pJbzx7euitxxcr1bDuesB5g4fCQ",
      "kty": "RSA",
      "kid": "OVJpBKI4nfn-A3ZuYX6xkjNc7KhugIIm-y5Douaj6Sg",
      "use": "enc"
    }
  ]
}
2021-03-27 15:39:36 SUCCESS
CheckServerKeysIsValid
Server JWKs is valid
server_jwks
{
  "keys": [
    {
      "crv": "P-256",
      "x": "pus2plcFzciOvQRrAfwm45u2NHw-IhjZe0gk55vO--o",
      "y": "McjUvdFc5nd2YEk9PLYw1HoHkYBBL42jtSoqAe4dCzM",
      "kty": "EC",
      "kid": "atDaXCMyhIUMZISEtmnBRX_C4BT7GoJUD4CMYWGbi_o",
      "use": "sig"
    },
    {
      "crv": "P-256",
      "x": "I8yVbnSd4WJjYH3age2eLK_S9sBtP8djG9y50X13yT0",
      "y": "29Jzh2o85AU1LOzK-SamLLHpXT0O439upvRMvvaeMQA",
      "kty": "EC",
      "kid": "g6MupPz7xKWQ0tKtZLcjBlnA2JAv1VH1NWYtPbsDa2o",
      "use": "enc"
    },
    {
      "crv": "secp256k1",
      "x": "65X_LqUa4XNR3ShA8hLtG-1YDKXEdWHagihJkSspdSQ",
      "y": "Mc8XQxxJnjSJjfcrd7hhlZMyQtHU4gANSFBzr1GsKKA",
      "kty": "EC",
      "kid": "cUJPqrATv3GVASHuCADHyW8p8C4wR5H_nTyaf5adzy0",
      "use": "sig"
    },
    {
      "crv": "P-384",
      "x": "rPUdhjvgdhRCox2456G0CIoKaTwZ8GnbYxwjf42QsT3VtPXi3p1c2RVs8XiDutrI",
      "y": "B_lZyUrqzwwiGHRIf5rGIXwzSgrRCoN2Hv01PPnMMeMzHVExMQCpIlkZrXO9bDKm",
      "kty": "EC",
      "kid": "6JVT-_BVPkvO-MljZhfaMeYC-LmZjlWj0SlzJLRA4yk",
      "use": "sig"
    },
    {
      "crv": "P-384",
      "x": "cIPV-GMwYobrMFKUHmgzvaliMUtDwO73Ht7X1AQPIpfBDIS7ovnZkt90DzcPn59P",
      "y": "4V2b3W7jRNZqANOc60LacK1pb62GVF5Dyn2Ra4wzbhRLGDVdD_UoazOW56TZ5tsl",
      "kty": "EC",
      "kid": "mIw-fa5LyZnypKpbddViJjWMjl8B5A-I5A31H_igCd8",
      "use": "enc"
    },
    {
      "crv": "P-521",
      "x": "AWyeRdPc35GRFdiu2dYhFgwcSJoUPw38qmUgG0VZSgsbdWWJxUv_iWWIux9hJono6f_qF-lq2At3xdGVBLR7BF5f",
      "y": "AY7WKdsbjyaMZ4Wh8o8Uy5Bju9WxD6N1A7r5_8o5OFIeqD_hej9FxuQDWC4rxU7Ls84yVVtPRG81TaXRoKBxr5XZ",
      "kty": "EC",
      "kid": "w1A1G94s-hK5YrIqWgmV30gtOZ85yQCP3ZMOPTzbc-0",
      "use": "sig"
    },
    {
      "crv": "Ed25519",
      "x": "kAdD9v4ErkCNxQdNMrf4IIplW6YUYBMWkECnLxnZ2tk",
      "kty": "OKP",
      "kid": "ONnNDJq5ZuIAcJyRHpZyZSDcVFf78F1eRhoElXlYEr8",
      "use": "sig"
    },
    {
      "crv": "P-521",
      "x": "AErKX164tyXiv5BwPMyrjoUGyXJ5hX1X7sRgvI0mnbfZhCRnKL67-q5PmTP31OkzA4xQGmAOyBIZvNSJ1p8txIQ3",
      "y": "ALRaE4Q3SLQPNAW_AXIOke34SFwXq2a5FiMHWY9zpJcmCQk9VJH7bG3AnHY_hxu2R-zC5caLy6TPcSzr9Dy4F0DX",
      "kty": "EC",
      "kid": "xKnQ0Rm1_EMwHefKR9UOt0IwCspmyr93L_GDMO_xqq8",
      "use": "enc"
    },
    {
      "crv": "Ed448",
      "x": "sNcFa_zimfHYOSQNS52N-nOX-CYG4dFXoTeuWHnulTj6Fn3heSObBl2NY5ifB9qyP4MHgnAtiboA",
      "kty": "OKP",
      "kid": "MCsSgS9d92FbCGRyBo91MYcXOtXF9qoOeXz65UR5EF8",
      "use": "sig"
    },
    {
      "e": "AQAB",
      "n": "q18zoa2EagO8rzK9svtdY3U2T7DiyZ6F6RUQcpF0AvUK1z4mANLlfhtasJ01BKSP25xLbO8xF72bOd07sQazQUMumKNuU1p8kzYH5yvXNRrFPg-G6r6NWzhT3qx5ov1jkdc2zqa8yj25DfXP6btFFYqfQoPBaFwSXxHLDOXLBfa5wuLnJFL8Yt6qm5aKaOOEJ_X8CfwKH_ajBUD4MhospWZbe9gyt7gKO28sdo8VdNFCq-OG9FWWCwDgS9AYfXOHIHMNvim6sOSsT__6ETkDqUxqYYPgsANARfASBYZs7FiJMv88Hjpa5BH60gbbdYWrCkq1vGh8u1nu0R6WfsxX6w",
      "kty": "RSA",
      "kid": "9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4",
      "use": "sig"
    },
    {
      "e": "AQAB",
      "n": "xU_pU1APQpq581Q760Nd3UwDwKqjN62NPoXyPWxkTD15H2QDYkPMhbzY5J1TizMGGdegbeN--tnhBxMzIRxqcf83UBKvakYYJBr49dvXQSWqdpn8yG6STmO9kpG94vDQP49VBJ8YmXh6A5104_G2qXfQKe33cexKpJPKNedtDhUGUjOLzhYHjRIAGmWBsaLq5Dcbg1UtLEonzEznjKYPDUGhpE7Ao4eVeVEh0ZlFE3aocORW3xkT7uJFPq0pWBCHwD5PDPHtUQczDbbP4xn4Gr8r-vTHrxhv1WYH0NH61-YHqgG_csDat5ef3m0pJbzx7euitxxcr1bDuesB5g4fCQ",
      "kty": "RSA",
      "kid": "OVJpBKI4nfn-A3ZuYX6xkjNc7KhugIIm-y5Douaj6Sg",
      "use": "enc"
    }
  ]
}
2021-03-27 15:39:36 SUCCESS
ValidateServerJWKs
Valid server JWKs: keys are valid JSON, contain the required fields and are correctly encoded using unpadded base64url
2021-03-27 15:39:36 SUCCESS
CheckForKeyIdInServerJWKs
All keys contain kids
2021-03-27 15:39:36 SUCCESS
CheckDistinctKeyIdValueInServerJWKs
Distinct 'kid' value in all keys of server_jwks
see
https://bitbucket.org/openid/connect/issues/1127
2021-03-27 15:39:36 SUCCESS
EnsureServerJwksDoesNotContainPrivateOrSymmetricKeys
Jwks does not contain any private or symmetric keys
2021-03-27 15:39:36 SUCCESS
GetDynamicClientConfiguration
Created dynamic_client_registration_template object from the client configuration.
client_name
first-openid-client
2021-03-27 15:39:36 SUCCESS
GenerateRS256ClientJWKs
Generated client JWKs
client_jwks
{
  "keys": [
    {
      "p": "6qSB89LVHPOUIhvbQizY-o5f45gtGQD5ku4bOhwir5vEmfMr0OtE5gPVX5AgB8KFTc8CK9XCEN00XD2sF4EsZXI7XwgHd7nY5TXl9PmY1C-6dvYLsR1Qh_6b191n4yDkclY8FWfh84hIL3Agizon0F_DFhaoY3S0VwbZwJlXBtM",
      "kty": "RSA",
      "q": "qusS_XXg-WU-CCBE85evkLb5nw5_fZ0rmdJVg3AK5t9sMF7PzaEWawDh4qC8fEsV7kRTyJqQ-5jVkXP0SJp-vaa93vl7t4DDlQbubVX0qJR1QU_fAPhZntfCmi2rXu05lzWs5ejc77dby-Z6LGg5Cux4ZZ9qiXLWjLeRf_jueNU",
      "d": "lZ8nomon6UGloerbQYNYpGTDCcUW00Uu2rO63BH6Cpaov-P9pWeXfzne_ccDKl3GmMDtIfePITIqzY8O9nPj-c36dGNmLP2i9PnGoXzNGg2QShlYcC73L_c_FDAESziMXIdpmhqIpicMhWm1Yq9HULm-vSf-9lA7x04SbHeio_Nhkqb9tTrXMq70q4_V6kybmjyoTg04GwTp9SpEWiwJT4whVzdhde02QgvwUew8UCTpFnNqmvERcaqousTFCkD1TMXD1_tLo7aLwkgyUSxA7TsJwjVgHCJVQbbdsPsFBLLIRJ17I7FTaKIJyHcp9GlNZVNhMf-TKrcONFgnuYMp6Q",
      "e": "AQAB",
      "use": "sig",
      "qi": "uzMAjPovr2j1IHJypWJMj2-HNvkaeUGWkuprsCkid23sNEpDdRHJsn-26_le3kfZMZuixG--LxhxQy5usLpLFqVBb7JbbNtY5mDbCc5bJ2KY_esdVtX2wwAJcqaA-6yew68s9VAPqV8EKMG5Z7uRGvew8e_HaWJHMTJtKiesLpU",
      "dp": "1rCGps01aTQFSeArEbVvInG6ksfeG46kzCdIijbMFdl0XVf9sz5Q4BSJ2tJIPFFjHvpVhj4jPsLm8a8MEsWCFaAbaqwyCP3m0nIqYacuipbRCZ--uuOTl5sChNR0BYFHBMaaWwud1fHP-nehj0I6w5GbMk6w668QgsAl5O9ojTk",
      "alg": "RS256",
      "dq": "FiRB34fnzycodBEKHaxm2A58I_jS10kHHvQ6k75uCx6ie1ms_eyCZPZGTP-Zq1hmzOkZGYG8intwH1mwKb-p75OsQTh8qHcL30B4nr1l5njk_8MDFrMVmRhGY4bLDo8YyNfxQA98n6lXQQDojtwpl5qutiuCt6-iz7PwK23qJsk",
      "n": "nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"
    }
  ]
}
public_client_jwks
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "use": "sig",
      "alg": "RS256",
      "n": "nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"
    }
  ]
}
2021-03-27 15:39:36 SUCCESS
CheckDistinctKeyIdValueInClientJWKs
Distinct 'kid' value in all keys of client_jwks
see
https://bitbucket.org/openid/connect/issues/1127
2021-03-27 15:39:36 SUCCESS
CreateDynamicRegistrationRequest
Created dynamic registration request
client_name
first-openid-client FzzfewOGAxLVkWf
2021-03-27 15:39:36
AddAuthorizationCodeGrantTypeToDynamicRegistrationRequest
Added 'authorization_code' to 'grant_types'
grant_types
[
  "authorization_code"
]
2021-03-27 15:39:36
AddImplicitGrantTypeToDynamicRegistrationRequest
Added 'implicit' to 'grant_types'
grant_types
[
  "authorization_code",
  "implicit"
]
2021-03-27 15:39:36
AddPublicJwksToDynamicRegistrationRequest
Added client public JWKS to dynamic registration request
dynamic_registration_request
{
  "client_name": "first-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"
      }
    ]
  }
}
2021-03-27 15:39:36
AddTokenEndpointAuthMethodToDynamicRegistrationRequestFromEnvironment
Added token endpoint auth method to dynamic registration request
dynamic_registration_request
{
  "client_name": "first-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"
      }
    ]
  },
  "token_endpoint_auth_method": "client_secret_basic"
}
2021-03-27 15:39:36
AddResponseTypesArrayToDynamicRegistrationRequestFromEnvironment
Added response_types array to dynamic registration request
dynamic_registration_request
{
  "client_name": "first-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"
      }
    ]
  },
  "token_endpoint_auth_method": "client_secret_basic",
  "response_types": [
    "code id_token"
  ]
}
2021-03-27 15:39:36
AddRedirectUriToDynamicRegistrationRequest
Added redirect_uris array to dynamic registration request
dynamic_registration_request
{
  "client_name": "first-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"
      }
    ]
  },
  "token_endpoint_auth_method": "client_secret_basic",
  "response_types": [
    "code id_token"
  ],
  "redirect_uris": [
    "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"
  ]
}
2021-03-27 15:39:36
AddContactsToDynamicRegistrationRequest
Added contacts array to dynamic registration request
dynamic_registration_request
{
  "client_name": "first-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"
      }
    ]
  },
  "token_endpoint_auth_method": "client_secret_basic",
  "response_types": [
    "code id_token"
  ],
  "redirect_uris": [
    "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"
  ],
  "contacts": [
    "certification@oidf.org"
  ]
}
2021-03-27 15:39:36
AddRefreshTokenGrantTypeToDynamicRegistrationRequest
Added 'refresh_token' to 'grant_types'
grant_types
[
  "authorization_code",
  "implicit",
  "refresh_token"
]
2021-03-27 15:39:36
CallDynamicRegistrationEndpoint
HTTP request
request_uri
https://certification.plusauth.com/oauth/reg
request_method
POST
request_headers
{
  "accept": "application/json",
  "accept-charset": "utf-8",
  "content-type": "application/json",
  "content-length": "771"
}
request_body
{"client_name":"first-openid-client FzzfewOGAxLVkWf","grant_types":["authorization_code","implicit","refresh_token"],"jwks":{"keys":[{"kty":"RSA","e":"AQAB","use":"sig","alg":"RS256","n":"nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"}]},"token_endpoint_auth_method":"client_secret_basic","response_types":["code id_token"],"redirect_uris":["https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"],"contacts":["certification@oidf.org"]}
2021-03-27 15:39:36 RESPONSE
CallDynamicRegistrationEndpoint
HTTP response
response_status_code
201 CREATED
response_status_text
Created
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "1778",
  "date": "Sat, 27 Mar 2021 15:39:36 GMT",
  "x-envoy-upstream-service-time": "10",
  "server": "istio-envoy"
}
response_body
{"application_type":"web","grant_types":["authorization_code","implicit","refresh_token"],"id_token_signed_response_alg":"RS256","oidc_conformant":true,"post_logout_redirect_uris":[],"require_auth_time":false,"response_types":["code id_token"],"subject_type":"public","token_endpoint_auth_method":"client_secret_basic","introspection_endpoint_auth_method":"client_secret_basic","introspection_signed_response_alg":"RS256","revocation_endpoint_auth_method":"client_secret_basic","backchannel_logout_session_required":false,"frontchannel_logout_session_required":false,"require_signed_request_object":false,"request_uris":[],"require_pushed_authorization_requests":false,"authorization_signed_response_alg":"RS256","web_message_uris":[],"tls_client_certificate_bound_access_tokens":false,"client_id_issued_at":1616859576,"client_id":"Eg2iyh1FSLv40rz_yIsx7","client_name":"first-openid-client FzzfewOGAxLVkWf","client_secret_expires_at":0,"client_secret":"bUfeIXTA1u136g79uK224lNFhGMrehBAlrGk1DbKqrNmZUdr-G-BzZowU8taSHPiK54x5AdeLiCmlFteE35NUg","contacts":["certification@oidf.org"],"jwks":{"keys":[{"kty":"RSA","e":"AQAB","use":"sig","alg":"RS256","n":"nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"}]},"redirect_uris":["https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"],"registration_client_uri":"https://certification.plusauth.com/oauth/reg/Eg2iyh1FSLv40rz_yIsx7","registration_access_token":"sNqu02Xgn2-tOX8FFcc17pqd6TN3y7zLW6EpJTtORDN"}
2021-03-27 15:39:36
CallDynamicRegistrationEndpoint
Registration endpoint response
dynamic_registration_response
{"application_type":"web","grant_types":["authorization_code","implicit","refresh_token"],"id_token_signed_response_alg":"RS256","oidc_conformant":true,"post_logout_redirect_uris":[],"require_auth_time":false,"response_types":["code id_token"],"subject_type":"public","token_endpoint_auth_method":"client_secret_basic","introspection_endpoint_auth_method":"client_secret_basic","introspection_signed_response_alg":"RS256","revocation_endpoint_auth_method":"client_secret_basic","backchannel_logout_session_required":false,"frontchannel_logout_session_required":false,"require_signed_request_object":false,"request_uris":[],"require_pushed_authorization_requests":false,"authorization_signed_response_alg":"RS256","web_message_uris":[],"tls_client_certificate_bound_access_tokens":false,"client_id_issued_at":1616859576,"client_id":"Eg2iyh1FSLv40rz_yIsx7","client_name":"first-openid-client FzzfewOGAxLVkWf","client_secret_expires_at":0,"client_secret":"bUfeIXTA1u136g79uK224lNFhGMrehBAlrGk1DbKqrNmZUdr-G-BzZowU8taSHPiK54x5AdeLiCmlFteE35NUg","contacts":["certification@oidf.org"],"jwks":{"keys":[{"kty":"RSA","e":"AQAB","use":"sig","alg":"RS256","n":"nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"}]},"redirect_uris":["https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"],"registration_client_uri":"https://certification.plusauth.com/oauth/reg/Eg2iyh1FSLv40rz_yIsx7","registration_access_token":"sNqu02Xgn2-tOX8FFcc17pqd6TN3y7zLW6EpJTtORDN"}
2021-03-27 15:39:36
CallDynamicRegistrationEndpoint
Parsed registration endpoint response
application_type
web
grant_types
[
  "authorization_code",
  "implicit",
  "refresh_token"
]
id_token_signed_response_alg
RS256
oidc_conformant
true
post_logout_redirect_uris
[]
require_auth_time
false
response_types
[
  "code id_token"
]
subject_type
public
token_endpoint_auth_method
client_secret_basic
introspection_endpoint_auth_method
client_secret_basic
introspection_signed_response_alg
RS256
revocation_endpoint_auth_method
client_secret_basic
backchannel_logout_session_required
false
frontchannel_logout_session_required
false
require_signed_request_object
false
request_uris
[]
require_pushed_authorization_requests
false
authorization_signed_response_alg
RS256
web_message_uris
[]
tls_client_certificate_bound_access_tokens
false
client_id_issued_at
1616859576
client_id
Eg2iyh1FSLv40rz_yIsx7
client_name
first-openid-client FzzfewOGAxLVkWf
client_secret_expires_at
0
client_secret
bUfeIXTA1u136g79uK224lNFhGMrehBAlrGk1DbKqrNmZUdr-G-BzZowU8taSHPiK54x5AdeLiCmlFteE35NUg
contacts
[
  "certification@oidf.org"
]
jwks
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "use": "sig",
      "alg": "RS256",
      "n": "nKi0txaXBZKfevcb9tlndAyDR73gb324avhSScss1PTeXvJAfL9YosjAD5lUpXtV1lJjAyXhlRIGNRYmJhKJiM2ohsMXWdWN_fdaMR4Xh1eSD81LogLmuVtPxX6B0aX6shk19M1oIMA0RV_Cq1RH5pTYnRzrlqgpSjX8Wp_jMGCwa2JgVId_KlkPWp5CUO0IZrQ27_i_TiFVk9tumgxuz7oRXQyO9XIaJjFOo9beXkGeDyAN2MaAFw4W7RAqDUFxlw_USOC_dsIecFRjdibLS3CRx6Qnc22BBB6Eh2-iAN19eQFmzZvJ2JGATKQgNztY5LhExuxmKuJGPzhSIMWVjw"
    }
  ]
}
redirect_uris
[
  "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"
]
registration_client_uri
https://certification.plusauth.com/oauth/reg/Eg2iyh1FSLv40rz_yIsx7
registration_access_token
sNqu02Xgn2-tOX8FFcc17pqd6TN3y7zLW6EpJTtORDN
2021-03-27 15:39:36 SUCCESS
CallDynamicRegistrationEndpoint
Extracted dynamic registration management credentials
registration_client_uri
https://certification.plusauth.com/oauth/reg/Eg2iyh1FSLv40rz_yIsx7
registration_access_token
sNqu02Xgn2-tOX8FFcc17pqd6TN3y7zLW6EpJTtORDN
2021-03-27 15:39:36
SetScopeInClientConfigurationToOpenId
Set scope in client configuration to "openid"
scope
openid
2021-03-27 15:39:36
SetScopeInClientConfigurationToOpenIdOfflineAccessIfServerSupportsOfflineAccess
Set scope in client configuration to "openid offline_access"as 'scope_supported' contains 'offline_access'
scope
openid offline_access
2021-03-27 15:39:36 SUCCESS
EnsureServerConfigurationSupportsClientSecretBasic
Contents of 'token_endpoint_auth_methods_supported' in discovery document matches expectations.
actual
[
  "none",
  "client_secret_basic",
  "client_secret_jwt",
  "client_secret_post",
  "private_key_jwt",
  "tls_client_auth",
  "self_signed_tls_client_auth"
]
expected
[
  "client_secret_basic"
]
minimum_matches_required
1
2021-03-27 15:39:36 SUCCESS
GetDynamicClient2Configuration
Found a dynamic_client_registration_template object
client_name
second-openid-client
2021-03-27 15:39:36 SUCCESS
GenerateRS256ClientJWKs
Generated client JWKs
client_jwks
{
  "keys": [
    {
      "p": "-4zXKhXlYQhOzPueXpScfzaXBW8N7uN1nyVuFWR-Z_oZQGahRpXsDw061PL1-VsVypyI7d9nY_KAZTtAKsUNNfByiT1BzaJ0l-HIbBUyuIOoj05LOFB2uYS86S9xg0-pAPQ3LljMzn3BeKxS08iARW9C8K5Jp-MihRzeiD57lMU",
      "kty": "RSA",
      "q": "rUpP3pdZutqLhu4AOlnE9bb-IBKuUgkJLxwUjGgfjFaiZY9zbyLUlGhSLYNgTpG0osdBFVt7h7eZrr3E5DC0ld-eQf5NfwTspyP374ZHcKlIkYmC8536lv4QFXLtcHvMMgUlRRFKNf7yiUeeSpkcj126fMmOxluMWL31FNvTe-s",
      "d": "T1NZ0-3ium3yKeRA05BQOXAxxu4HdD2BLHEKgXp8en-SoLffsOGyp17_08ByoHzrIMJBm59L0PaLtAYibpD0PAUnmB5R7kV2IVm011T3OVWyuUtAs1Q59sVAvTzMiesmSqVglM34-6Cjy9ld_Udiimy-hhXMBH7LBo6JhJ2sZJ805xsRt7FYUDASRMYL85Kmuda3wEFcSaISJ3a6S9oLz0-QAMT4zVQazGSqBkcNgFJ3LZ0Oh6ybGX2RM9XPfho3jeXwhqoK1zAaUqXZAlPQJ9Ijo6TJ3g1VYdTX6yyOnAcTNL6FRbd-ML6_x-suSG9V5AfwdSW5lC794eIxcrjXeQ",
      "e": "AQAB",
      "use": "sig",
      "qi": "AshpkYbAVuxi5fDazKnEF1-kyJUAkja_4XGxK-ex-ueY3Pti2CDQGsoz7HgtypPFLmER_O_y_9DR0kJPU7ab73pBOp-LOW5Cy_qoljfZIWqvSJdIc6GZ-ZKgQniQ6KSbN71BfBi67mgWznBzM0O9AoubMwrkZzmqKjPFTpgQzGU",
      "dp": "-xvXVm3RMxHmB_5OU8AqkVtfWs9Hq2do7VuiDrzo6sbhGkbZS-sxYL0mM5nuLePdVwr4Le1L-pwDzApfvdJDo8rJq3J5E9vOZCfBuRNYNJVJWPUhZa_9NKjrJCR2PkzxOsCPrTZ8DM3AqsPrUvreAXJV8okpgezdcuAkzQECwLk",
      "alg": "RS256",
      "dq": "Idppnf-NTP6S0Wo_aybMXoBARv2_RlFzlNt0fDV_LEhkc1jB4U05oEB9BV0r_E1kr4Qjh8uWZ14LzOJPy5BkRv8niJbohs7seH6DWiyuWikH_z6Q8YzEPqkldTs9fYMB0ifFLygAimni8cSm_MXKmYti-ivaE5Ag69k4PrnvJ78",
      "n": "qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"
    }
  ]
}
public_client_jwks
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "use": "sig",
      "alg": "RS256",
      "n": "qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"
    }
  ]
}
2021-03-27 15:39:36 SUCCESS
CheckDistinctKeyIdValueInClientJWKs
Distinct 'kid' value in all keys of client_jwks
see
https://bitbucket.org/openid/connect/issues/1127
2021-03-27 15:39:36 SUCCESS
CreateDynamicRegistrationRequest
Created dynamic registration request
client_name
second-openid-client FzzfewOGAxLVkWf
2021-03-27 15:39:36
AddAuthorizationCodeGrantTypeToDynamicRegistrationRequest
Added 'authorization_code' to 'grant_types'
grant_types
[
  "authorization_code"
]
2021-03-27 15:39:36
AddImplicitGrantTypeToDynamicRegistrationRequest
Added 'implicit' to 'grant_types'
grant_types
[
  "authorization_code",
  "implicit"
]
2021-03-27 15:39:36
AddPublicJwksToDynamicRegistrationRequest
Added client public JWKS to dynamic registration request
dynamic_registration_request
{
  "client_name": "second-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"
      }
    ]
  }
}
2021-03-27 15:39:36
AddTokenEndpointAuthMethodToDynamicRegistrationRequestFromEnvironment
Added token endpoint auth method to dynamic registration request
dynamic_registration_request
{
  "client_name": "second-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"
      }
    ]
  },
  "token_endpoint_auth_method": "client_secret_basic"
}
2021-03-27 15:39:36
AddResponseTypesArrayToDynamicRegistrationRequestFromEnvironment
Added response_types array to dynamic registration request
dynamic_registration_request
{
  "client_name": "second-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"
      }
    ]
  },
  "token_endpoint_auth_method": "client_secret_basic",
  "response_types": [
    "code id_token"
  ]
}
2021-03-27 15:39:36
AddRedirectUriToDynamicRegistrationRequest
Added redirect_uris array to dynamic registration request
dynamic_registration_request
{
  "client_name": "second-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"
      }
    ]
  },
  "token_endpoint_auth_method": "client_secret_basic",
  "response_types": [
    "code id_token"
  ],
  "redirect_uris": [
    "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"
  ]
}
2021-03-27 15:39:36
AddContactsToDynamicRegistrationRequest
Added contacts array to dynamic registration request
dynamic_registration_request
{
  "client_name": "second-openid-client FzzfewOGAxLVkWf",
  "grant_types": [
    "authorization_code",
    "implicit"
  ],
  "jwks": {
    "keys": [
      {
        "kty": "RSA",
        "e": "AQAB",
        "use": "sig",
        "alg": "RS256",
        "n": "qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"
      }
    ]
  },
  "token_endpoint_auth_method": "client_secret_basic",
  "response_types": [
    "code id_token"
  ],
  "redirect_uris": [
    "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"
  ],
  "contacts": [
    "certification@oidf.org"
  ]
}
2021-03-27 15:39:36
AddRefreshTokenGrantTypeToDynamicRegistrationRequest
Added 'refresh_token' to 'grant_types'
grant_types
[
  "authorization_code",
  "implicit",
  "refresh_token"
]
2021-03-27 15:39:36
CallDynamicRegistrationEndpoint
HTTP request
request_uri
https://certification.plusauth.com/oauth/reg
request_method
POST
request_headers
{
  "accept": "application/json",
  "accept-charset": "utf-8",
  "content-type": "application/json",
  "content-length": "772"
}
request_body
{"client_name":"second-openid-client FzzfewOGAxLVkWf","grant_types":["authorization_code","implicit","refresh_token"],"jwks":{"keys":[{"kty":"RSA","e":"AQAB","use":"sig","alg":"RS256","n":"qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"}]},"token_endpoint_auth_method":"client_secret_basic","response_types":["code id_token"],"redirect_uris":["https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"],"contacts":["certification@oidf.org"]}
2021-03-27 15:39:37 RESPONSE
CallDynamicRegistrationEndpoint
HTTP response
response_status_code
201 CREATED
response_status_text
Created
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "1779",
  "date": "Sat, 27 Mar 2021 15:39:37 GMT",
  "x-envoy-upstream-service-time": "11",
  "server": "istio-envoy"
}
response_body
{"application_type":"web","grant_types":["authorization_code","implicit","refresh_token"],"id_token_signed_response_alg":"RS256","oidc_conformant":true,"post_logout_redirect_uris":[],"require_auth_time":false,"response_types":["code id_token"],"subject_type":"public","token_endpoint_auth_method":"client_secret_basic","introspection_endpoint_auth_method":"client_secret_basic","introspection_signed_response_alg":"RS256","revocation_endpoint_auth_method":"client_secret_basic","backchannel_logout_session_required":false,"frontchannel_logout_session_required":false,"require_signed_request_object":false,"request_uris":[],"require_pushed_authorization_requests":false,"authorization_signed_response_alg":"RS256","web_message_uris":[],"tls_client_certificate_bound_access_tokens":false,"client_id_issued_at":1616859577,"client_id":"XAWhFzWUWotR7pbibc546","client_name":"second-openid-client FzzfewOGAxLVkWf","client_secret_expires_at":0,"client_secret":"JSv4F3ZuFgULG3l2YjrN9y3DsSI8W926fQpqD7YtRMpK7AapI6SD0pPIGvdCeWGGou0Nrcg5w0JVuqR2fPM4cw","contacts":["certification@oidf.org"],"jwks":{"keys":[{"kty":"RSA","e":"AQAB","use":"sig","alg":"RS256","n":"qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"}]},"redirect_uris":["https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"],"registration_client_uri":"https://certification.plusauth.com/oauth/reg/XAWhFzWUWotR7pbibc546","registration_access_token":"S3qVwhx0Qxn4oQW42Omn-x7mvpyQcZkpPhJr4xZYmEr"}
2021-03-27 15:39:37
CallDynamicRegistrationEndpoint
Registration endpoint response
dynamic_registration_response
{"application_type":"web","grant_types":["authorization_code","implicit","refresh_token"],"id_token_signed_response_alg":"RS256","oidc_conformant":true,"post_logout_redirect_uris":[],"require_auth_time":false,"response_types":["code id_token"],"subject_type":"public","token_endpoint_auth_method":"client_secret_basic","introspection_endpoint_auth_method":"client_secret_basic","introspection_signed_response_alg":"RS256","revocation_endpoint_auth_method":"client_secret_basic","backchannel_logout_session_required":false,"frontchannel_logout_session_required":false,"require_signed_request_object":false,"request_uris":[],"require_pushed_authorization_requests":false,"authorization_signed_response_alg":"RS256","web_message_uris":[],"tls_client_certificate_bound_access_tokens":false,"client_id_issued_at":1616859577,"client_id":"XAWhFzWUWotR7pbibc546","client_name":"second-openid-client FzzfewOGAxLVkWf","client_secret_expires_at":0,"client_secret":"JSv4F3ZuFgULG3l2YjrN9y3DsSI8W926fQpqD7YtRMpK7AapI6SD0pPIGvdCeWGGou0Nrcg5w0JVuqR2fPM4cw","contacts":["certification@oidf.org"],"jwks":{"keys":[{"kty":"RSA","e":"AQAB","use":"sig","alg":"RS256","n":"qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"}]},"redirect_uris":["https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"],"registration_client_uri":"https://certification.plusauth.com/oauth/reg/XAWhFzWUWotR7pbibc546","registration_access_token":"S3qVwhx0Qxn4oQW42Omn-x7mvpyQcZkpPhJr4xZYmEr"}
2021-03-27 15:39:37
CallDynamicRegistrationEndpoint
Parsed registration endpoint response
application_type
web
grant_types
[
  "authorization_code",
  "implicit",
  "refresh_token"
]
id_token_signed_response_alg
RS256
oidc_conformant
true
post_logout_redirect_uris
[]
require_auth_time
false
response_types
[
  "code id_token"
]
subject_type
public
token_endpoint_auth_method
client_secret_basic
introspection_endpoint_auth_method
client_secret_basic
introspection_signed_response_alg
RS256
revocation_endpoint_auth_method
client_secret_basic
backchannel_logout_session_required
false
frontchannel_logout_session_required
false
require_signed_request_object
false
request_uris
[]
require_pushed_authorization_requests
false
authorization_signed_response_alg
RS256
web_message_uris
[]
tls_client_certificate_bound_access_tokens
false
client_id_issued_at
1616859577
client_id
XAWhFzWUWotR7pbibc546
client_name
second-openid-client FzzfewOGAxLVkWf
client_secret_expires_at
0
client_secret
JSv4F3ZuFgULG3l2YjrN9y3DsSI8W926fQpqD7YtRMpK7AapI6SD0pPIGvdCeWGGou0Nrcg5w0JVuqR2fPM4cw
contacts
[
  "certification@oidf.org"
]
jwks
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "use": "sig",
      "alg": "RS256",
      "n": "qkcymNI3KJ0jbMfz7JcPmi1SgjdX_DfSZwCNjv8RpElClkum9V8FvGGPaeDyB7oiNTBTS3amefQMdvsMX6Zny_VDmf0D7_8ZCSnRND6sbhXAP9ezuAgYCh9WtmsftZs7Vp8wirU_JLsuHN7i9-uKDl2iTA3NbLNVKQHJX5-MX9wKcYs1AX2GvVmuiRYp_thoYUPCUB1FjV8VcKHuUQjXrOuA76yzH_hXMbIOxVT_B5SMzOVj_WAyoHkiogjifFL8jiXCfgPYfbb4MWV2YcEALbljoqx38Hta2daPTKfmOXcfCICDt3jtbjrzV_T17eF5EqI4dZuyRVy8pB2a4Us31w"
    }
  ]
}
redirect_uris
[
  "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback"
]
registration_client_uri
https://certification.plusauth.com/oauth/reg/XAWhFzWUWotR7pbibc546
registration_access_token
S3qVwhx0Qxn4oQW42Omn-x7mvpyQcZkpPhJr4xZYmEr
2021-03-27 15:39:37 SUCCESS
CallDynamicRegistrationEndpoint
Extracted dynamic registration management credentials
registration_client_uri
https://certification.plusauth.com/oauth/reg/XAWhFzWUWotR7pbibc546
registration_access_token
S3qVwhx0Qxn4oQW42Omn-x7mvpyQcZkpPhJr4xZYmEr
2021-03-27 15:39:37
SetScopeInClientConfigurationToOpenId
Set scope in client configuration to "openid"
scope
openid
2021-03-27 15:39:37
SetScopeInClientConfigurationToOpenIdOfflineAccessIfServerSupportsOfflineAccess
Set scope in client configuration to "openid offline_access"as 'scope_supported' contains 'offline_access'
scope
openid offline_access
2021-03-27 15:39:37 SUCCESS
EnsureServerConfigurationSupportsClientSecretBasic
Contents of 'token_endpoint_auth_methods_supported' in discovery document matches expectations.
actual
[
  "none",
  "client_secret_basic",
  "client_secret_jwt",
  "client_secret_post",
  "private_key_jwt",
  "tls_client_auth",
  "self_signed_tls_client_auth"
]
expected
[
  "client_secret_basic"
]
minimum_matches_required
1
2021-03-27 15:39:37 SUCCESS
SetProtectedResourceUrlToUserInfoEndpoint
userinfo_endpoint will be used to test access token. The user info is not a mandatory to implement feature in the OpenID Connect specification, but is mandatory for certification.
protected_resource_url
https://certification.plusauth.com/me
2021-03-27 15:39:37
oidcc-refresh-token
Setup Done
Make request to authorization endpoint
2021-03-27 15:39:37 SUCCESS
CreateAuthorizationEndpointRequestFromClientInformation
Created authorization endpoint request
client_id
Eg2iyh1FSLv40rz_yIsx7
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
2021-03-27 15:39:37
CreateRandomStateValue
Created state value
requested_state_length
10
state
TYjGwLd4HC
2021-03-27 15:39:37 SUCCESS
AddStateToAuthorizationEndpointRequest
Added state parameter to request
client_id
Eg2iyh1FSLv40rz_yIsx7
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
state
TYjGwLd4HC
2021-03-27 15:39:37
CreateRandomNonceValue
Created nonce value
requested_nonce_length
10
nonce
IZjxBfBMa3
2021-03-27 15:39:37 SUCCESS
AddNonceToAuthorizationEndpointRequest
Added nonce parameter to request
client_id
Eg2iyh1FSLv40rz_yIsx7
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
state
TYjGwLd4HC
nonce
IZjxBfBMa3
2021-03-27 15:39:37 SUCCESS
SetAuthorizationEndpointRequestResponseTypeFromEnvironment
Added response_type parameter to request
client_id
Eg2iyh1FSLv40rz_yIsx7
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
state
TYjGwLd4HC
nonce
IZjxBfBMa3
response_type
code id_token
2021-03-27 15:39:37 SUCCESS
AddPromptConsentToAuthorizationEndpointRequestIfScopeContainsOfflineAccess
Added prompt=consent to authorization endpoint request
client_id
Eg2iyh1FSLv40rz_yIsx7
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
state
TYjGwLd4HC
nonce
IZjxBfBMa3
response_type
code id_token
prompt
consent
2021-03-27 15:39:37 SUCCESS
BuildPlainRedirectToAuthorizationEndpoint
Sending to authorization endpoint
redirect_to_authorization_endpoint
https://certification.plusauth.com/oauth/auth?client_id=Eg2iyh1FSLv40rz_yIsx7&redirect_uri=https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback&scope=openid%20offline_access&state=TYjGwLd4HC&nonce=IZjxBfBMa3&response_type=code%20id_token&prompt=consent
2021-03-27 15:39:37 REDIRECT
oidcc-refresh-token
Redirecting to authorization endpoint
redirect_to
https://certification.plusauth.com/oauth/auth?client_id=Eg2iyh1FSLv40rz_yIsx7&redirect_uri=https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback&scope=openid%20offline_access&state=TYjGwLd4HC&nonce=IZjxBfBMa3&response_type=code%20id_token&prompt=consent
2021-03-27 15:39:37
WebRunner
Scripted browser HTTP request
browser
goToUrl
request_method
GET
request_uri
https://certification.plusauth.com/oauth/auth?client_id=Eg2iyh1FSLv40rz_yIsx7&redirect_uri=https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback&scope=openid%20offline_access&state=TYjGwLd4HC&nonce=IZjxBfBMa3&response_type=code%20id_token&prompt=consent
2021-03-27 15:39:37 RESPONSE
WebRunner
Scripted browser HTTP response
response_content
<!DOCTYPE html>
<html lang="en" >
<head><script>var PlusAuth = window.PlusAuth = {"client":{"clientName":"first-openid-client FzzfewOGAxLVkWf","applicationType":"web","social":[]},"details":{},"params":{"client_id":"Eg2iyh1FSLv40rz_yIsx7","nonce":"IZjxBfBMa3","prompt":"consent","redirect_uri":"https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback","response_type":"code id_token","scope":"openid offline_access","state":"TYjGwLd4HC"},"prompt":{"name":"login"},"settings":{}} </script>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  <meta http-equiv="x-ua-compatible" content="ie=edge">
  <title>Sign-in</title>
</head>
<body >
<div class="login-card">
  <h1>Login</h1>
  <form autocomplete="off" action="/signin" method="post">
    <input type="hidden" name="provider" value="google">
    <input required type="text" name="username" placeholder="Username" >
    <input required type="password" name="password" placeholder="Password">
    <button type="submit" class="login login-submit">Sign-in</button>
    <button type="submit" class="google-button">
        <span class="google-button__text">Sign in with Google</span>
    </button>
  </form>
</div>
</body >
</html >
response_content_type
text/html
response_status_text
200-OK
response_status_code
200
2021-03-27 15:39:37 INFO
WebRunner
Entering text
task
Login
browser
text
element_type
name
value
foo
url
https://certification.plusauth.com/signin
target
username
2021-03-27 15:39:37 INFO
WebRunner
Entering text
task
Login
browser
text
element_type
name
value
bar
url
https://certification.plusauth.com/signin
target
password
2021-03-27 15:39:37 INFO
WebRunner
Clicking an element
task
Login
browser
click
element_type
class
url
https://certification.plusauth.com/signin
target
login-submit
2021-03-27 15:39:38 INFO
WebRunner
Completed processing of webpage
task
Login
browser
complete
response_status_text
200-OK
match
https://certification.plusauth.com/signin*
url
https://certification.plusauth.com/signin/consent
response_status_code
200
2021-03-27 15:39:38 INFO
WebRunner
Clicking an element
task
Consent
browser
click
element_type
class
url
https://certification.plusauth.com/signin/consent
target
login-submit
2021-03-27 15:39:39 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance FzzfewOGAxLVkWf
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/avif,image/webp,image/apng,*/*;q\u003d0.8,application/signed-exchange;v\u003db3;q\u003d0.9",
  "sec-fetch-site": "same-origin",
  "sec-fetch-mode": "navigate",
  "sec-fetch-user": "?1",
  "sec-fetch-dest": "document",
  "referer": "https://certification.plusauth.com/signin/consent",
  "accept-encoding": "gzip, deflate, br",
  "accept-language": "en-US",
  "origin": "https://certification.plusauth.com",
  "cache-control": "max-age\u003d0",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "connection": "close",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net"
}
incoming_path
callback
incoming_body_form_params
incoming_method
GET
incoming_body_json
incoming_query_string_params
{}
incoming_body
2021-03-27 15:39:39 SUCCESS
CreateRandomImplicitSubmitUrl
Created random implicit submission URL
implicit_submit
{
  "path": "implicit/5E946i7iXkrSu36A1jDm",
  "fullUrl": "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/implicit/5E946i7iXkrSu36A1jDm"
}
2021-03-27 15:39:39 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance FzzfewOGAxLVkWf
outgoing
ModelAndView [view="implicitCallback"; model={implicitSubmitUrl=https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/implicit/5E946i7iXkrSu36A1jDm, returnUrl=/log-detail.html?log=FzzfewOGAxLVkWf}]
outgoing_path
callback
2021-03-27 15:39:39 INFO
WebRunner
Completed processing of webpage
task
Consent
browser
complete
response_status_text
200-
match
https://certification.plusauth.com/signin/consent*
url
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback#code=a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5&id_token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg&state=TYjGwLd4HC&session_state=31NbpOIGAjPWkL4bQwWBcknx6jjcaeFHpSGevJPT2ZU
response_status_code
200
2021-03-27 15:39:39 INFO
WebRunner
Waiting
regexp
seconds
10
task
Verify Complete
browser
wait
action
element_type
id
url
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback#code=a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5&id_token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg&state=TYjGwLd4HC&session_state=31NbpOIGAjPWkL4bQwWBcknx6jjcaeFHpSGevJPT2ZU
target
submission_complete
2021-03-27 15:39:39 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance FzzfewOGAxLVkWf
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36",
  "accept": "*/*",
  "sec-fetch-site": "same-origin",
  "sec-fetch-mode": "navigate",
  "sec-fetch-user": "?1",
  "sec-fetch-dest": "document",
  "referer": "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback#code\u003da3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5\u0026id_token\u003deyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg\u0026state\u003dTYjGwLd4HC\u0026session_state\u003d31NbpOIGAjPWkL4bQwWBcknx6jjcaeFHpSGevJPT2ZU",
  "accept-encoding": "gzip, deflate, br",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003dB3A07F07FAA07ECEACA999AB8E00E77E",
  "x-requested-with": "XMLHttpRequest",
  "content-type": "text/plain",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "879",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
implicit/5E946i7iXkrSu36A1jDm
incoming_body_form_params
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
#code=a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5&id_token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg&state=TYjGwLd4HC&session_state=31NbpOIGAjPWkL4bQwWBcknx6jjcaeFHpSGevJPT2ZU
2021-03-27 15:39:39 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance FzzfewOGAxLVkWf
outgoing_status_code
204
outgoing_headers
{}
outgoing_body

                                
outgoing_path
implicit/5E946i7iXkrSu36A1jDm
2021-03-27 15:39:39
ExtractImplicitHashToCallbackResponse
Extracted response from URL fragment
parameters
[
  {
    "name": "code",
    "value": "a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5"
  },
  {
    "name": "id_token",
    "value": "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg"
  },
  {
    "name": "state",
    "value": "TYjGwLd4HC"
  },
  {
    "name": "session_state",
    "value": "31NbpOIGAjPWkL4bQwWBcknx6jjcaeFHpSGevJPT2ZU"
  }
]
2021-03-27 15:39:39 SUCCESS
ExtractImplicitHashToCallbackResponse
Extracted the hash values
code
a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg
state
TYjGwLd4HC
session_state
31NbpOIGAjPWkL4bQwWBcknx6jjcaeFHpSGevJPT2ZU
2021-03-27 15:39:39 REDIRECT-IN
oidcc-refresh-token
Authorization endpoint response captured
url_query
{}
headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/avif,image/webp,image/apng,*/*;q\u003d0.8,application/signed-exchange;v\u003db3;q\u003d0.9",
  "sec-fetch-site": "same-origin",
  "sec-fetch-mode": "navigate",
  "sec-fetch-user": "?1",
  "sec-fetch-dest": "document",
  "referer": "https://certification.plusauth.com/signin/consent",
  "accept-encoding": "gzip, deflate, br",
  "accept-language": "en-US",
  "origin": "https://certification.plusauth.com",
  "cache-control": "max-age\u003d0",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "connection": "close",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net"
}
http_method
GET
url_fragment
{
  "code": "a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5",
  "id_token": "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg",
  "state": "TYjGwLd4HC",
  "session_state": "31NbpOIGAjPWkL4bQwWBcknx6jjcaeFHpSGevJPT2ZU"
}
post_body
Verify authorization endpoint response
2021-03-27 15:39:39 SUCCESS
RejectAuthCodeInUrlQuery
Authorization code is not present in URL query returned from authorization endpoint
2021-03-27 15:39:39 SUCCESS
RejectErrorInUrlQuery
'error' is not present in URL query returned from authorization endpoint
2021-03-27 15:39:39 SUCCESS
CheckMatchingCallbackParameters
Callback parameters successfully verified
2021-03-27 15:39:39
ValidateIssInAuthorizationResponse
No 'iss' value in authorization response.
2021-03-27 15:39:39 SUCCESS
CheckIfAuthorizationEndpointError
No error from authorization endpoint
2021-03-27 15:39:39 SUCCESS
CheckStateInAuthorizationResponse
State in response correctly returned
state
TYjGwLd4HC
2021-03-27 15:39:39 SUCCESS
ExtractAuthorizationCodeFromAuthorizationResponse
Found authorization code
code
a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5
2021-03-27 15:39:39 SUCCESS
ExtractIdTokenFromAuthorizationResponse
Found and parsed the id_token from authorization_endpoint_response
value
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg
header
{
  "kid": "9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4",
  "typ": "JWT",
  "alg": "RS256"
}
claims
{
  "sub": "certification_1",
  "c_hash": "_Y29Zixjhcv9OrWs9CwXDg",
  "aud": "Eg2iyh1FSLv40rz_yIsx7",
  "s_hash": "UkTz7uAU-XsaTb5JvyU2_g",
  "iss": "https://certification.plusauth.com",
  "exp": 1616863178,
  "nonce": "IZjxBfBMa3",
  "iat": 1616859578
}
2021-03-27 15:39:39 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2021-03-27 15:39:39 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
IZjxBfBMa3
2021-03-27 15:39:39 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2021-03-27 15:39:39 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg
2021-03-27 15:39:39 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg
2021-03-27 15:39:39 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
certification_1
2021-03-27 15:39:39 SUCCESS
CreateTokenEndpointRequestForAuthorizationCodeGrant
grant_type
authorization_code
code
a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
2021-03-27 15:39:39 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic RWcyaXloMUZTTHY0MHJ6X3lJc3g3OmJVZmVJWFRBMXUxMzZnNzl1SzIyNGxORmhHTXJlaEJBbHJHazFEYktxck5tWlVkci1HLUJ6Wm93VTh0YVNIUGlLNTR4NUFkZUxpQ21sRnRlRTM1TlVn
2021-03-27 15:39:39
CallTokenEndpoint
HTTP request
request_uri
https://certification.plusauth.com/oauth/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic RWcyaXloMUZTTHY0MHJ6X3lJc3g3OmJVZmVJWFRBMXUxMzZnNzl1SzIyNGxORmhHTXJlaEJBbHJHazFEYktxck5tWlVkci1HLUJ6Wm93VTh0YVNIUGlLNTR4NUFkZUxpQ21sRnRlRTM1TlVn",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "197"
}
request_body
grant_type=authorization_code&code=a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5&redirect_uri=https%3A%2F%2Fwww.certification.openid.net%2Ftest%2Fa%2Foidc-provider-discovery-dynamic_client%2Fcallback
2021-03-27 15:39:39 INFO
WebRunner
Completed processing of webpage
task
Verify Complete
browser
complete
response_status_text
200-
match
*/test/*/callback*
url
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback#code=a3C0cfHQsRKxcIb2rgrWIjUbBgpGc5T0Vpp6gOjPRr5&id_token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJjX2hhc2giOiJfWTI5Wml4amhjdjlPcldzOUN3WERnIiwic19oYXNoIjoiVWtUejd1QVUtWHNhVGI1SnZ5VTJfZyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE3OCwiaWF0IjoxNjE2ODU5NTc4LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Ye8GMfpvVpUFxnC2XG9M005zaZDp_Whki1NrRaiMGXuSKqKnaklZKh_HWZ3reI_UekY6XfWx9FCxC1C7KA32G_2_GoZEWk_cJZ34yyJ-mbwIsebJr5_NWEk4iHIqup7wEEFsX0ag3HH7Uac3-U06W7cCkybX1G8MWrrexvhE0gNdAVU_rRaZQSFWiodOXoTgRfHUTgkYkc-6J3Dh-XTwvPZcK8sxQ0dven8n77lSu9ejDycLE-NJpigqZRjGW7zF51rZ_n8IJLwO-d6PvvQssrmh_SPnwJfveeQkTK0QDbmCFqzANSffhNaUEYmug4kWyoz772UM-qsoJ531lF_PNg&state=TYjGwLd4HC&session_state=31NbpOIGAjPWkL4bQwWBcknx6jjcaeFHpSGevJPT2ZU
response_status_code
200
2021-03-27 15:39:40 RESPONSE
CallTokenEndpoint
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "911",
  "date": "Sat, 27 Mar 2021 15:39:40 GMT",
  "x-envoy-upstream-service-time": "23",
  "server": "istio-envoy"
}
response_body
{"access_token":"Tx4_xWQNEY_JF0fgN9sjlXQJRcLW2ao4F3hoRqkYpAI","expires_in":7200,"id_token":"eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJhdF9oYXNoIjoiWnFGekp3Z0VnNmNIUHpJbjJOaUdidyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE4MCwiaWF0IjoxNjE2ODU5NTgwLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Bz5X-cpaeAtNJHXwW_LB7kgn7-81HhUZQ-MVWxJldsbjJzACXMaCg19vAWaTjLXVxuqSjwjZ_3oAEw0YyksV2Tq7R4u4CBR89rU9mvPmIEbKgatZDJcYVp8jl2JKoO8pxuHL4aNFF03S39vSeAvr1MrdtCcffMpqFnYbyua0mIZIbfdX9uycRyiVl2FuUbQxNEOgkE2nG41H7jvUTGnE6x71yA-R2uFwYJWslzU6baSNRtEshUgCXPkcqqt53EOTUl1au9i7UR4c5HHGyYfeIICR5YZEki0IOgbAVLqG-Bax8daN-24sJ215-bFFYmhezbqGoqW8NYOmOvnQLpA8yg","refresh_token":"JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n","scope":"openid offline_access","token_type":"Bearer"}
2021-03-27 15:39:40
CallTokenEndpoint
Token endpoint response
token_endpoint_response
{"access_token":"Tx4_xWQNEY_JF0fgN9sjlXQJRcLW2ao4F3hoRqkYpAI","expires_in":7200,"id_token":"eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJhdF9oYXNoIjoiWnFGekp3Z0VnNmNIUHpJbjJOaUdidyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE4MCwiaWF0IjoxNjE2ODU5NTgwLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Bz5X-cpaeAtNJHXwW_LB7kgn7-81HhUZQ-MVWxJldsbjJzACXMaCg19vAWaTjLXVxuqSjwjZ_3oAEw0YyksV2Tq7R4u4CBR89rU9mvPmIEbKgatZDJcYVp8jl2JKoO8pxuHL4aNFF03S39vSeAvr1MrdtCcffMpqFnYbyua0mIZIbfdX9uycRyiVl2FuUbQxNEOgkE2nG41H7jvUTGnE6x71yA-R2uFwYJWslzU6baSNRtEshUgCXPkcqqt53EOTUl1au9i7UR4c5HHGyYfeIICR5YZEki0IOgbAVLqG-Bax8daN-24sJ215-bFFYmhezbqGoqW8NYOmOvnQLpA8yg","refresh_token":"JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n","scope":"openid offline_access","token_type":"Bearer"}
2021-03-27 15:39:40 SUCCESS
CallTokenEndpoint
Parsed token endpoint response
access_token
Tx4_xWQNEY_JF0fgN9sjlXQJRcLW2ao4F3hoRqkYpAI
expires_in
7200
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJhdF9oYXNoIjoiWnFGekp3Z0VnNmNIUHpJbjJOaUdidyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE4MCwiaWF0IjoxNjE2ODU5NTgwLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Bz5X-cpaeAtNJHXwW_LB7kgn7-81HhUZQ-MVWxJldsbjJzACXMaCg19vAWaTjLXVxuqSjwjZ_3oAEw0YyksV2Tq7R4u4CBR89rU9mvPmIEbKgatZDJcYVp8jl2JKoO8pxuHL4aNFF03S39vSeAvr1MrdtCcffMpqFnYbyua0mIZIbfdX9uycRyiVl2FuUbQxNEOgkE2nG41H7jvUTGnE6x71yA-R2uFwYJWslzU6baSNRtEshUgCXPkcqqt53EOTUl1au9i7UR4c5HHGyYfeIICR5YZEki0IOgbAVLqG-Bax8daN-24sJ215-bFFYmhezbqGoqW8NYOmOvnQLpA8yg
refresh_token
JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n
scope
openid offline_access
token_type
Bearer
2021-03-27 15:39:40 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2021-03-27 15:39:40 SUCCESS
CheckForAccessTokenValue
Found an access token
access_token
Tx4_xWQNEY_JF0fgN9sjlXQJRcLW2ao4F3hoRqkYpAI
2021-03-27 15:39:40 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
Tx4_xWQNEY_JF0fgN9sjlXQJRcLW2ao4F3hoRqkYpAI
type
Bearer
2021-03-27 15:39:40 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
7200
2021-03-27 15:39:40 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
7200
2021-03-27 15:39:40 SUCCESS
CheckForRefreshTokenValue
Found a refresh token
refresh_token
JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n
2021-03-27 15:39:40 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJhdF9oYXNoIjoiWnFGekp3Z0VnNmNIUHpJbjJOaUdidyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE4MCwiaWF0IjoxNjE2ODU5NTgwLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Bz5X-cpaeAtNJHXwW_LB7kgn7-81HhUZQ-MVWxJldsbjJzACXMaCg19vAWaTjLXVxuqSjwjZ_3oAEw0YyksV2Tq7R4u4CBR89rU9mvPmIEbKgatZDJcYVp8jl2JKoO8pxuHL4aNFF03S39vSeAvr1MrdtCcffMpqFnYbyua0mIZIbfdX9uycRyiVl2FuUbQxNEOgkE2nG41H7jvUTGnE6x71yA-R2uFwYJWslzU6baSNRtEshUgCXPkcqqt53EOTUl1au9i7UR4c5HHGyYfeIICR5YZEki0IOgbAVLqG-Bax8daN-24sJ215-bFFYmhezbqGoqW8NYOmOvnQLpA8yg
header
{
  "kid": "9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4",
  "typ": "JWT",
  "alg": "RS256"
}
claims
{
  "at_hash": "ZqFzJwgEg6cHPzIn2NiGbw",
  "sub": "certification_1",
  "aud": "Eg2iyh1FSLv40rz_yIsx7",
  "iss": "https://certification.plusauth.com",
  "exp": 1616863180,
  "nonce": "IZjxBfBMa3",
  "iat": 1616859580
}
2021-03-27 15:39:40 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2021-03-27 15:39:40 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
IZjxBfBMa3
2021-03-27 15:39:40 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2021-03-27 15:39:40 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJhdF9oYXNoIjoiWnFGekp3Z0VnNmNIUHpJbjJOaUdidyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE4MCwiaWF0IjoxNjE2ODU5NTgwLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Bz5X-cpaeAtNJHXwW_LB7kgn7-81HhUZQ-MVWxJldsbjJzACXMaCg19vAWaTjLXVxuqSjwjZ_3oAEw0YyksV2Tq7R4u4CBR89rU9mvPmIEbKgatZDJcYVp8jl2JKoO8pxuHL4aNFF03S39vSeAvr1MrdtCcffMpqFnYbyua0mIZIbfdX9uycRyiVl2FuUbQxNEOgkE2nG41H7jvUTGnE6x71yA-R2uFwYJWslzU6baSNRtEshUgCXPkcqqt53EOTUl1au9i7UR4c5HHGyYfeIICR5YZEki0IOgbAVLqG-Bax8daN-24sJ215-bFFYmhezbqGoqW8NYOmOvnQLpA8yg
2021-03-27 15:39:40 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJhdF9oYXNoIjoiWnFGekp3Z0VnNmNIUHpJbjJOaUdidyIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE4MCwiaWF0IjoxNjE2ODU5NTgwLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Bz5X-cpaeAtNJHXwW_LB7kgn7-81HhUZQ-MVWxJldsbjJzACXMaCg19vAWaTjLXVxuqSjwjZ_3oAEw0YyksV2Tq7R4u4CBR89rU9mvPmIEbKgatZDJcYVp8jl2JKoO8pxuHL4aNFF03S39vSeAvr1MrdtCcffMpqFnYbyua0mIZIbfdX9uycRyiVl2FuUbQxNEOgkE2nG41H7jvUTGnE6x71yA-R2uFwYJWslzU6baSNRtEshUgCXPkcqqt53EOTUl1au9i7UR4c5HHGyYfeIICR5YZEki0IOgbAVLqG-Bax8daN-24sJ215-bFFYmhezbqGoqW8NYOmOvnQLpA8yg
2021-03-27 15:39:40 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
certification_1
2021-03-27 15:39:40 SUCCESS
VerifyIdTokenSubConsistentHybridFlow
authorization endpoint and token endpoint id_token have same sub
sub_auth_endpoint
certification_1
sub_token_endpoint
certification_1
2021-03-27 15:39:40 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n
2021-03-27 15:39:40 SUCCESS
EnsureServerConfigurationSupportsRefreshToken
The server configuration indicates support for refresh tokens
supported_grant_types
[
  "implicit",
  "authorization_code",
  "refresh_token",
  "client_credentials",
  "urn:ietf:params:oauth:grant-type:device_code",
  "urn:ietf:params:oauth:grant-type:token-exchange"
]
2021-03-27 15:39:40 SUCCESS
EnsureRefreshTokenContainsAllowedCharactersOnly
Refresh token does not contain any illegal characters
Refresh Token Request
2021-03-27 15:39:40 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n
2021-03-27 15:39:40 SUCCESS
AddScopeToTokenEndpointRequest
Added scope of 'openid offline_access' to token endpoint request
grant_type
refresh_token
refresh_token
JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n
scope
openid offline_access
2021-03-27 15:39:40 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic RWcyaXloMUZTTHY0MHJ6X3lJc3g3OmJVZmVJWFRBMXUxMzZnNzl1SzIyNGxORmhHTXJlaEJBbHJHazFEYktxck5tWlVkci1HLUJ6Wm93VTh0YVNIUGlLNTR4NUFkZUxpQ21sRnRlRTM1TlVn
2021-03-27 15:39:40 SUCCESS
WaitForOneSecond
Pausing for 1 seconds
2021-03-27 15:39:41 SUCCESS
WaitForOneSecond
Woke up after 1 seconds sleep
2021-03-27 15:39:41
CallTokenEndpointAndReturnFullResponse
HTTP request
request_uri
https://certification.plusauth.com/oauth/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic RWcyaXloMUZTTHY0MHJ6X3lJc3g3OmJVZmVJWFRBMXUxMzZnNzl1SzIyNGxORmhHTXJlaEJBbHJHazFEYktxck5tWlVkci1HLUJ6Wm93VTh0YVNIUGlLNTR4NUFkZUxpQ21sRnRlRTM1TlVn",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "110"
}
request_body
grant_type=refresh_token&refresh_token=JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n&scope=openid+offline_access
2021-03-27 15:39:41 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "911",
  "date": "Sat, 27 Mar 2021 15:39:41 GMT",
  "x-envoy-upstream-service-time": "19",
  "server": "istio-envoy"
}
response_body
{"access_token":"0q6kARRbeZlfBl8RcpqWQstlYht2FKdYYBgf03fPaOP","expires_in":7200,"id_token":"eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJhdF9oYXNoIjoielVYcE1DR0daRkNpdTVrWFNweVJIUSIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE4MSwiaWF0IjoxNjE2ODU5NTgxLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.CAYw-TARW1JP3B1B1sXoxom4XJlQYSyXvfd3SnKxCtcH_mma9MNTlUi7i9gdf6261uV9fZGn91ipFBDdzhZU_l6Jkfcc98mDcLjfxbk4N4HC_GvlCjHk6qqASzH2juOOg2RN9mIwfO0U0XDv8KnL2EJ77TGRyHeov3Ioh-YmVCyEcR4UT9bAirRim8R4btbnjcZ14gQ0NyBx8r3ZO0qDJ3C9RPthnKIjp4Lr9UK9Gkomw0vE1XJOR4RslI_bvQqJLoxed2Lq66kSXNucYCKndizvrWgCZmhOb3neGH_SH0SDaKgt0SfdM-UYbR-OhV-6soDndMA7K7HYSK47-UScew","refresh_token":"JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n","scope":"openid offline_access","token_type":"Bearer"}
2021-03-27 15:39:41 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
access_token
0q6kARRbeZlfBl8RcpqWQstlYht2FKdYYBgf03fPaOP
expires_in
7200
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJhdF9oYXNoIjoielVYcE1DR0daRkNpdTVrWFNweVJIUSIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE4MSwiaWF0IjoxNjE2ODU5NTgxLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.CAYw-TARW1JP3B1B1sXoxom4XJlQYSyXvfd3SnKxCtcH_mma9MNTlUi7i9gdf6261uV9fZGn91ipFBDdzhZU_l6Jkfcc98mDcLjfxbk4N4HC_GvlCjHk6qqASzH2juOOg2RN9mIwfO0U0XDv8KnL2EJ77TGRyHeov3Ioh-YmVCyEcR4UT9bAirRim8R4btbnjcZ14gQ0NyBx8r3ZO0qDJ3C9RPthnKIjp4Lr9UK9Gkomw0vE1XJOR4RslI_bvQqJLoxed2Lq66kSXNucYCKndizvrWgCZmhOb3neGH_SH0SDaKgt0SfdM-UYbR-OhV-6soDndMA7K7HYSK47-UScew
refresh_token
JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n
scope
openid offline_access
token_type
Bearer
2021-03-27 15:39:41 SUCCESS
CheckTokenEndpointHttpStatus200
Token endpoint http status code was 200
2021-03-27 15:39:41 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2021-03-27 15:39:41 SUCCESS
CheckTokenEndpointCacheHeaders
'pragma' and 'cache-control' headers in token endpoint response contain expected values.
cache_control_header
no-cache, no-store
pragma_header
no-cache
2021-03-27 15:39:41 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2021-03-27 15:39:41 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
0q6kARRbeZlfBl8RcpqWQstlYht2FKdYYBgf03fPaOP
type
Bearer
2021-03-27 15:39:41 SUCCESS
CheckTokenTypeIsBearer
Token type is bearer
2021-03-27 15:39:41 SUCCESS
EnsureMinimumAccessTokenEntropy
Calculated shannon entropy seems sufficient
actual
204.30983444353632
expected
96.0
2021-03-27 15:39:41 SUCCESS
EnsureAccessTokenContainsAllowedCharactersOnly
Access token does not contain any illegal characters
2021-03-27 15:39:41 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
7200
2021-03-27 15:39:41 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
7200
2021-03-27 15:39:41 SUCCESS
EnsureAccessTokenValuesAreDifferent
Access token values are not the same
first_access_token
Tx4_xWQNEY_JF0fgN9sjlXQJRcLW2ao4F3hoRqkYpAI
second_access_token
0q6kARRbeZlfBl8RcpqWQstlYht2FKdYYBgf03fPaOP
2021-03-27 15:39:41 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IklaanhCZkJNYTMiLCJhdF9oYXNoIjoielVYcE1DR0daRkNpdTVrWFNweVJIUSIsImF1ZCI6IkVnMml5aDFGU0x2NDByel95SXN4NyIsImV4cCI6MTYxNjg2MzE4MSwiaWF0IjoxNjE2ODU5NTgxLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.CAYw-TARW1JP3B1B1sXoxom4XJlQYSyXvfd3SnKxCtcH_mma9MNTlUi7i9gdf6261uV9fZGn91ipFBDdzhZU_l6Jkfcc98mDcLjfxbk4N4HC_GvlCjHk6qqASzH2juOOg2RN9mIwfO0U0XDv8KnL2EJ77TGRyHeov3Ioh-YmVCyEcR4UT9bAirRim8R4btbnjcZ14gQ0NyBx8r3ZO0qDJ3C9RPthnKIjp4Lr9UK9Gkomw0vE1XJOR4RslI_bvQqJLoxed2Lq66kSXNucYCKndizvrWgCZmhOb3neGH_SH0SDaKgt0SfdM-UYbR-OhV-6soDndMA7K7HYSK47-UScew
header
{
  "kid": "9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4",
  "typ": "JWT",
  "alg": "RS256"
}
claims
{
  "at_hash": "zUXpMCGGZFCiu5kXSpyRHQ",
  "sub": "certification_1",
  "aud": "Eg2iyh1FSLv40rz_yIsx7",
  "iss": "https://certification.plusauth.com",
  "exp": 1616863181,
  "nonce": "IZjxBfBMa3",
  "iat": 1616859581
}
2021-03-27 15:39:41 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
JzZUTwd_guaKyEZGesMSvGquilFGndfZ8l-YCdiDL5n
2021-03-27 15:39:41 SUCCESS
EnsureMinimumRefreshTokenLength
Refresh token is of sufficient length
actual
344
required
128
2021-03-27 15:39:41 SUCCESS
EnsureMinimumRefreshTokenEntropy
Calculated shannon entropy seems sufficient
actual
211.06472194569977
expected
96.0
2021-03-27 15:39:41 SUCCESS
CompareIdTokenClaims
Validated id token claims successfully
iss
{
  "first": "https://certification.plusauth.com",
  "second": "https://certification.plusauth.com",
  "note": "Values are expected to be equal"
}
sub
{
  "first": "certification_1",
  "second": "certification_1",
  "note": "Values are expected to be equal"
}
iat
{
  "first": 1616859580,
  "second": 1616859581,
  "note": "Values are expected to be different"
}
aud
{
  "first": "Eg2iyh1FSLv40rz_yIsx7",
  "second": "Eg2iyh1FSLv40rz_yIsx7",
  "note": "Values are expected to be equal"
}
azp
Id tokens do not contain azp claims
Userinfo endpoint tests
2021-03-27 15:39:41
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://certification.plusauth.com/me
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer 0q6kARRbeZlfBl8RcpqWQstlYht2FKdYYBgf03fPaOP",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2021-03-27 15:39:42 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "x-fapi-interaction-id": "42085511-31e2-42ee-87a9-10d7933f3a1f",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "25",
  "date": "Sat, 27 Mar 2021 15:39:42 GMT",
  "x-envoy-upstream-service-time": "14",
  "server": "istio-envoy"
}
response_body
{"sub":"certification_1"}
2021-03-27 15:39:42 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "x-fapi-interaction-id": "42085511-31e2-42ee-87a9-10d7933f3a1f",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "25",
  "date": "Sat, 27 Mar 2021 15:39:42 GMT",
  "x-envoy-upstream-service-time": "14",
  "server": "istio-envoy"
}
status_code
{
  "code": 200
}
body
{"sub":"certification_1"}
Second client: Make request to authorization endpoint
2021-03-27 15:39:42 SUCCESS
CreateAuthorizationEndpointRequestFromClientInformation
Created authorization endpoint request
client_id
XAWhFzWUWotR7pbibc546
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
2021-03-27 15:39:42
CreateRandomStateValue
Created state value
requested_state_length
10
state
uzqkHi659V
2021-03-27 15:39:42 SUCCESS
AddStateToAuthorizationEndpointRequest
Added state parameter to request
client_id
XAWhFzWUWotR7pbibc546
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
state
uzqkHi659V
2021-03-27 15:39:42
CreateRandomNonceValue
Created nonce value
requested_nonce_length
10
nonce
9eBGcM06pE
2021-03-27 15:39:42 SUCCESS
AddNonceToAuthorizationEndpointRequest
Added nonce parameter to request
client_id
XAWhFzWUWotR7pbibc546
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
state
uzqkHi659V
nonce
9eBGcM06pE
2021-03-27 15:39:42 SUCCESS
SetAuthorizationEndpointRequestResponseTypeFromEnvironment
Added response_type parameter to request
client_id
XAWhFzWUWotR7pbibc546
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
state
uzqkHi659V
nonce
9eBGcM06pE
response_type
code id_token
2021-03-27 15:39:42 SUCCESS
AddPromptConsentToAuthorizationEndpointRequestIfScopeContainsOfflineAccess
Added prompt=consent to authorization endpoint request
client_id
XAWhFzWUWotR7pbibc546
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
scope
openid offline_access
state
uzqkHi659V
nonce
9eBGcM06pE
response_type
code id_token
prompt
consent
2021-03-27 15:39:42 SUCCESS
BuildPlainRedirectToAuthorizationEndpoint
Sending to authorization endpoint
redirect_to_authorization_endpoint
https://certification.plusauth.com/oauth/auth?client_id=XAWhFzWUWotR7pbibc546&redirect_uri=https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback&scope=openid%20offline_access&state=uzqkHi659V&nonce=9eBGcM06pE&response_type=code%20id_token&prompt=consent
2021-03-27 15:39:42 REDIRECT
oidcc-refresh-token
Redirecting to authorization endpoint
redirect_to
https://certification.plusauth.com/oauth/auth?client_id=XAWhFzWUWotR7pbibc546&redirect_uri=https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback&scope=openid%20offline_access&state=uzqkHi659V&nonce=9eBGcM06pE&response_type=code%20id_token&prompt=consent
2021-03-27 15:39:42
WebRunner
Scripted browser HTTP request
browser
goToUrl
request_method
GET
request_uri
https://certification.plusauth.com/oauth/auth?client_id=XAWhFzWUWotR7pbibc546&redirect_uri=https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback&scope=openid%20offline_access&state=uzqkHi659V&nonce=9eBGcM06pE&response_type=code%20id_token&prompt=consent
2021-03-27 15:39:42 RESPONSE
WebRunner
Scripted browser HTTP response
response_content
<!DOCTYPE html>
<html lang="en" >
<head><script>var PlusAuth = window.PlusAuth = {"client":{"clientName":"second-openid-client FzzfewOGAxLVkWf","applicationType":"web","social":[]},"details":{"scopes":{"new":["openid","offline_access"],"accepted":[],"rejected":[]},"claims":{"new":[],"accepted":[],"rejected":[]},"account":"certification_1"},"params":{"client_id":"XAWhFzWUWotR7pbibc546","nonce":"9eBGcM06pE","prompt":"consent","redirect_uri":"https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback","response_type":"code id_token","scope":"openid offline_access","state":"uzqkHi659V"},"prompt":{"name":"consent"},"settings":{}} </script>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
  <meta http-equiv="x-ua-compatible" content="ie=edge">
  <title>Consent</title>
</head>
<body >
<div class="login-card">
  <h1>Consent</h1>
  <form autocomplete="off" action="/signin/consent/confirm" method="post">
    <button autofocus type="submit" class="login login-submit">Continue</button>
  </form>
  <a href="/signin/consent/reject" autofocus class="login-reject">Reject</a>
</div>
</body >
</html >
response_content_type
text/html
response_status_text
200-OK
response_status_code
200
2021-03-27 15:39:42 INFO
WebRunner
Entering text
task
Login
browser
text
element_type
name
value
foo
url
https://certification.plusauth.com/signin/consent
target
username
2021-03-27 15:39:42 INFO
WebRunner
Element not found, skipping as 'text' command is marked 'optional'
task
Login
browser
text
element_type
name
value
foo
url
https://certification.plusauth.com/signin/consent
target
username
2021-03-27 15:39:42 INFO
WebRunner
Entering text
task
Login
browser
text
element_type
name
value
bar
url
https://certification.plusauth.com/signin/consent
target
password
2021-03-27 15:39:42 INFO
WebRunner
Element not found, skipping as 'text' command is marked 'optional'
task
Login
browser
text
element_type
name
value
bar
url
https://certification.plusauth.com/signin/consent
target
password
2021-03-27 15:39:42 INFO
WebRunner
Clicking an element
task
Login
browser
click
element_type
class
url
https://certification.plusauth.com/signin/consent
target
login-submit
2021-03-27 15:39:43 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance FzzfewOGAxLVkWf
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/avif,image/webp,image/apng,*/*;q\u003d0.8,application/signed-exchange;v\u003db3;q\u003d0.9",
  "sec-fetch-site": "same-origin",
  "sec-fetch-mode": "navigate",
  "sec-fetch-user": "?1",
  "sec-fetch-dest": "document",
  "referer": "https://certification.plusauth.com/signin/consent",
  "accept-encoding": "gzip, deflate, br",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003dB3A07F07FAA07ECEACA999AB8E00E77E",
  "origin": "https://certification.plusauth.com",
  "cache-control": "max-age\u003d0",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "connection": "close",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net"
}
incoming_path
callback
incoming_body_form_params
incoming_method
GET
incoming_body_json
incoming_query_string_params
{}
incoming_body
2021-03-27 15:39:43 SUCCESS
CreateRandomImplicitSubmitUrl
Created random implicit submission URL
implicit_submit
{
  "path": "implicit/ctCBXA5KSMj3viNXuEDC",
  "fullUrl": "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/implicit/ctCBXA5KSMj3viNXuEDC"
}
2021-03-27 15:39:43 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance FzzfewOGAxLVkWf
outgoing
ModelAndView [view="implicitCallback"; model={implicitSubmitUrl=https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/implicit/ctCBXA5KSMj3viNXuEDC, returnUrl=/log-detail.html?log=FzzfewOGAxLVkWf}]
outgoing_path
callback
2021-03-27 15:39:43 INFO
WebRunner
Completed processing of webpage
task
Login
browser
complete
response_status_text
200-
match
https://certification.plusauth.com/signin*
url
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback#code=mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW&id_token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g&state=uzqkHi659V&session_state=Iivk70P6Z2ajTMFdE5AphXBK_jyVURmCE-AzksPU91Q
response_status_code
200
2021-03-27 15:39:43
WebRunner
Skipping optional task due to URL mismatch
task
Consent
browser
skip
match
https://certification.plusauth.com/signin/consent*
url
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback#code=mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW&id_token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g&state=uzqkHi659V&session_state=Iivk70P6Z2ajTMFdE5AphXBK_jyVURmCE-AzksPU91Q
commands
[
  [
    "click",
    "class",
    "login-submit"
  ]
]
2021-03-27 15:39:43 INFO
WebRunner
Waiting
regexp
seconds
10
task
Verify Complete
browser
wait
action
element_type
id
url
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback#code=mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW&id_token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g&state=uzqkHi659V&session_state=Iivk70P6Z2ajTMFdE5AphXBK_jyVURmCE-AzksPU91Q
target
submission_complete
2021-03-27 15:39:43 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance FzzfewOGAxLVkWf
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36",
  "accept": "*/*",
  "sec-fetch-site": "same-origin",
  "sec-fetch-mode": "navigate",
  "sec-fetch-user": "?1",
  "sec-fetch-dest": "document",
  "referer": "https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback#code\u003dmKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW\u0026id_token\u003deyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g\u0026state\u003duzqkHi659V\u0026session_state\u003dIivk70P6Z2ajTMFdE5AphXBK_jyVURmCE-AzksPU91Q",
  "accept-encoding": "gzip, deflate, br",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003dB3A07F07FAA07ECEACA999AB8E00E77E",
  "x-requested-with": "XMLHttpRequest",
  "content-type": "text/plain",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "879",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
implicit/ctCBXA5KSMj3viNXuEDC
incoming_body_form_params
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
#code=mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW&id_token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g&state=uzqkHi659V&session_state=Iivk70P6Z2ajTMFdE5AphXBK_jyVURmCE-AzksPU91Q
2021-03-27 15:39:43 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance FzzfewOGAxLVkWf
outgoing_status_code
204
outgoing_headers
{}
outgoing_body

                                
outgoing_path
implicit/ctCBXA5KSMj3viNXuEDC
2021-03-27 15:39:43
ExtractImplicitHashToCallbackResponse
Extracted response from URL fragment
parameters
[
  {
    "name": "code",
    "value": "mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW"
  },
  {
    "name": "id_token",
    "value": "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g"
  },
  {
    "name": "state",
    "value": "uzqkHi659V"
  },
  {
    "name": "session_state",
    "value": "Iivk70P6Z2ajTMFdE5AphXBK_jyVURmCE-AzksPU91Q"
  }
]
2021-03-27 15:39:43 SUCCESS
ExtractImplicitHashToCallbackResponse
Extracted the hash values
code
mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g
state
uzqkHi659V
session_state
Iivk70P6Z2ajTMFdE5AphXBK_jyVURmCE-AzksPU91Q
2021-03-27 15:39:43 REDIRECT-IN
oidcc-refresh-token
Authorization endpoint response captured
url_query
{}
headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/avif,image/webp,image/apng,*/*;q\u003d0.8,application/signed-exchange;v\u003db3;q\u003d0.9",
  "sec-fetch-site": "same-origin",
  "sec-fetch-mode": "navigate",
  "sec-fetch-user": "?1",
  "sec-fetch-dest": "document",
  "referer": "https://certification.plusauth.com/signin/consent",
  "accept-encoding": "gzip, deflate, br",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003dB3A07F07FAA07ECEACA999AB8E00E77E",
  "origin": "https://certification.plusauth.com",
  "cache-control": "max-age\u003d0",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "connection": "close",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net"
}
http_method
GET
url_fragment
{
  "code": "mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW",
  "id_token": "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g",
  "state": "uzqkHi659V",
  "session_state": "Iivk70P6Z2ajTMFdE5AphXBK_jyVURmCE-AzksPU91Q"
}
post_body
Second client: Verify authorization endpoint response
2021-03-27 15:39:43 SUCCESS
RejectAuthCodeInUrlQuery
Authorization code is not present in URL query returned from authorization endpoint
2021-03-27 15:39:43 SUCCESS
RejectErrorInUrlQuery
'error' is not present in URL query returned from authorization endpoint
2021-03-27 15:39:43 SUCCESS
CheckMatchingCallbackParameters
Callback parameters successfully verified
2021-03-27 15:39:43
ValidateIssInAuthorizationResponse
No 'iss' value in authorization response.
2021-03-27 15:39:43 SUCCESS
CheckIfAuthorizationEndpointError
No error from authorization endpoint
2021-03-27 15:39:43 SUCCESS
CheckStateInAuthorizationResponse
State in response correctly returned
state
uzqkHi659V
2021-03-27 15:39:43 SUCCESS
ExtractAuthorizationCodeFromAuthorizationResponse
Found authorization code
code
mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW
2021-03-27 15:39:43 SUCCESS
ExtractIdTokenFromAuthorizationResponse
Found and parsed the id_token from authorization_endpoint_response
value
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g
header
{
  "kid": "9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4",
  "typ": "JWT",
  "alg": "RS256"
}
claims
{
  "sub": "certification_1",
  "c_hash": "pTanCQ_rp8kScvs8q0ni7Q",
  "aud": "XAWhFzWUWotR7pbibc546",
  "s_hash": "H9ueFPq-_4N9wb9Zf1-Oyw",
  "iss": "https://certification.plusauth.com",
  "exp": 1616863183,
  "nonce": "9eBGcM06pE",
  "iat": 1616859583
}
2021-03-27 15:39:43 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2021-03-27 15:39:43 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
9eBGcM06pE
2021-03-27 15:39:43 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2021-03-27 15:39:43 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g
2021-03-27 15:39:43 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g
2021-03-27 15:39:43 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
certification_1
2021-03-27 15:39:43 SUCCESS
CreateTokenEndpointRequestForAuthorizationCodeGrant
grant_type
authorization_code
code
mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW
redirect_uri
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback
2021-03-27 15:39:43 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic WEFXaEZ6V1VXb3RSN3BiaWJjNTQ2OkpTdjRGM1p1RmdVTEczbDJZanJOOXkzRHNTSThXOTI2ZlFwcUQ3WXRSTXBLN0FhcEk2U0QwcFBJR3ZkQ2VXR0dvdTBOcmNnNXcwSlZ1cVIyZlBNNGN3
2021-03-27 15:39:43
CallTokenEndpoint
HTTP request
request_uri
https://certification.plusauth.com/oauth/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic WEFXaEZ6V1VXb3RSN3BiaWJjNTQ2OkpTdjRGM1p1RmdVTEczbDJZanJOOXkzRHNTSThXOTI2ZlFwcUQ3WXRSTXBLN0FhcEk2U0QwcFBJR3ZkQ2VXR0dvdTBOcmNnNXcwSlZ1cVIyZlBNNGN3",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "197"
}
request_body
grant_type=authorization_code&code=mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW&redirect_uri=https%3A%2F%2Fwww.certification.openid.net%2Ftest%2Fa%2Foidc-provider-discovery-dynamic_client%2Fcallback
2021-03-27 15:39:43 INFO
WebRunner
Completed processing of webpage
task
Verify Complete
browser
complete
response_status_text
200-
match
*/test/*/callback*
url
https://www.certification.openid.net/test/a/oidc-provider-discovery-dynamic_client/callback#code=mKlZw2frq2yOgxlI3YrIuV_iYC8dtGft-M6tANtRkmW&id_token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJjX2hhc2giOiJwVGFuQ1FfcnA4a1NjdnM4cTBuaTdRIiwic19oYXNoIjoiSDl1ZUZQcS1fNE45d2I5WmYxLU95dyIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4MywiaWF0IjoxNjE2ODU5NTgzLCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.X6LlvUUnJ6VIWiWRMXHlgDrPwfAyBzU9AmNNHIwvnUQtjPJo8EShJtCix8Z4YKcJIxugWJ5rVeC8ShQ7scaBOX2zThqaO5UjXMfvLwWqxd-TJAz25dF3-cJQH7P_I-TNrzUBqm5u4znjrdN4FacmGqLemGniVLSenAL91yOd48_k6Q8zZT48_-RGhQkpxSasOzuHocH1Uxpcu5nqcWEeNmHZUXWC9Zw7FxsaKVG6zMkkLnLFTq50X8pcx2yG28hZjfRNjpGZ7bGSy3J1pu_nGvIgeV9cAI6-0HuVfGLVvDEZI2JkvFxA6sC4mUJSZMWn_VL6OV_XI0KdeioKGnJ82g&state=uzqkHi659V&session_state=Iivk70P6Z2ajTMFdE5AphXBK_jyVURmCE-AzksPU91Q
response_status_code
200
2021-03-27 15:39:44 RESPONSE
CallTokenEndpoint
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "911",
  "date": "Sat, 27 Mar 2021 15:39:44 GMT",
  "x-envoy-upstream-service-time": "18",
  "server": "istio-envoy"
}
response_body
{"access_token":"fFdY9wsaH1Yx4FiNiNI99EAm3XU7Pk9FlV6fET6UKx3","expires_in":7200,"id_token":"eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJhdF9oYXNoIjoiQTVCYzdYOG5OWk10THdCeVpOa2Z2USIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4NCwiaWF0IjoxNjE2ODU5NTg0LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.CBzR2Shiw9MGIHDaS9gBQEcmDHqeWFUriHf5-wyyF3Oh3EhX4_nCTdeK799nEIq8L7ycPu1wYG0gk6pzRbegc-DyNO7toChlWr8TrDwNMR1WUFI_A_eyG0QjS0TPyqJ7qeaq1DWrvAG__1IOr6Uis97ScHzlO2-j7FDTfBF_N1HJd7l--EjcV04eAj0HkwY0YTpCubnKIUqdz2r0ZjorMyXAym9nDBVuYIiWeaS5Xk89U8iepMQVGgOmIeXHlfOrnb2OEgwLd0Tx2ahEZ_sF0H7znHSWSCbe_5rLwWT1tC8XuUAcOwhh22RP0L_B325KOjYJx7jrsM_xqg9Q0tv23Q","refresh_token":"7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW","scope":"openid offline_access","token_type":"Bearer"}
2021-03-27 15:39:44
CallTokenEndpoint
Token endpoint response
token_endpoint_response
{"access_token":"fFdY9wsaH1Yx4FiNiNI99EAm3XU7Pk9FlV6fET6UKx3","expires_in":7200,"id_token":"eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJhdF9oYXNoIjoiQTVCYzdYOG5OWk10THdCeVpOa2Z2USIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4NCwiaWF0IjoxNjE2ODU5NTg0LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.CBzR2Shiw9MGIHDaS9gBQEcmDHqeWFUriHf5-wyyF3Oh3EhX4_nCTdeK799nEIq8L7ycPu1wYG0gk6pzRbegc-DyNO7toChlWr8TrDwNMR1WUFI_A_eyG0QjS0TPyqJ7qeaq1DWrvAG__1IOr6Uis97ScHzlO2-j7FDTfBF_N1HJd7l--EjcV04eAj0HkwY0YTpCubnKIUqdz2r0ZjorMyXAym9nDBVuYIiWeaS5Xk89U8iepMQVGgOmIeXHlfOrnb2OEgwLd0Tx2ahEZ_sF0H7znHSWSCbe_5rLwWT1tC8XuUAcOwhh22RP0L_B325KOjYJx7jrsM_xqg9Q0tv23Q","refresh_token":"7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW","scope":"openid offline_access","token_type":"Bearer"}
2021-03-27 15:39:44 SUCCESS
CallTokenEndpoint
Parsed token endpoint response
access_token
fFdY9wsaH1Yx4FiNiNI99EAm3XU7Pk9FlV6fET6UKx3
expires_in
7200
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJhdF9oYXNoIjoiQTVCYzdYOG5OWk10THdCeVpOa2Z2USIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4NCwiaWF0IjoxNjE2ODU5NTg0LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.CBzR2Shiw9MGIHDaS9gBQEcmDHqeWFUriHf5-wyyF3Oh3EhX4_nCTdeK799nEIq8L7ycPu1wYG0gk6pzRbegc-DyNO7toChlWr8TrDwNMR1WUFI_A_eyG0QjS0TPyqJ7qeaq1DWrvAG__1IOr6Uis97ScHzlO2-j7FDTfBF_N1HJd7l--EjcV04eAj0HkwY0YTpCubnKIUqdz2r0ZjorMyXAym9nDBVuYIiWeaS5Xk89U8iepMQVGgOmIeXHlfOrnb2OEgwLd0Tx2ahEZ_sF0H7znHSWSCbe_5rLwWT1tC8XuUAcOwhh22RP0L_B325KOjYJx7jrsM_xqg9Q0tv23Q
refresh_token
7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW
scope
openid offline_access
token_type
Bearer
2021-03-27 15:39:44 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2021-03-27 15:39:44 SUCCESS
CheckForAccessTokenValue
Found an access token
access_token
fFdY9wsaH1Yx4FiNiNI99EAm3XU7Pk9FlV6fET6UKx3
2021-03-27 15:39:44 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
fFdY9wsaH1Yx4FiNiNI99EAm3XU7Pk9FlV6fET6UKx3
type
Bearer
2021-03-27 15:39:44 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
7200
2021-03-27 15:39:44 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
7200
2021-03-27 15:39:44 SUCCESS
CheckForRefreshTokenValue
Found a refresh token
refresh_token
7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW
2021-03-27 15:39:44 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJhdF9oYXNoIjoiQTVCYzdYOG5OWk10THdCeVpOa2Z2USIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4NCwiaWF0IjoxNjE2ODU5NTg0LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.CBzR2Shiw9MGIHDaS9gBQEcmDHqeWFUriHf5-wyyF3Oh3EhX4_nCTdeK799nEIq8L7ycPu1wYG0gk6pzRbegc-DyNO7toChlWr8TrDwNMR1WUFI_A_eyG0QjS0TPyqJ7qeaq1DWrvAG__1IOr6Uis97ScHzlO2-j7FDTfBF_N1HJd7l--EjcV04eAj0HkwY0YTpCubnKIUqdz2r0ZjorMyXAym9nDBVuYIiWeaS5Xk89U8iepMQVGgOmIeXHlfOrnb2OEgwLd0Tx2ahEZ_sF0H7znHSWSCbe_5rLwWT1tC8XuUAcOwhh22RP0L_B325KOjYJx7jrsM_xqg9Q0tv23Q
header
{
  "kid": "9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4",
  "typ": "JWT",
  "alg": "RS256"
}
claims
{
  "at_hash": "A5Bc7X8nNZMtLwByZNkfvQ",
  "sub": "certification_1",
  "aud": "XAWhFzWUWotR7pbibc546",
  "iss": "https://certification.plusauth.com",
  "exp": 1616863184,
  "nonce": "9eBGcM06pE",
  "iat": 1616859584
}
2021-03-27 15:39:44 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2021-03-27 15:39:44 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
9eBGcM06pE
2021-03-27 15:39:44 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2021-03-27 15:39:44 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJhdF9oYXNoIjoiQTVCYzdYOG5OWk10THdCeVpOa2Z2USIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4NCwiaWF0IjoxNjE2ODU5NTg0LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.CBzR2Shiw9MGIHDaS9gBQEcmDHqeWFUriHf5-wyyF3Oh3EhX4_nCTdeK799nEIq8L7ycPu1wYG0gk6pzRbegc-DyNO7toChlWr8TrDwNMR1WUFI_A_eyG0QjS0TPyqJ7qeaq1DWrvAG__1IOr6Uis97ScHzlO2-j7FDTfBF_N1HJd7l--EjcV04eAj0HkwY0YTpCubnKIUqdz2r0ZjorMyXAym9nDBVuYIiWeaS5Xk89U8iepMQVGgOmIeXHlfOrnb2OEgwLd0Tx2ahEZ_sF0H7znHSWSCbe_5rLwWT1tC8XuUAcOwhh22RP0L_B325KOjYJx7jrsM_xqg9Q0tv23Q
2021-03-27 15:39:44 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJhdF9oYXNoIjoiQTVCYzdYOG5OWk10THdCeVpOa2Z2USIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4NCwiaWF0IjoxNjE2ODU5NTg0LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.CBzR2Shiw9MGIHDaS9gBQEcmDHqeWFUriHf5-wyyF3Oh3EhX4_nCTdeK799nEIq8L7ycPu1wYG0gk6pzRbegc-DyNO7toChlWr8TrDwNMR1WUFI_A_eyG0QjS0TPyqJ7qeaq1DWrvAG__1IOr6Uis97ScHzlO2-j7FDTfBF_N1HJd7l--EjcV04eAj0HkwY0YTpCubnKIUqdz2r0ZjorMyXAym9nDBVuYIiWeaS5Xk89U8iepMQVGgOmIeXHlfOrnb2OEgwLd0Tx2ahEZ_sF0H7znHSWSCbe_5rLwWT1tC8XuUAcOwhh22RP0L_B325KOjYJx7jrsM_xqg9Q0tv23Q
2021-03-27 15:39:44 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
certification_1
2021-03-27 15:39:44 SUCCESS
VerifyIdTokenSubConsistentHybridFlow
authorization endpoint and token endpoint id_token have same sub
sub_auth_endpoint
certification_1
sub_token_endpoint
certification_1
2021-03-27 15:39:44 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW
2021-03-27 15:39:44 SUCCESS
EnsureServerConfigurationSupportsRefreshToken
The server configuration indicates support for refresh tokens
supported_grant_types
[
  "implicit",
  "authorization_code",
  "refresh_token",
  "client_credentials",
  "urn:ietf:params:oauth:grant-type:device_code",
  "urn:ietf:params:oauth:grant-type:token-exchange"
]
2021-03-27 15:39:44 SUCCESS
EnsureRefreshTokenContainsAllowedCharactersOnly
Refresh token does not contain any illegal characters
Second client: Refresh Token Request
2021-03-27 15:39:44 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW
2021-03-27 15:39:44 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic WEFXaEZ6V1VXb3RSN3BiaWJjNTQ2OkpTdjRGM1p1RmdVTEczbDJZanJOOXkzRHNTSThXOTI2ZlFwcUQ3WXRSTXBLN0FhcEk2U0QwcFBJR3ZkQ2VXR0dvdTBOcmNnNXcwSlZ1cVIyZlBNNGN3
2021-03-27 15:39:44 SUCCESS
WaitForOneSecond
Pausing for 1 seconds
2021-03-27 15:39:45 SUCCESS
WaitForOneSecond
Woke up after 1 seconds sleep
2021-03-27 15:39:45
CallTokenEndpointAndReturnFullResponse
HTTP request
request_uri
https://certification.plusauth.com/oauth/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic WEFXaEZ6V1VXb3RSN3BiaWJjNTQ2OkpTdjRGM1p1RmdVTEczbDJZanJOOXkzRHNTSThXOTI2ZlFwcUQ3WXRSTXBLN0FhcEk2U0QwcFBJR3ZkQ2VXR0dvdTBOcmNnNXcwSlZ1cVIyZlBNNGN3",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "82"
}
request_body
grant_type=refresh_token&refresh_token=7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW
2021-03-27 15:39:45 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "911",
  "date": "Sat, 27 Mar 2021 15:39:45 GMT",
  "x-envoy-upstream-service-time": "32",
  "server": "istio-envoy"
}
response_body
{"access_token":"SLHmblThX3pbAVKvfFmalexUPacJxUQ_UmI_7pwavh7","expires_in":7200,"id_token":"eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJhdF9oYXNoIjoiVW1HMW9rR1MwdW1FSnJPMGpnbGVDQSIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4NSwiaWF0IjoxNjE2ODU5NTg1LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Krx5jgDLHxqHUYD2WmHRaGFsSUqQca-IjE8aok5b6WMKIpMaqoD0HroZZfb7_LXKq2L1ZmQSqiwP_y4hggtd-_aQOJh9JzNuRPtQw8gqERLbAwv1W6XzFULYMYqn2IoKUIiETnpdrZ9harxs7r2oWJIBQm_cOluz0K1sxqNNvp2yPIbIZrUhP3SlUaVhSBhT4Q8_aAvQhHD-urJatexd0LxERLGMKgAwMKP3NuEAvgJ52oulqf9locC2lPdQVyNfRqL5y4kjI4K7mxAionDoVU_hVOp5wHgYID1lQPt2So5pNFlt6LK8o8tq71ztOXb5b2zO7BHcKQrMTQoKBM5Rrw","refresh_token":"7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW","scope":"openid offline_access","token_type":"Bearer"}
2021-03-27 15:39:45 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
access_token
SLHmblThX3pbAVKvfFmalexUPacJxUQ_UmI_7pwavh7
expires_in
7200
id_token
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJhdF9oYXNoIjoiVW1HMW9rR1MwdW1FSnJPMGpnbGVDQSIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4NSwiaWF0IjoxNjE2ODU5NTg1LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Krx5jgDLHxqHUYD2WmHRaGFsSUqQca-IjE8aok5b6WMKIpMaqoD0HroZZfb7_LXKq2L1ZmQSqiwP_y4hggtd-_aQOJh9JzNuRPtQw8gqERLbAwv1W6XzFULYMYqn2IoKUIiETnpdrZ9harxs7r2oWJIBQm_cOluz0K1sxqNNvp2yPIbIZrUhP3SlUaVhSBhT4Q8_aAvQhHD-urJatexd0LxERLGMKgAwMKP3NuEAvgJ52oulqf9locC2lPdQVyNfRqL5y4kjI4K7mxAionDoVU_hVOp5wHgYID1lQPt2So5pNFlt6LK8o8tq71ztOXb5b2zO7BHcKQrMTQoKBM5Rrw
refresh_token
7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW
scope
openid offline_access
token_type
Bearer
2021-03-27 15:39:45 SUCCESS
CheckTokenEndpointHttpStatus200
Token endpoint http status code was 200
2021-03-27 15:39:45 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2021-03-27 15:39:45 SUCCESS
CheckTokenEndpointCacheHeaders
'pragma' and 'cache-control' headers in token endpoint response contain expected values.
cache_control_header
no-cache, no-store
pragma_header
no-cache
2021-03-27 15:39:45 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2021-03-27 15:39:45 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
SLHmblThX3pbAVKvfFmalexUPacJxUQ_UmI_7pwavh7
type
Bearer
2021-03-27 15:39:45 SUCCESS
CheckTokenTypeIsBearer
Token type is bearer
2021-03-27 15:39:45 SUCCESS
EnsureMinimumAccessTokenEntropy
Calculated shannon entropy seems sufficient
actual
203.06472194569977
expected
96.0
2021-03-27 15:39:45 SUCCESS
EnsureAccessTokenContainsAllowedCharactersOnly
Access token does not contain any illegal characters
2021-03-27 15:39:46 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
7200
2021-03-27 15:39:46 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
7200
2021-03-27 15:39:46 SUCCESS
EnsureAccessTokenValuesAreDifferent
Access token values are not the same
first_access_token
fFdY9wsaH1Yx4FiNiNI99EAm3XU7Pk9FlV6fET6UKx3
second_access_token
SLHmblThX3pbAVKvfFmalexUPacJxUQ_UmI_7pwavh7
2021-03-27 15:39:46 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IjlkdFRNR29rQVl1REdRamRFNmx5aHdSX3dNMENnaWhCLUJYNmxrNi1aTzQifQ.eyJzdWIiOiJjZXJ0aWZpY2F0aW9uXzEiLCJub25jZSI6IjllQkdjTTA2cEUiLCJhdF9oYXNoIjoiVW1HMW9rR1MwdW1FSnJPMGpnbGVDQSIsImF1ZCI6IlhBV2hGeldVV290UjdwYmliYzU0NiIsImV4cCI6MTYxNjg2MzE4NSwiaWF0IjoxNjE2ODU5NTg1LCJpc3MiOiJodHRwczovL2NlcnRpZmljYXRpb24ucGx1c2F1dGguY29tIn0.Krx5jgDLHxqHUYD2WmHRaGFsSUqQca-IjE8aok5b6WMKIpMaqoD0HroZZfb7_LXKq2L1ZmQSqiwP_y4hggtd-_aQOJh9JzNuRPtQw8gqERLbAwv1W6XzFULYMYqn2IoKUIiETnpdrZ9harxs7r2oWJIBQm_cOluz0K1sxqNNvp2yPIbIZrUhP3SlUaVhSBhT4Q8_aAvQhHD-urJatexd0LxERLGMKgAwMKP3NuEAvgJ52oulqf9locC2lPdQVyNfRqL5y4kjI4K7mxAionDoVU_hVOp5wHgYID1lQPt2So5pNFlt6LK8o8tq71ztOXb5b2zO7BHcKQrMTQoKBM5Rrw
header
{
  "kid": "9dtTMGokAYuDGQjdE6lyhwR_wM0CgihB-BX6lk6-ZO4",
  "typ": "JWT",
  "alg": "RS256"
}
claims
{
  "at_hash": "UmG1okGS0umEJrO0jgleCA",
  "sub": "certification_1",
  "aud": "XAWhFzWUWotR7pbibc546",
  "iss": "https://certification.plusauth.com",
  "exp": 1616863185,
  "nonce": "9eBGcM06pE",
  "iat": 1616859585
}
2021-03-27 15:39:46 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW
2021-03-27 15:39:46 SUCCESS
EnsureMinimumRefreshTokenLength
Refresh token is of sufficient length
actual
344
required
128
2021-03-27 15:39:46 SUCCESS
EnsureMinimumRefreshTokenEntropy
Calculated shannon entropy seems sufficient
actual
212.5744969500267
expected
96.0
2021-03-27 15:39:46 SUCCESS
CompareIdTokenClaims
Validated id token claims successfully
iss
{
  "first": "https://certification.plusauth.com",
  "second": "https://certification.plusauth.com",
  "note": "Values are expected to be equal"
}
sub
{
  "first": "certification_1",
  "second": "certification_1",
  "note": "Values are expected to be equal"
}
iat
{
  "first": 1616859584,
  "second": 1616859585,
  "note": "Values are expected to be different"
}
aud
{
  "first": "XAWhFzWUWotR7pbibc546",
  "second": "XAWhFzWUWotR7pbibc546",
  "note": "Values are expected to be equal"
}
azp
Id tokens do not contain azp claims
Second client: Userinfo endpoint tests
2021-03-27 15:39:46
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://certification.plusauth.com/me
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer SLHmblThX3pbAVKvfFmalexUPacJxUQ_UmI_7pwavh7",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2021-03-27 15:39:46 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "x-fapi-interaction-id": "f5fc914d-d32b-4d8f-b598-9fbea3dd258c",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "25",
  "date": "Sat, 27 Mar 2021 15:39:46 GMT",
  "x-envoy-upstream-service-time": "13",
  "server": "istio-envoy"
}
response_body
{"sub":"certification_1"}
2021-03-27 15:39:46 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "x-fapi-interaction-id": "f5fc914d-d32b-4d8f-b598-9fbea3dd258c",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "25",
  "date": "Sat, 27 Mar 2021 15:39:46 GMT",
  "x-envoy-upstream-service-time": "13",
  "server": "istio-envoy"
}
status_code
{
  "code": 200
}
body
{"sub":"certification_1"}
Attempting to use refresh_token issued to client 2 with client 1
2021-03-27 15:39:46 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW
2021-03-27 15:39:46 SUCCESS
AddScopeToTokenEndpointRequest
Added scope of 'openid offline_access' to token endpoint request
grant_type
refresh_token
refresh_token
7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW
scope
openid offline_access
2021-03-27 15:39:46 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic RWcyaXloMUZTTHY0MHJ6X3lJc3g3OmJVZmVJWFRBMXUxMzZnNzl1SzIyNGxORmhHTXJlaEJBbHJHazFEYktxck5tWlVkci1HLUJ6Wm93VTh0YVNIUGlLNTR4NUFkZUxpQ21sRnRlRTM1TlVn
2021-03-27 15:39:46
CallTokenEndpointAndReturnFullResponse
HTTP request
request_uri
https://certification.plusauth.com/oauth/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic RWcyaXloMUZTTHY0MHJ6X3lJc3g3OmJVZmVJWFRBMXUxMzZnNzl1SzIyNGxORmhHTXJlaEJBbHJHazFEYktxck5tWlVkci1HLUJ6Wm93VTh0YVNIUGlLNTR4NUFkZUxpQ21sRnRlRTM1TlVn",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "110"
}
request_body
grant_type=refresh_token&refresh_token=7KjLwN0I9iRLfEUrRXxoE7SW4i4MiO1rVG8cjt_CkDW&scope=openid+offline_access
2021-03-27 15:39:47 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
400 BAD_REQUEST
response_status_text
Bad Request
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "content-type": "application/json; charset\u003dutf-8",
  "content-length": "72",
  "date": "Sat, 27 Mar 2021 15:39:47 GMT",
  "x-envoy-upstream-service-time": "8",
  "server": "istio-envoy"
}
response_body
{"error":"invalid_grant","error_description":"grant request is invalid"}
2021-03-27 15:39:47 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
error
invalid_grant
error_description
grant request is invalid
2021-03-27 15:39:47 SUCCESS
ValidateErrorFromTokenEndpointResponseError
Token endpoint response error returned valid 'error' field
error
invalid_grant
2021-03-27 15:39:47 SUCCESS
CheckTokenEndpointHttpStatus400
Token endpoint http status code was 400
2021-03-27 15:39:47 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2021-03-27 15:39:47 SUCCESS
CheckErrorFromTokenEndpointResponseErrorInvalidGrant
Token Endpoint response error returned expected 'error' of 'invalid_grant'
error
invalid_grant
2021-03-27 15:39:47 FINISHED
oidcc-refresh-token
Test has run to completion
testmodule_result
PASSED
Unregister dynamically registered client
2021-03-27 15:39:47
UnregisterDynamicallyRegisteredClient
HTTP request
request_uri
https://certification.plusauth.com/oauth/reg/Eg2iyh1FSLv40rz_yIsx7
request_method
DELETE
request_headers
{
  "accept": "application/json",
  "accept-charset": "utf-8",
  "authorization": "Bearer sNqu02Xgn2-tOX8FFcc17pqd6TN3y7zLW6EpJTtORDN",
  "content-length": "0"
}
request_body

                                
2021-03-27 15:39:47 RESPONSE
UnregisterDynamicallyRegisteredClient
HTTP response
response_status_code
204 NO_CONTENT
response_status_text
No Content
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "date": "Sat, 27 Mar 2021 15:39:47 GMT",
  "x-envoy-upstream-service-time": "15",
  "server": "istio-envoy"
}
response_body

                                
2021-03-27 15:39:47 SUCCESS
UnregisterDynamicallyRegisteredClient
Client successfully unregistered
Second client: Unregister dynamically registered client
2021-03-27 15:39:47
UnregisterDynamicallyRegisteredClient
HTTP request
request_uri
https://certification.plusauth.com/oauth/reg/XAWhFzWUWotR7pbibc546
request_method
DELETE
request_headers
{
  "accept": "application/json",
  "accept-charset": "utf-8",
  "authorization": "Bearer S3qVwhx0Qxn4oQW42Omn-x7mvpyQcZkpPhJr4xZYmEr",
  "content-length": "0"
}
request_body

                                
2021-03-27 15:39:48 RESPONSE
UnregisterDynamicallyRegisteredClient
HTTP response
response_status_code
204 NO_CONTENT
response_status_text
No Content
response_headers
{
  "vary": "Origin",
  "pragma": "no-cache",
  "cache-control": "no-cache, no-store",
  "date": "Sat, 27 Mar 2021 15:39:48 GMT",
  "x-envoy-upstream-service-time": "8",
  "server": "istio-envoy"
}
response_body

                                
2021-03-27 15:39:48 SUCCESS
UnregisterDynamicallyRegisteredClient
Client successfully unregistered
2021-03-27 15:39:50
TEST-RUNNER
Alias has now been claimed by another test
alias
oidc-provider-discovery-dynamic_client
new_test_id
ElmzX1zlTxDOyhZ
Test Results