Test Summary

Test Results

Expand All Collapse All
All times are UTC
2020-07-31 12:30:59 INFO
TEST-RUNNER
Test instance AA1koCLYCJ2tyuO created
baseUrl
https://www.certification.openid.net/test/a/oidf-authlete-core
variant
{
  "client_auth_type": "client_secret_basic",
  "response_type": "code id_token token",
  "server_metadata": "static",
  "response_mode": "form_post",
  "client_registration": "static_client"
}
alias
oidf-authlete-core
description
Authlete plain OIDC client secret basic - static server config
planId
f4s0MatdN55iD
config
{
  "alias": "oidf-authlete-core",
  "description": "Authlete plain OIDC client secret basic - static server config",
  "publish": "everything",
  "server": {
    "issuer": "https://fapidev-as.authlete.net/",
    "jwks_uri": "https://fapidev-as.authlete.net/api/jwks",
    "authorization_endpoint": "https://fapidev-www.authlete.net/api/authorization",
    "token_endpoint": "https://fapidev-as.authlete.net/api/token",
    "userinfo_endpoint": "https://fapidev-rs.authlete.net/api/userinfo",
    "acr_values": "urn:mace:incommon:iap:silver urn:openbanking:psd2:sca urn:openbanking:psd2:ca",
    "login_hint": "john"
  },
  "client": {
    "client_id": "470519824180317",
    "client_secret": "Ek2CiuOrmfdhvsjGl037_pscCmYseks4bzSSxc3UZUcr-9Ki2rlCRdg_Mt-Ukc9b-LpajnMUcwmzqgXs-eDKzw"
  },
  "client_secret_post": {
    "client_id": "469894541303688",
    "client_secret": "SGMsD1U1t0iZXChy0YtbnICAfU9ULEgh5MElWNX6iOq0sWYI0TGiTn-4mRDlhsSOQGfWoZwYWqKAubsbrY7nfA"
  },
  "client2": {
    "client_id": "470553331604632",
    "client_secret": "3NLezSFOjyxuERp_cH3zFMbym9oNur3NMdYIJWimiTHEKROvsDTT1-BVfo8AbLNiUgyIbbGcr79n7fkTL7D8qA"
  },
  "browser": [
    {
      "match": "https://fapidev-www.authlete.net/api/authorization*",
      "tasks": [
        {
          "task": "Initial Login",
          "optional": true,
          "match": "https://fapidev-www.authlete.net/api/authorization*",
          "commands": [
            [
              "text",
              "id",
              "loginId",
              "john",
              "optional"
            ],
            [
              "text",
              "id",
              "password",
              "john",
              "optional"
            ],
            [
              "click",
              "name",
              "authorized"
            ]
          ]
        },
        {
          "task": "Verify Complete",
          "match": "https://*/test/a/oidf-authlete-core/callback*",
          "commands": [
            [
              "wait",
              "id",
              "submission_complete",
              10
            ]
          ]
        }
      ]
    }
  ]
}
testName
oidcc-refresh-token
2020-07-31 12:30:59 SUCCESS
CreateRedirectUri
Created redirect URI
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
2020-07-31 12:30:59 SUCCESS
GetStaticServerConfiguration
Found a static server object
issuer
https://fapidev-as.authlete.net/
jwks_uri
https://fapidev-as.authlete.net/api/jwks
authorization_endpoint
https://fapidev-www.authlete.net/api/authorization
token_endpoint
https://fapidev-as.authlete.net/api/token
userinfo_endpoint
https://fapidev-rs.authlete.net/api/userinfo
acr_values
urn:mace:incommon:iap:silver urn:openbanking:psd2:sca urn:openbanking:psd2:ca
login_hint
john
2020-07-31 12:30:59 SUCCESS
CheckServerConfiguration
Found required server configuration keys
required
[
  "authorization_endpoint",
  "token_endpoint",
  "issuer"
]
2020-07-31 12:30:59 SUCCESS
ExtractTLSTestValuesFromServerConfiguration
Extracted TLS information from authorization server configuration
registration_endpoint
authorization_endpoint
{
  "testHost": "fapidev-www.authlete.net",
  "testPort": 443
}
token_endpoint
{
  "testHost": "fapidev-as.authlete.net",
  "testPort": 443
}
userinfo_endpoint
{
  "testHost": "fapidev-rs.authlete.net",
  "testPort": 443
}
2020-07-31 12:30:59
FetchServerKeys
Fetching server key
jwks_uri
https://fapidev-as.authlete.net/api/jwks
2020-07-31 12:30:59
FetchServerKeys
HTTP request
request_uri
https://fapidev-as.authlete.net/api/jwks
request_method
GET
request_headers
{
  "accept": "text/plain, application/json, application/cbor, application/*+json, */*",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:30:59 RESPONSE
FetchServerKeys
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:30:59 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "472",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "kid": "authlete-fapidev-api-20180524",
      "n": "nJclr5TJ3Y21Ggt0lz2EO7wWKn6jTaIlMv1sNMy2VmkcSf8EVsFqJ1vSXjFxWvBj7RolFCyaChFwI_jog9c2rAkIwF8Voi5eB3PRjl3OaNRUYILRgLsaclTj02NWMvwbiJ18yJ63D4Ojzif8_RyAHuM3HO2rs6nPEyZMW3Xd0z3Lw099TpIcxA4Ktfo2DliUfMZh9s3lB_f6DSxX5Z9CXqrzNsoCCxqJZ55WuUUNA4LmYl5OgrH8sD7_TvY1QTjjmRzUptgj1S-gwagIjrkn9ooALa8gRN4etKztA2topBn0KO2VwEo_P4iejBn2Z3I2FlQnDNu0t7xNwBhsM2Vg8Q"
    }
  ]
}
2020-07-31 12:30:59
FetchServerKeys
Found JWK set string
jwk_string
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "kid": "authlete-fapidev-api-20180524",
      "n": "nJclr5TJ3Y21Ggt0lz2EO7wWKn6jTaIlMv1sNMy2VmkcSf8EVsFqJ1vSXjFxWvBj7RolFCyaChFwI_jog9c2rAkIwF8Voi5eB3PRjl3OaNRUYILRgLsaclTj02NWMvwbiJ18yJ63D4Ojzif8_RyAHuM3HO2rs6nPEyZMW3Xd0z3Lw099TpIcxA4Ktfo2DliUfMZh9s3lB_f6DSxX5Z9CXqrzNsoCCxqJZ55WuUUNA4LmYl5OgrH8sD7_TvY1QTjjmRzUptgj1S-gwagIjrkn9ooALa8gRN4etKztA2topBn0KO2VwEo_P4iejBn2Z3I2FlQnDNu0t7xNwBhsM2Vg8Q"
    }
  ]
}
2020-07-31 12:30:59 SUCCESS
FetchServerKeys
Found server JWK set
server_jwks
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "kid": "authlete-fapidev-api-20180524",
      "n": "nJclr5TJ3Y21Ggt0lz2EO7wWKn6jTaIlMv1sNMy2VmkcSf8EVsFqJ1vSXjFxWvBj7RolFCyaChFwI_jog9c2rAkIwF8Voi5eB3PRjl3OaNRUYILRgLsaclTj02NWMvwbiJ18yJ63D4Ojzif8_RyAHuM3HO2rs6nPEyZMW3Xd0z3Lw099TpIcxA4Ktfo2DliUfMZh9s3lB_f6DSxX5Z9CXqrzNsoCCxqJZ55WuUUNA4LmYl5OgrH8sD7_TvY1QTjjmRzUptgj1S-gwagIjrkn9ooALa8gRN4etKztA2topBn0KO2VwEo_P4iejBn2Z3I2FlQnDNu0t7xNwBhsM2Vg8Q"
    }
  ]
}
2020-07-31 12:30:59 SUCCESS
CheckServerKeysIsValid
Server JWKs is valid
server_jwks
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "kid": "authlete-fapidev-api-20180524",
      "n": "nJclr5TJ3Y21Ggt0lz2EO7wWKn6jTaIlMv1sNMy2VmkcSf8EVsFqJ1vSXjFxWvBj7RolFCyaChFwI_jog9c2rAkIwF8Voi5eB3PRjl3OaNRUYILRgLsaclTj02NWMvwbiJ18yJ63D4Ojzif8_RyAHuM3HO2rs6nPEyZMW3Xd0z3Lw099TpIcxA4Ktfo2DliUfMZh9s3lB_f6DSxX5Z9CXqrzNsoCCxqJZ55WuUUNA4LmYl5OgrH8sD7_TvY1QTjjmRzUptgj1S-gwagIjrkn9ooALa8gRN4etKztA2topBn0KO2VwEo_P4iejBn2Z3I2FlQnDNu0t7xNwBhsM2Vg8Q"
    }
  ]
}
2020-07-31 12:30:59 SUCCESS
ValidateServerJWKs
Valid server JWKs: keys are valid JSON, contain the required fields and are correctly encoded using unpadded base64url
2020-07-31 12:30:59 SUCCESS
CheckForKeyIdInServerJWKs
All keys contain kids
2020-07-31 12:30:59 SUCCESS
CheckDistinctKeyIdValueInServerJWKs
Distinct 'kid' value in all keys of server_jwks
see
https://bitbucket.org/openid/connect/issues/1127
2020-07-31 12:30:59 SUCCESS
EnsureServerJwksDoesNotContainPrivateOrSymmetricKeys
Jwks does not contain any private or symmetric keys
2020-07-31 12:30:59 SUCCESS
GetStaticClientConfiguration
Found a static client object
client_id
470519824180317
client_secret
Ek2CiuOrmfdhvsjGl037_pscCmYseks4bzSSxc3UZUcr-9Ki2rlCRdg_Mt-Ukc9b-LpajnMUcwmzqgXs-eDKzw
2020-07-31 12:30:59
SetScopeInClientConfigurationToOpenIdOfflineAccess
Set scope in client configuration to "openid offline_access" so that a refresh token is issued
scope
openid offline_access
2020-07-31 12:30:59 SUCCESS
GetStaticClient2Configuration
Found a static second client object
client_id
470553331604632
client_secret
3NLezSFOjyxuERp_cH3zFMbym9oNur3NMdYIJWimiTHEKROvsDTT1-BVfo8AbLNiUgyIbbGcr79n7fkTL7D8qA
2020-07-31 12:30:59
SetScopeInClientConfigurationToOpenIdOfflineAccess
Set scope in client configuration to "openid offline_access" so that a refresh token is issued
scope
openid offline_access
2020-07-31 12:30:59 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://fapidev-rs.authlete.net/api/userinfo
2020-07-31 12:30:59
oidcc-refresh-token
Setup Done
Make request to authorization endpoint
2020-07-31 12:30:59 SUCCESS
CreateAuthorizationEndpointRequestFromClientInformation
Created authorization endpoint request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
2020-07-31 12:30:59
CreateRandomStateValue
Created state value
requested_state_length
10
state
z37iDxb8KF
2020-07-31 12:30:59 SUCCESS
AddStateToAuthorizationEndpointRequest
Added state parameter to request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
z37iDxb8KF
2020-07-31 12:30:59
CreateRandomNonceValue
Created nonce value
requested_nonce_length
10
nonce
LRahdgZx27
2020-07-31 12:30:59 SUCCESS
AddNonceToAuthorizationEndpointRequest
Added nonce parameter to request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
z37iDxb8KF
nonce
LRahdgZx27
2020-07-31 12:30:59 SUCCESS
SetAuthorizationEndpointRequestResponseTypeFromEnvironment
Added response_type parameter to request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
z37iDxb8KF
nonce
LRahdgZx27
response_type
code id_token token
2020-07-31 12:30:59
SetAuthorizationEndpointRequestResponseModeToFormPost
Added response_mode parameter to request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
z37iDxb8KF
nonce
LRahdgZx27
response_type
code id_token token
response_mode
form_post
2020-07-31 12:30:59 SUCCESS
AddPromptConsentToAuthorizationEndpointRequestIfScopeContainsOfflineAccess
Added prompt=consent to authorization endpoint request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
z37iDxb8KF
nonce
LRahdgZx27
response_type
code id_token token
response_mode
form_post
prompt
consent
2020-07-31 12:30:59 SUCCESS
BuildPlainRedirectToAuthorizationEndpoint
Sending to authorization endpoint
redirect_to_authorization_endpoint
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=z37iDxb8KF&nonce=LRahdgZx27&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
2020-07-31 12:30:59 REDIRECT
oidcc-refresh-token
Redirecting to authorization endpoint
redirect_to
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=z37iDxb8KF&nonce=LRahdgZx27&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
2020-07-31 12:30:59
WebRunner
Scripted browser HTTP request
browser
goToUrl
request_method
GET
request_uri
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=z37iDxb8KF&nonce=LRahdgZx27&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
2020-07-31 12:31:00 RESPONSE
WebRunner
Scripted browser HTTP response
response_content
<!doctype html>
<!---->
<!--




-->
<html>
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes">
  <title>FAPI Test Service | Authorization</title>
  <link rel="stylesheet" href="/css/authorization.css">
  <!--  //-->
</head>
<body class="font-default">
  <div id="page_title">FAPI Test Service</div>

  <div id="content">
    <h3 id="client-name">core conformance client secret basic</h3>
    <div class="indent">
      <img id="logo" src="https://button.heenan.me.uk/~joseph/authlete-150x150.png" alt="[Logo] (150x150)">

      <div id="client-summary">
        <p>core conformance client secret basic</p>
        <ul id="client-link-list">
          

          

          
        </ul>
      </div>

      <div style="clear: both;"></div>
    </div>

    
    <h4 id="permissions">Permissions</h4>
    <div class="indent">
      <p>The application is requesting the following permissions.</p>

      <dl id="scope-list">
        
        <dt>offline_access</dt>
        <dd>A permission to request a refresh token exchangeable with an access token which can access the UserInfo Endpoint even when the end-user is offline. See OpenID Connect Core 1.0, 11. for details.</dd>
        
        <dt>openid</dt>
        <dd>A permission to request an OpenID Provider to issue an ID Token. See OpenID Connect Core 1.0, 3.1.2.1. for details.</dd>
        
      </dl>
    </div>
    

    

    

    <h4 id="authorization">Authorization</h4>
    <div class="indent">
      <p>Do you grant authorization to the application?</p>

      <form id="authorization-form" action="/api/authorization/decision" method="POST">
        
        <div id="login-fields" class="indent">
          <div id="login-prompt">Input Login ID and password.</div>
          <input type="text" id="loginId" name="loginId" placeholder="Login ID"
                 autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"
                 class="font-default" required value="" >
          <input type="password" id="password" name="password" placeholder="Password"
                 class="font-default" required>
        </div>
        
        
        <div id="authorization-form-buttons">
          <input type="submit" name="authorized" id="authorize-button" value="Authorize" class="font-default"/>
          <input type="submit" name="denied"     id="deny-button"      value="Deny"      class="font-default"/>
        </div>
      </form>
    </div>
  </div>

</body>
</html>
response_content_type
*/*
response_status_text
200-OK
response_status_code
200
2020-07-31 12:31:00 INFO
WebRunner
Entering text
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=z37iDxb8KF&nonce=LRahdgZx27&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
target
loginId
2020-07-31 12:31:00 INFO
WebRunner
Entering text
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=z37iDxb8KF&nonce=LRahdgZx27&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
target
password
2020-07-31 12:31:00 INFO
WebRunner
Clicking an element
task
Initial Login
browser
click
element_type
name
url
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=z37iDxb8KF&nonce=LRahdgZx27&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
target
authorized
2020-07-31 12:31:00 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance AA1koCLYCJ2tyuO
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/webp,image/apng,*/*;q\u003d0.8",
  "referer": "https://fapidev-www.authlete.net/api/authorization/decision",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "origin": "https://fapidev-www.authlete.net/api/authorization/decision",
  "cache-control": "max-age\u003d0",
  "content-type": "application/x-www-form-urlencoded",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "1623",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
callback
incoming_body_form_params
{
  "state": "z37iDxb8KF",
  "code": "EUECfanrCXYapddyrhDtkKWFg6sye3lbrs7F6dpqf4w",
  "access_token": "eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MCwiaWF0IjoxNTk2MTk4NjYwLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJvTUI4NmltRHk0WUZWclE2Zm11Vmd6dFY3M3FlYUNiUFQ2QkcyT25OdTM4In0.LqCN8yFvh0cHe1sjcZ-UKFJSguqPlhG1TyE_mrwZVV0NpjWFb0jFf_wsfojE5KTK7P23g5vndEHwI1_m6xJzYdchZjagGljsDh0Gho36BnsiKkkWLAfBYxvsmlo4VmDghyyMVWXFMIEXo3fr0as_SdflJ9XqPTiuaT36Pj4ZvmHi6etqanONdFOYQjhlpfr911xAv3YGdTaC_7fQaYYKhOQEJCk5WfGyAKSsH3y_KQVenBZ2swjdaJrebh-a4IspKEgszOfU5b3vP8LyOHqn7wJAqiJ5agwtklW02Rrp4NDrYY7KDlcQm8zTPHmN49e9C_5cWlZN7wLOJsZznjB88A",
  "token_type": "Bearer",
  "expires_in": "86400",
  "scope": "offline_access openid",
  "id_token": "eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiRkVuRGhYUEUtZklIYWNjVVl6V3hyZyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTE5ODI0MTgwMzE3Il0sImNfaGFzaCI6IlNNOGNqaXEzTGFtVmtQSmZvYXdhM3ciLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MCwiaWF0IjoxNTk2MTk4NjYwLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.LvssemVERrHSIPVNKHYsbLv8zFSO-5IptmisVSIXIRyDVD02179PMXAj_lOPtlPpFAHFTPE5LTHq3BMmuFPGJxzXXi0-1eaDCVY-7IRHZnldTAixzArQfDrndzOzLPP2NSgyXPf9kjYsqgj__NZ74myxx-y8hvNP1BvbJ-Nd9xJPrEsQtkCWrCFxq8xhorbMKqfmbO6s0abL8hWnHT8bv7mmvSDYL-zr966ytkFOgQmdMCunxF1S64zcEfz9tH_ocX6UJArW2uxCD8ee73Z36KSKTstJrtiAdIqmv7-HuyMdIjkVF-KWZn5IvpXIzE_jk_nAtDnILlN7doz0ExP3iQ"
}
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
state=z37iDxb8KF&code=EUECfanrCXYapddyrhDtkKWFg6sye3lbrs7F6dpqf4w&access_token=eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MCwiaWF0IjoxNTk2MTk4NjYwLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJvTUI4NmltRHk0WUZWclE2Zm11Vmd6dFY3M3FlYUNiUFQ2QkcyT25OdTM4In0.LqCN8yFvh0cHe1sjcZ-UKFJSguqPlhG1TyE_mrwZVV0NpjWFb0jFf_wsfojE5KTK7P23g5vndEHwI1_m6xJzYdchZjagGljsDh0Gho36BnsiKkkWLAfBYxvsmlo4VmDghyyMVWXFMIEXo3fr0as_SdflJ9XqPTiuaT36Pj4ZvmHi6etqanONdFOYQjhlpfr911xAv3YGdTaC_7fQaYYKhOQEJCk5WfGyAKSsH3y_KQVenBZ2swjdaJrebh-a4IspKEgszOfU5b3vP8LyOHqn7wJAqiJ5agwtklW02Rrp4NDrYY7KDlcQm8zTPHmN49e9C_5cWlZN7wLOJsZznjB88A&token_type=Bearer&expires_in=86400&scope=offline_access+openid&id_token=eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiRkVuRGhYUEUtZklIYWNjVVl6V3hyZyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTE5ODI0MTgwMzE3Il0sImNfaGFzaCI6IlNNOGNqaXEzTGFtVmtQSmZvYXdhM3ciLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MCwiaWF0IjoxNTk2MTk4NjYwLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.LvssemVERrHSIPVNKHYsbLv8zFSO-5IptmisVSIXIRyDVD02179PMXAj_lOPtlPpFAHFTPE5LTHq3BMmuFPGJxzXXi0-1eaDCVY-7IRHZnldTAixzArQfDrndzOzLPP2NSgyXPf9kjYsqgj__NZ74myxx-y8hvNP1BvbJ-Nd9xJPrEsQtkCWrCFxq8xhorbMKqfmbO6s0abL8hWnHT8bv7mmvSDYL-zr966ytkFOgQmdMCunxF1S64zcEfz9tH_ocX6UJArW2uxCD8ee73Z36KSKTstJrtiAdIqmv7-HuyMdIjkVF-KWZn5IvpXIzE_jk_nAtDnILlN7doz0ExP3iQ
2020-07-31 12:31:00 SUCCESS
CreateRandomImplicitSubmitUrl
Created random implicit submission URL
implicit_submit
{
  "path": "implicit/9mIt1Uqu9d6K8qmsa6VZ",
  "fullUrl": "https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/9mIt1Uqu9d6K8qmsa6VZ"
}
2020-07-31 12:31:00 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance AA1koCLYCJ2tyuO
outgoing
ModelAndView [view="implicitCallback"; model={implicitSubmitUrl=https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/9mIt1Uqu9d6K8qmsa6VZ, returnUrl=/log-detail.html?log=AA1koCLYCJ2tyuO}]
outgoing_path
callback
2020-07-31 12:31:00 INFO
WebRunner
Completed processing of webpage
task
Initial Login
browser
complete
response_status_text
200-
match
https://fapidev-www.authlete.net/api/authorization*
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
response_status_code
200
2020-07-31 12:31:00 INFO
WebRunner
Waiting
regexp
seconds
10
task
Verify Complete
browser
wait
action
element_type
id
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
target
submission_complete
2020-07-31 12:31:00 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance AA1koCLYCJ2tyuO
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "*/*",
  "referer": "https://www.certification.openid.net/test/a/oidf-authlete-core/callback",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003d695B4733A1BE82B9C1C66CCA78AB586F",
  "x-requested-with": "XMLHttpRequest",
  "content-type": "text/plain",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "0",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
implicit/9mIt1Uqu9d6K8qmsa6VZ
incoming_body_form_params
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
2020-07-31 12:31:00 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance AA1koCLYCJ2tyuO
outgoing
org.springframework.web.servlet.view.RedirectView: [RedirectView]; URL [/log-detail.html?log=AA1koCLYCJ2tyuO]
outgoing_path
implicit/9mIt1Uqu9d6K8qmsa6VZ
2020-07-31 12:31:00 SUCCESS
ExtractImplicitHashToCallbackResponse
implicit_hash is empty
2020-07-31 12:31:00 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 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/webp,image/apng,*/*;q\u003d0.8",
  "referer": "https://fapidev-www.authlete.net/api/authorization/decision",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "origin": "https://fapidev-www.authlete.net/api/authorization/decision",
  "cache-control": "max-age\u003d0",
  "content-type": "application/x-www-form-urlencoded",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "1623",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
http_method
POST
url_fragment
{}
post_body
{
  "state": "z37iDxb8KF",
  "code": "EUECfanrCXYapddyrhDtkKWFg6sye3lbrs7F6dpqf4w",
  "access_token": "eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MCwiaWF0IjoxNTk2MTk4NjYwLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJvTUI4NmltRHk0WUZWclE2Zm11Vmd6dFY3M3FlYUNiUFQ2QkcyT25OdTM4In0.LqCN8yFvh0cHe1sjcZ-UKFJSguqPlhG1TyE_mrwZVV0NpjWFb0jFf_wsfojE5KTK7P23g5vndEHwI1_m6xJzYdchZjagGljsDh0Gho36BnsiKkkWLAfBYxvsmlo4VmDghyyMVWXFMIEXo3fr0as_SdflJ9XqPTiuaT36Pj4ZvmHi6etqanONdFOYQjhlpfr911xAv3YGdTaC_7fQaYYKhOQEJCk5WfGyAKSsH3y_KQVenBZ2swjdaJrebh-a4IspKEgszOfU5b3vP8LyOHqn7wJAqiJ5agwtklW02Rrp4NDrYY7KDlcQm8zTPHmN49e9C_5cWlZN7wLOJsZznjB88A",
  "token_type": "Bearer",
  "expires_in": "86400",
  "scope": "offline_access openid",
  "id_token": "eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiRkVuRGhYUEUtZklIYWNjVVl6V3hyZyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTE5ODI0MTgwMzE3Il0sImNfaGFzaCI6IlNNOGNqaXEzTGFtVmtQSmZvYXdhM3ciLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MCwiaWF0IjoxNTk2MTk4NjYwLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.LvssemVERrHSIPVNKHYsbLv8zFSO-5IptmisVSIXIRyDVD02179PMXAj_lOPtlPpFAHFTPE5LTHq3BMmuFPGJxzXXi0-1eaDCVY-7IRHZnldTAixzArQfDrndzOzLPP2NSgyXPf9kjYsqgj__NZ74myxx-y8hvNP1BvbJ-Nd9xJPrEsQtkCWrCFxq8xhorbMKqfmbO6s0abL8hWnHT8bv7mmvSDYL-zr966ytkFOgQmdMCunxF1S64zcEfz9tH_ocX6UJArW2uxCD8ee73Z36KSKTstJrtiAdIqmv7-HuyMdIjkVF-KWZn5IvpXIzE_jk_nAtDnILlN7doz0ExP3iQ"
}
Verify authorization endpoint response
2020-07-31 12:31:00 SUCCESS
CheckCallbackHttpMethodIsPost
HTTP method used at redirect_uri is 'POST'
2020-07-31 12:31:00 SUCCESS
CheckCallbackContentTypeIsFormUrlEncoded
content-type header to redirect_uri has the expected value
content_type
application/x-www-form-urlencoded
expected
application/x-www-form-urlencoded
2020-07-31 12:31:00 SUCCESS
RejectAuthCodeInUrlQuery
Authorization code is not present in URL query returned from authorization endpoint
2020-07-31 12:31:00 SUCCESS
RejectErrorInUrlQuery
'error' is not present in URL query returned from authorization endpoint
2020-07-31 12:31:00 SUCCESS
CheckMatchingCallbackParameters
Callback parameters successfully verified
2020-07-31 12:31:00 SUCCESS
CheckIfAuthorizationEndpointError
No error from authorization endpoint
2020-07-31 12:31:00 SUCCESS
CheckMatchingStateParameter
State parameter correctly returned
state
z37iDxb8KF
2020-07-31 12:31:00 SUCCESS
ExtractAuthorizationCodeFromAuthorizationResponse
Found authorization code
code
EUECfanrCXYapddyrhDtkKWFg6sye3lbrs7F6dpqf4w
2020-07-31 12:31:00 SUCCESS
ExtractAccessTokenFromAuthorizationResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MCwiaWF0IjoxNTk2MTk4NjYwLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJvTUI4NmltRHk0WUZWclE2Zm11Vmd6dFY3M3FlYUNiUFQ2QkcyT25OdTM4In0.LqCN8yFvh0cHe1sjcZ-UKFJSguqPlhG1TyE_mrwZVV0NpjWFb0jFf_wsfojE5KTK7P23g5vndEHwI1_m6xJzYdchZjagGljsDh0Gho36BnsiKkkWLAfBYxvsmlo4VmDghyyMVWXFMIEXo3fr0as_SdflJ9XqPTiuaT36Pj4ZvmHi6etqanONdFOYQjhlpfr911xAv3YGdTaC_7fQaYYKhOQEJCk5WfGyAKSsH3y_KQVenBZ2swjdaJrebh-a4IspKEgszOfU5b3vP8LyOHqn7wJAqiJ5agwtklW02Rrp4NDrYY7KDlcQm8zTPHmN49e9C_5cWlZN7wLOJsZznjB88A
type
Bearer
2020-07-31 12:31:00 SUCCESS
ExtractIdTokenFromAuthorizationResponse
Found and parsed the id_token from authorization_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiRkVuRGhYUEUtZklIYWNjVVl6V3hyZyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTE5ODI0MTgwMzE3Il0sImNfaGFzaCI6IlNNOGNqaXEzTGFtVmtQSmZvYXdhM3ciLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MCwiaWF0IjoxNTk2MTk4NjYwLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.LvssemVERrHSIPVNKHYsbLv8zFSO-5IptmisVSIXIRyDVD02179PMXAj_lOPtlPpFAHFTPE5LTHq3BMmuFPGJxzXXi0-1eaDCVY-7IRHZnldTAixzArQfDrndzOzLPP2NSgyXPf9kjYsqgj__NZ74myxx-y8hvNP1BvbJ-Nd9xJPrEsQtkCWrCFxq8xhorbMKqfmbO6s0abL8hWnHT8bv7mmvSDYL-zr966ytkFOgQmdMCunxF1S64zcEfz9tH_ocX6UJArW2uxCD8ee73Z36KSKTstJrtiAdIqmv7-HuyMdIjkVF-KWZn5IvpXIzE_jk_nAtDnILlN7doz0ExP3iQ
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "at_hash": "FEnDhXPE-fIHaccUYzWxrg",
  "sub": "1001",
  "aud": "470519824180317",
  "c_hash": "SM8cjiq3LamVkPJfoawa3w",
  "s_hash": "-rInw-zE9dMUnanAtDFLOA",
  "auth_time": 1596198660,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198960,
  "iat": 1596198660,
  "nonce": "LRahdgZx27"
}
2020-07-31 12:31:00 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:31:00 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
LRahdgZx27
2020-07-31 12:31:00 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:31:00 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiRkVuRGhYUEUtZklIYWNjVVl6V3hyZyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTE5ODI0MTgwMzE3Il0sImNfaGFzaCI6IlNNOGNqaXEzTGFtVmtQSmZvYXdhM3ciLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MCwiaWF0IjoxNTk2MTk4NjYwLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.LvssemVERrHSIPVNKHYsbLv8zFSO-5IptmisVSIXIRyDVD02179PMXAj_lOPtlPpFAHFTPE5LTHq3BMmuFPGJxzXXi0-1eaDCVY-7IRHZnldTAixzArQfDrndzOzLPP2NSgyXPf9kjYsqgj__NZ74myxx-y8hvNP1BvbJ-Nd9xJPrEsQtkCWrCFxq8xhorbMKqfmbO6s0abL8hWnHT8bv7mmvSDYL-zr966ytkFOgQmdMCunxF1S64zcEfz9tH_ocX6UJArW2uxCD8ee73Z36KSKTstJrtiAdIqmv7-HuyMdIjkVF-KWZn5IvpXIzE_jk_nAtDnILlN7doz0ExP3iQ
2020-07-31 12:31:00 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiRkVuRGhYUEUtZklIYWNjVVl6V3hyZyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTE5ODI0MTgwMzE3Il0sImNfaGFzaCI6IlNNOGNqaXEzTGFtVmtQSmZvYXdhM3ciLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MCwiaWF0IjoxNTk2MTk4NjYwLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.LvssemVERrHSIPVNKHYsbLv8zFSO-5IptmisVSIXIRyDVD02179PMXAj_lOPtlPpFAHFTPE5LTHq3BMmuFPGJxzXXi0-1eaDCVY-7IRHZnldTAixzArQfDrndzOzLPP2NSgyXPf9kjYsqgj__NZ74myxx-y8hvNP1BvbJ-Nd9xJPrEsQtkCWrCFxq8xhorbMKqfmbO6s0abL8hWnHT8bv7mmvSDYL-zr966ytkFOgQmdMCunxF1S64zcEfz9tH_ocX6UJArW2uxCD8ee73Z36KSKTstJrtiAdIqmv7-HuyMdIjkVF-KWZn5IvpXIzE_jk_nAtDnILlN7doz0ExP3iQ
2020-07-31 12:31:00 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
Userinfo endpoint tests
2020-07-31 12:31:00
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://fapidev-rs.authlete.net/api/userinfo
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MCwiaWF0IjoxNTk2MTk4NjYwLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJvTUI4NmltRHk0WUZWclE2Zm11Vmd6dFY3M3FlYUNiUFQ2QkcyT25OdTM4In0.LqCN8yFvh0cHe1sjcZ-UKFJSguqPlhG1TyE_mrwZVV0NpjWFb0jFf_wsfojE5KTK7P23g5vndEHwI1_m6xJzYdchZjagGljsDh0Gho36BnsiKkkWLAfBYxvsmlo4VmDghyyMVWXFMIEXo3fr0as_SdflJ9XqPTiuaT36Pj4ZvmHi6etqanONdFOYQjhlpfr911xAv3YGdTaC_7fQaYYKhOQEJCk5WfGyAKSsH3y_KQVenBZ2swjdaJrebh-a4IspKEgszOfU5b3vP8LyOHqn7wJAqiJ5agwtklW02Rrp4NDrYY7KDlcQm8zTPHmN49e9C_5cWlZN7wLOJsZznjB88A",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:31:01 INFO
WebRunner
Completed processing of webpage
task
Verify Complete
browser
complete
response_status_text
200-
match
https://*/test/a/oidf-authlete-core/callback*
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
response_status_code
200
2020-07-31 12:31:01 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:31:01 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"sub":"1001"}
2020-07-31 12:31:01 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:31:01 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
status_code
{
  "code": 200
}
body
{"sub":"1001"}
2020-07-31 12:31:01 SUCCESS
CreateTokenEndpointRequestForAuthorizationCodeGrant
grant_type
authorization_code
code
EUECfanrCXYapddyrhDtkKWFg6sye3lbrs7F6dpqf4w
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
2020-07-31 12:31:01 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3
2020-07-31 12:31:01
CallTokenEndpoint
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "177"
}
request_body
grant_type=authorization_code&code=EUECfanrCXYapddyrhDtkKWFg6sye3lbrs7F6dpqf4w&redirect_uri=https%3A%2F%2Fwww.certification.openid.net%2Ftest%2Fa%2Foidf-authlete-core%2Fcallback
2020-07-31 12:31:01 RESPONSE
CallTokenEndpoint
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:31:01 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "1547",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MSwiaWF0IjoxNTk2MTk4NjYxLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJZSU9xaUJnRExpeVB4b243TFJ5Qm84NWJrSkl4ZmxSV0hPWkZ5bmpFS25NIn0.gH2Sh8RkoiIocSkKdGcHUuC0fFySzfoyr2VjN5CfG-o8CeFuyVE3UEH6OIKrQIFNZC2M-V30D6_RckPQDTAjB9YJ37RbewojRiX5DilXAU8Ptja4jtZ8vaVodOWsrvBPSEA9QJWsunci4pcXNLIHnydY98ObIv7sJ0w2_TN5qdhUAXYM95wwNs7Fj2xEf7xSjIkDRgFblQXsACIPZ3iYxVPt41JYQYXDCIz8NPQNnUQwXkapRB7eHKI9cqVsZ7JeH1uVMVBp5g0hb0L7ZI_VZkPvBAZ20w4izTgFQLMRaXQ6ioyVzK98TBQNmWu4IBxSWOcRBfMakX7LUfyg4KqERw","refresh_token":"re3RVQ0ePGLBNA-Mvv11qg3Smi0ICX1xQJu7qEaQrvU","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MSwiaWF0IjoxNTk2MTk4NjYxLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.OUWmEruLnwkq4ZPNoJmWAoa_yir7L5jj5GvDguE_UH78jwOTmUUSsbULu1DK-5PcFln8O5MXv-3d9tPLx5BrFkVCBHmgWmSi1sVvh1bz5J7bO3qm5eghVsLrFR5bg-FbrapSm6tK-tOQGOVOnnGyGe8ThuHopz_hjI38ZS3TGVORwhd7d6fEBhXrUCzweE4JRvQOO-OE7oKBOFuE_K9bBY9PO66U0-wyQLTKPGMxpHB0zuwHGHGtYOkeKGjvnXw3h93cX7jKnAnYAGiLcI6cFOfCDvokjBK3MIz9RuXgLqLhVQiL-SMml4D9Aj-4ETUhgG_4KXVUnIozhmwMIij29A","token_type":"Bearer","expires_in":86400}
2020-07-31 12:31:01
CallTokenEndpoint
Token endpoint response
token_endpoint_response
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MSwiaWF0IjoxNTk2MTk4NjYxLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJZSU9xaUJnRExpeVB4b243TFJ5Qm84NWJrSkl4ZmxSV0hPWkZ5bmpFS25NIn0.gH2Sh8RkoiIocSkKdGcHUuC0fFySzfoyr2VjN5CfG-o8CeFuyVE3UEH6OIKrQIFNZC2M-V30D6_RckPQDTAjB9YJ37RbewojRiX5DilXAU8Ptja4jtZ8vaVodOWsrvBPSEA9QJWsunci4pcXNLIHnydY98ObIv7sJ0w2_TN5qdhUAXYM95wwNs7Fj2xEf7xSjIkDRgFblQXsACIPZ3iYxVPt41JYQYXDCIz8NPQNnUQwXkapRB7eHKI9cqVsZ7JeH1uVMVBp5g0hb0L7ZI_VZkPvBAZ20w4izTgFQLMRaXQ6ioyVzK98TBQNmWu4IBxSWOcRBfMakX7LUfyg4KqERw","refresh_token":"re3RVQ0ePGLBNA-Mvv11qg3Smi0ICX1xQJu7qEaQrvU","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MSwiaWF0IjoxNTk2MTk4NjYxLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.OUWmEruLnwkq4ZPNoJmWAoa_yir7L5jj5GvDguE_UH78jwOTmUUSsbULu1DK-5PcFln8O5MXv-3d9tPLx5BrFkVCBHmgWmSi1sVvh1bz5J7bO3qm5eghVsLrFR5bg-FbrapSm6tK-tOQGOVOnnGyGe8ThuHopz_hjI38ZS3TGVORwhd7d6fEBhXrUCzweE4JRvQOO-OE7oKBOFuE_K9bBY9PO66U0-wyQLTKPGMxpHB0zuwHGHGtYOkeKGjvnXw3h93cX7jKnAnYAGiLcI6cFOfCDvokjBK3MIz9RuXgLqLhVQiL-SMml4D9Aj-4ETUhgG_4KXVUnIozhmwMIij29A","token_type":"Bearer","expires_in":86400}
2020-07-31 12:31:01 SUCCESS
CallTokenEndpoint
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MSwiaWF0IjoxNTk2MTk4NjYxLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJZSU9xaUJnRExpeVB4b243TFJ5Qm84NWJrSkl4ZmxSV0hPWkZ5bmpFS25NIn0.gH2Sh8RkoiIocSkKdGcHUuC0fFySzfoyr2VjN5CfG-o8CeFuyVE3UEH6OIKrQIFNZC2M-V30D6_RckPQDTAjB9YJ37RbewojRiX5DilXAU8Ptja4jtZ8vaVodOWsrvBPSEA9QJWsunci4pcXNLIHnydY98ObIv7sJ0w2_TN5qdhUAXYM95wwNs7Fj2xEf7xSjIkDRgFblQXsACIPZ3iYxVPt41JYQYXDCIz8NPQNnUQwXkapRB7eHKI9cqVsZ7JeH1uVMVBp5g0hb0L7ZI_VZkPvBAZ20w4izTgFQLMRaXQ6ioyVzK98TBQNmWu4IBxSWOcRBfMakX7LUfyg4KqERw
refresh_token
re3RVQ0ePGLBNA-Mvv11qg3Smi0ICX1xQJu7qEaQrvU
scope
offline_access openid
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MSwiaWF0IjoxNTk2MTk4NjYxLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.OUWmEruLnwkq4ZPNoJmWAoa_yir7L5jj5GvDguE_UH78jwOTmUUSsbULu1DK-5PcFln8O5MXv-3d9tPLx5BrFkVCBHmgWmSi1sVvh1bz5J7bO3qm5eghVsLrFR5bg-FbrapSm6tK-tOQGOVOnnGyGe8ThuHopz_hjI38ZS3TGVORwhd7d6fEBhXrUCzweE4JRvQOO-OE7oKBOFuE_K9bBY9PO66U0-wyQLTKPGMxpHB0zuwHGHGtYOkeKGjvnXw3h93cX7jKnAnYAGiLcI6cFOfCDvokjBK3MIz9RuXgLqLhVQiL-SMml4D9Aj-4ETUhgG_4KXVUnIozhmwMIij29A
token_type
Bearer
expires_in
86400
2020-07-31 12:31:01 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:31:01 SUCCESS
CheckForAccessTokenValue
Found an access token
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MSwiaWF0IjoxNTk2MTk4NjYxLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJZSU9xaUJnRExpeVB4b243TFJ5Qm84NWJrSkl4ZmxSV0hPWkZ5bmpFS25NIn0.gH2Sh8RkoiIocSkKdGcHUuC0fFySzfoyr2VjN5CfG-o8CeFuyVE3UEH6OIKrQIFNZC2M-V30D6_RckPQDTAjB9YJ37RbewojRiX5DilXAU8Ptja4jtZ8vaVodOWsrvBPSEA9QJWsunci4pcXNLIHnydY98ObIv7sJ0w2_TN5qdhUAXYM95wwNs7Fj2xEf7xSjIkDRgFblQXsACIPZ3iYxVPt41JYQYXDCIz8NPQNnUQwXkapRB7eHKI9cqVsZ7JeH1uVMVBp5g0hb0L7ZI_VZkPvBAZ20w4izTgFQLMRaXQ6ioyVzK98TBQNmWu4IBxSWOcRBfMakX7LUfyg4KqERw
2020-07-31 12:31:01 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MSwiaWF0IjoxNTk2MTk4NjYxLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJZSU9xaUJnRExpeVB4b243TFJ5Qm84NWJrSkl4ZmxSV0hPWkZ5bmpFS25NIn0.gH2Sh8RkoiIocSkKdGcHUuC0fFySzfoyr2VjN5CfG-o8CeFuyVE3UEH6OIKrQIFNZC2M-V30D6_RckPQDTAjB9YJ37RbewojRiX5DilXAU8Ptja4jtZ8vaVodOWsrvBPSEA9QJWsunci4pcXNLIHnydY98ObIv7sJ0w2_TN5qdhUAXYM95wwNs7Fj2xEf7xSjIkDRgFblQXsACIPZ3iYxVPt41JYQYXDCIz8NPQNnUQwXkapRB7eHKI9cqVsZ7JeH1uVMVBp5g0hb0L7ZI_VZkPvBAZ20w4izTgFQLMRaXQ6ioyVzK98TBQNmWu4IBxSWOcRBfMakX7LUfyg4KqERw
type
Bearer
2020-07-31 12:31:01 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:31:01 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:31:01 SUCCESS
CheckForRefreshTokenValue
Found a refresh token
refresh_token
re3RVQ0ePGLBNA-Mvv11qg3Smi0ICX1xQJu7qEaQrvU
2020-07-31 12:31:01 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MSwiaWF0IjoxNTk2MTk4NjYxLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.OUWmEruLnwkq4ZPNoJmWAoa_yir7L5jj5GvDguE_UH78jwOTmUUSsbULu1DK-5PcFln8O5MXv-3d9tPLx5BrFkVCBHmgWmSi1sVvh1bz5J7bO3qm5eghVsLrFR5bg-FbrapSm6tK-tOQGOVOnnGyGe8ThuHopz_hjI38ZS3TGVORwhd7d6fEBhXrUCzweE4JRvQOO-OE7oKBOFuE_K9bBY9PO66U0-wyQLTKPGMxpHB0zuwHGHGtYOkeKGjvnXw3h93cX7jKnAnYAGiLcI6cFOfCDvokjBK3MIz9RuXgLqLhVQiL-SMml4D9Aj-4ETUhgG_4KXVUnIozhmwMIij29A
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "sub": "1001",
  "aud": "470519824180317",
  "s_hash": "-rInw-zE9dMUnanAtDFLOA",
  "auth_time": 1596198660,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198961,
  "iat": 1596198661,
  "nonce": "LRahdgZx27"
}
2020-07-31 12:31:01 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:31:01 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
LRahdgZx27
2020-07-31 12:31:01 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:31:01 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MSwiaWF0IjoxNTk2MTk4NjYxLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.OUWmEruLnwkq4ZPNoJmWAoa_yir7L5jj5GvDguE_UH78jwOTmUUSsbULu1DK-5PcFln8O5MXv-3d9tPLx5BrFkVCBHmgWmSi1sVvh1bz5J7bO3qm5eghVsLrFR5bg-FbrapSm6tK-tOQGOVOnnGyGe8ThuHopz_hjI38ZS3TGVORwhd7d6fEBhXrUCzweE4JRvQOO-OE7oKBOFuE_K9bBY9PO66U0-wyQLTKPGMxpHB0zuwHGHGtYOkeKGjvnXw3h93cX7jKnAnYAGiLcI6cFOfCDvokjBK3MIz9RuXgLqLhVQiL-SMml4D9Aj-4ETUhgG_4KXVUnIozhmwMIij29A
2020-07-31 12:31:01 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiItckludy16RTlkTVVuYW5BdERGTE9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MSwiaWF0IjoxNTk2MTk4NjYxLCJub25jZSI6IkxSYWhkZ1p4MjcifQ.OUWmEruLnwkq4ZPNoJmWAoa_yir7L5jj5GvDguE_UH78jwOTmUUSsbULu1DK-5PcFln8O5MXv-3d9tPLx5BrFkVCBHmgWmSi1sVvh1bz5J7bO3qm5eghVsLrFR5bg-FbrapSm6tK-tOQGOVOnnGyGe8ThuHopz_hjI38ZS3TGVORwhd7d6fEBhXrUCzweE4JRvQOO-OE7oKBOFuE_K9bBY9PO66U0-wyQLTKPGMxpHB0zuwHGHGtYOkeKGjvnXw3h93cX7jKnAnYAGiLcI6cFOfCDvokjBK3MIz9RuXgLqLhVQiL-SMml4D9Aj-4ETUhgG_4KXVUnIozhmwMIij29A
2020-07-31 12:31:01 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
2020-07-31 12:31:01 SUCCESS
VerifyIdTokenSubConsistentHybridFlow
authorization endpoint and token endpoint id_token have same sub
sub_auth_endpoint
1001
sub_token_endpoint
1001
2020-07-31 12:31:01 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
re3RVQ0ePGLBNA-Mvv11qg3Smi0ICX1xQJu7qEaQrvU
2020-07-31 12:31:01 SUCCESS
EnsureRefreshTokenContainsAllowedCharactersOnly
Refresh token does not contain any illegal characters
Refresh Token Request
2020-07-31 12:31:01 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
re3RVQ0ePGLBNA-Mvv11qg3Smi0ICX1xQJu7qEaQrvU
2020-07-31 12:31:01 SUCCESS
AddScopeToTokenEndpointRequest
Added scope of 'openid offline_access' to token endpoint request
grant_type
refresh_token
refresh_token
re3RVQ0ePGLBNA-Mvv11qg3Smi0ICX1xQJu7qEaQrvU
scope
openid offline_access
2020-07-31 12:31:01 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3
2020-07-31 12:31:01 SUCCESS
WaitForOneSecond
Pausing for 1 seconds
2020-07-31 12:31:02 SUCCESS
WaitForOneSecond
Woke up after 1 seconds sleep
2020-07-31 12:31:02
CallTokenEndpointAndReturnFullResponse
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3",
  "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=re3RVQ0ePGLBNA-Mvv11qg3Smi0ICX1xQJu7qEaQrvU&scope=openid+offline_access
2020-07-31 12:31:03 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:31:02 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "860",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiI5b1dXY0JOSThsVGpwY1ZESzl4YXNzRzZKSVhEMy1ybGRrSGI1UWo1SmhBIn0.H6ILKzSe4wLg3rJ7ulOuG_dwW_DyQgcWtnIhJU-mTRfxOb2RkMdirzynir_7RoYDm1L3rqY5H5eZiv-LhOzFYSnUixXY_VGfKy07FlBj8RXOhewRkAbw65SgI_BKOtFxKwqoJX8_KbwR1HAifEN4E8sFQEQOKNQK9Tw8ogXgeyGhphE-nQF7rEJsGgv2sgkD_xNnlrj9qwsBQ8ALXP3tN7vpqs0-0FpWf3u2mPe0MdxPPuhFFUH2dVX6EK9g541gwJB1LvjnvJ5hJMKlREqSCUAF7tezxseTmobhG3JABI-kRe9LM-CYUGQlK0Y1UsUvjU3krvsvde7CivDMx4bR9w","refresh_token":"8ZjAuG-5L7VCg-tgbhKqmHaehKSBbjhrvNu9j3wX1Xg","scope":"openid offline_access","token_type":"Bearer","expires_in":86400}
2020-07-31 12:31:03 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiI5b1dXY0JOSThsVGpwY1ZESzl4YXNzRzZKSVhEMy1ybGRrSGI1UWo1SmhBIn0.H6ILKzSe4wLg3rJ7ulOuG_dwW_DyQgcWtnIhJU-mTRfxOb2RkMdirzynir_7RoYDm1L3rqY5H5eZiv-LhOzFYSnUixXY_VGfKy07FlBj8RXOhewRkAbw65SgI_BKOtFxKwqoJX8_KbwR1HAifEN4E8sFQEQOKNQK9Tw8ogXgeyGhphE-nQF7rEJsGgv2sgkD_xNnlrj9qwsBQ8ALXP3tN7vpqs0-0FpWf3u2mPe0MdxPPuhFFUH2dVX6EK9g541gwJB1LvjnvJ5hJMKlREqSCUAF7tezxseTmobhG3JABI-kRe9LM-CYUGQlK0Y1UsUvjU3krvsvde7CivDMx4bR9w
refresh_token
8ZjAuG-5L7VCg-tgbhKqmHaehKSBbjhrvNu9j3wX1Xg
scope
openid offline_access
token_type
Bearer
expires_in
86400
2020-07-31 12:31:03 SUCCESS
CheckTokenEndpointHttpStatus200
Token endpoint http status code was 200
2020-07-31 12:31:03 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2020-07-31 12:31:03 SUCCESS
CheckTokenEndpointCacheHeaders
Checked 'pragma' and 'cache-control' in the headers of token_endpoint_response.
2020-07-31 12:31:03 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:31:03 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiI5b1dXY0JOSThsVGpwY1ZESzl4YXNzRzZKSVhEMy1ybGRrSGI1UWo1SmhBIn0.H6ILKzSe4wLg3rJ7ulOuG_dwW_DyQgcWtnIhJU-mTRfxOb2RkMdirzynir_7RoYDm1L3rqY5H5eZiv-LhOzFYSnUixXY_VGfKy07FlBj8RXOhewRkAbw65SgI_BKOtFxKwqoJX8_KbwR1HAifEN4E8sFQEQOKNQK9Tw8ogXgeyGhphE-nQF7rEJsGgv2sgkD_xNnlrj9qwsBQ8ALXP3tN7vpqs0-0FpWf3u2mPe0MdxPPuhFFUH2dVX6EK9g541gwJB1LvjnvJ5hJMKlREqSCUAF7tezxseTmobhG3JABI-kRe9LM-CYUGQlK0Y1UsUvjU3krvsvde7CivDMx4bR9w
type
Bearer
2020-07-31 12:31:03 SUCCESS
CheckTokenTypeIsBearer
Token type is bearer
2020-07-31 12:31:03 SUCCESS
EnsureMinimumAccessTokenEntropy
Calculated shannon entropy seems sufficient
actual
4165.679522565101
expected
96.0
2020-07-31 12:31:03 SUCCESS
EnsureAccessTokenContainsAllowedCharactersOnly
Access token does not contain any illegal characters
2020-07-31 12:31:03 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:31:03 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:31:03 SUCCESS
EnsureAccessTokenValuesAreDifferent
Access token values are not the same
first_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MSwiaWF0IjoxNTk2MTk4NjYxLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJZSU9xaUJnRExpeVB4b243TFJ5Qm84NWJrSkl4ZmxSV0hPWkZ5bmpFS25NIn0.gH2Sh8RkoiIocSkKdGcHUuC0fFySzfoyr2VjN5CfG-o8CeFuyVE3UEH6OIKrQIFNZC2M-V30D6_RckPQDTAjB9YJ37RbewojRiX5DilXAU8Ptja4jtZ8vaVodOWsrvBPSEA9QJWsunci4pcXNLIHnydY98ObIv7sJ0w2_TN5qdhUAXYM95wwNs7Fj2xEf7xSjIkDRgFblQXsACIPZ3iYxVPt41JYQYXDCIz8NPQNnUQwXkapRB7eHKI9cqVsZ7JeH1uVMVBp5g0hb0L7ZI_VZkPvBAZ20w4izTgFQLMRaXQ6ioyVzK98TBQNmWu4IBxSWOcRBfMakX7LUfyg4KqERw
second_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiI5b1dXY0JOSThsVGpwY1ZESzl4YXNzRzZKSVhEMy1ybGRrSGI1UWo1SmhBIn0.H6ILKzSe4wLg3rJ7ulOuG_dwW_DyQgcWtnIhJU-mTRfxOb2RkMdirzynir_7RoYDm1L3rqY5H5eZiv-LhOzFYSnUixXY_VGfKy07FlBj8RXOhewRkAbw65SgI_BKOtFxKwqoJX8_KbwR1HAifEN4E8sFQEQOKNQK9Tw8ogXgeyGhphE-nQF7rEJsGgv2sgkD_xNnlrj9qwsBQ8ALXP3tN7vpqs0-0FpWf3u2mPe0MdxPPuhFFUH2dVX6EK9g541gwJB1LvjnvJ5hJMKlREqSCUAF7tezxseTmobhG3JABI-kRe9LM-CYUGQlK0Y1UsUvjU3krvsvde7CivDMx4bR9w
2020-07-31 12:31:03 INFO
ExtractIdTokenFromTokenResponse
Couldn't find id_token in token_endpoint_response
2020-07-31 12:31:03 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
8ZjAuG-5L7VCg-tgbhKqmHaehKSBbjhrvNu9j3wX1Xg
2020-07-31 12:31:03 SUCCESS
EnsureMinimumRefreshTokenLength
Refresh token is of sufficient length
actual
344
required
128
2020-07-31 12:31:03 SUCCESS
EnsureMinimumRefreshTokenEntropy
Calculated shannon entropy seems sufficient
actual
209.06472194569977
expected
96.0
2020-07-31 12:31:03 INFO
CompareIdTokenClaims
Skipped evaluation due to missing required object: second_id_token
expected
second_id_token
mapped
second_id_token
Userinfo endpoint tests
2020-07-31 12:31:03
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://fapidev-rs.authlete.net/api/userinfo
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiI5b1dXY0JOSThsVGpwY1ZESzl4YXNzRzZKSVhEMy1ybGRrSGI1UWo1SmhBIn0.H6ILKzSe4wLg3rJ7ulOuG_dwW_DyQgcWtnIhJU-mTRfxOb2RkMdirzynir_7RoYDm1L3rqY5H5eZiv-LhOzFYSnUixXY_VGfKy07FlBj8RXOhewRkAbw65SgI_BKOtFxKwqoJX8_KbwR1HAifEN4E8sFQEQOKNQK9Tw8ogXgeyGhphE-nQF7rEJsGgv2sgkD_xNnlrj9qwsBQ8ALXP3tN7vpqs0-0FpWf3u2mPe0MdxPPuhFFUH2dVX6EK9g541gwJB1LvjnvJ5hJMKlREqSCUAF7tezxseTmobhG3JABI-kRe9LM-CYUGQlK0Y1UsUvjU3krvsvde7CivDMx4bR9w",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:31:03 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:31:03 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"sub":"1001"}
2020-07-31 12:31:03 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:31:03 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
status_code
{
  "code": 200
}
body
{"sub":"1001"}
Second client: Make request to authorization endpoint
2020-07-31 12:31:03 SUCCESS
CreateAuthorizationEndpointRequestFromClientInformation
Created authorization endpoint request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
2020-07-31 12:31:03
CreateRandomStateValue
Created state value
requested_state_length
10
state
xrKndrbflp
2020-07-31 12:31:03 SUCCESS
AddStateToAuthorizationEndpointRequest
Added state parameter to request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
xrKndrbflp
2020-07-31 12:31:03
CreateRandomNonceValue
Created nonce value
requested_nonce_length
10
nonce
yIHPrspoMW
2020-07-31 12:31:03 SUCCESS
AddNonceToAuthorizationEndpointRequest
Added nonce parameter to request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
xrKndrbflp
nonce
yIHPrspoMW
2020-07-31 12:31:03 SUCCESS
SetAuthorizationEndpointRequestResponseTypeFromEnvironment
Added response_type parameter to request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
xrKndrbflp
nonce
yIHPrspoMW
response_type
code id_token token
2020-07-31 12:31:03
SetAuthorizationEndpointRequestResponseModeToFormPost
Added response_mode parameter to request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
xrKndrbflp
nonce
yIHPrspoMW
response_type
code id_token token
response_mode
form_post
2020-07-31 12:31:03 SUCCESS
AddPromptConsentToAuthorizationEndpointRequestIfScopeContainsOfflineAccess
Added prompt=consent to authorization endpoint request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
xrKndrbflp
nonce
yIHPrspoMW
response_type
code id_token token
response_mode
form_post
prompt
consent
2020-07-31 12:31:03 SUCCESS
BuildPlainRedirectToAuthorizationEndpoint
Sending to authorization endpoint
redirect_to_authorization_endpoint
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=xrKndrbflp&nonce=yIHPrspoMW&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
2020-07-31 12:31:03 REDIRECT
oidcc-refresh-token
Redirecting to authorization endpoint
redirect_to
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=xrKndrbflp&nonce=yIHPrspoMW&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
2020-07-31 12:31:03
WebRunner
Scripted browser HTTP request
browser
goToUrl
request_method
GET
request_uri
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=xrKndrbflp&nonce=yIHPrspoMW&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
2020-07-31 12:31:03 RESPONSE
WebRunner
Scripted browser HTTP response
response_content
<!doctype html>
<!---->
<!--




-->
<html>
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes">
  <title>FAPI Test Service | Authorization</title>
  <link rel="stylesheet" href="/css/authorization.css">
  <!--  //-->
</head>
<body class="font-default">
  <div id="page_title">FAPI Test Service</div>

  <div id="content">
    <h3 id="client-name">core conformance client secret basic (2nd client)</h3>
    <div class="indent">
      <img id="logo" src="https://button.heenan.me.uk/~joseph/authlete-150x150.png" alt="[Logo] (150x150)">

      <div id="client-summary">
        <p>core conformance client secret basic (2nd client)</p>
        <ul id="client-link-list">
          

          

          
        </ul>
      </div>

      <div style="clear: both;"></div>
    </div>

    
    <h4 id="permissions">Permissions</h4>
    <div class="indent">
      <p>The application is requesting the following permissions.</p>

      <dl id="scope-list">
        
        <dt>offline_access</dt>
        <dd>A permission to request a refresh token exchangeable with an access token which can access the UserInfo Endpoint even when the end-user is offline. See OpenID Connect Core 1.0, 11. for details.</dd>
        
        <dt>openid</dt>
        <dd>A permission to request an OpenID Provider to issue an ID Token. See OpenID Connect Core 1.0, 3.1.2.1. for details.</dd>
        
      </dl>
    </div>
    

    

    

    <h4 id="authorization">Authorization</h4>
    <div class="indent">
      <p>Do you grant authorization to the application?</p>

      <form id="authorization-form" action="/api/authorization/decision" method="POST">
        
        
        <div id="login-user"><i>Logged in as 1001</i></div>
        
        <div id="authorization-form-buttons">
          <input type="submit" name="authorized" id="authorize-button" value="Authorize" class="font-default"/>
          <input type="submit" name="denied"     id="deny-button"      value="Deny"      class="font-default"/>
        </div>
      </form>
    </div>
  </div>

</body>
</html>
response_content_type
*/*
response_status_text
200-OK
response_status_code
200
2020-07-31 12:31:03 INFO
WebRunner
Entering text
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=xrKndrbflp&nonce=yIHPrspoMW&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
target
loginId
2020-07-31 12:31:03 INFO
WebRunner
Element not found, skipping as 'text' command is marked 'optional'
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=xrKndrbflp&nonce=yIHPrspoMW&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
target
loginId
2020-07-31 12:31:03 INFO
WebRunner
Entering text
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=xrKndrbflp&nonce=yIHPrspoMW&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
target
password
2020-07-31 12:31:03 INFO
WebRunner
Element not found, skipping as 'text' command is marked 'optional'
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=xrKndrbflp&nonce=yIHPrspoMW&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
target
password
2020-07-31 12:31:03 INFO
WebRunner
Clicking an element
task
Initial Login
browser
click
element_type
name
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=xrKndrbflp&nonce=yIHPrspoMW&response_type=code%20id_token%20token&response_mode=form_post&prompt=consent
target
authorized
2020-07-31 12:31:04 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance AA1koCLYCJ2tyuO
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/webp,image/apng,*/*;q\u003d0.8",
  "referer": "https://fapidev-www.authlete.net/api/authorization/decision",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003d695B4733A1BE82B9C1C66CCA78AB586F",
  "origin": "https://fapidev-www.authlete.net/api/authorization/decision",
  "cache-control": "max-age\u003d0",
  "content-type": "application/x-www-form-urlencoded",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "1623",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
callback
incoming_body_form_params
{
  "state": "xrKndrbflp",
  "code": "QFkxyhPyp0NkLJWZUgg8qWAxzHDngyuDlY6WLuhIjvE",
  "access_token": "eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJQNFZNZkYyV3BJZXoydFJiRjF6ZGNaSERFdWhEendxelpXWWtmNnhVR1hvIn0.Ew8WSyI7s6uhLPu19iznMudB7xhwV0eZvVquKbRnOinfOaOYqlPu0_4xx__CZi5nZAvuygEWuszGfpnRH8aZNXm4DcLkeZtWkAX8EMQVu0loD2wBIwFP1oZjQYpbpTwfp3kcMC5ErlQhHMBXoAYzxK_Vfci8omPBqSNnwgiApsEKsoOsyFwSEY1MGQYdmyRT-49IROKFH2qYd0EowONYZhhb9hjbLmc2BCCI44pUoo6Pji74I2f_Msy0jyu4XFtD5muUzXOtofu3EI7u2816gQ9rrmrQktisLbMcpd2_vdgK0BDuK4F7rY7ROYT9nGwHYP-h2xtWCZS6sFkX2987Gg",
  "token_type": "Bearer",
  "expires_in": "86400",
  "scope": "offline_access openid",
  "id_token": "eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiOUloT2x1NzBnUjRMdVRHZnJBSURzdyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTUzMzMxNjA0NjMyIl0sImNfaGFzaCI6IkJVZ3JPdDhZZFpHNkFrdm8yWnNoMWciLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MywiaWF0IjoxNTk2MTk4NjYzLCJub25jZSI6InlJSFByc3BvTVcifQ.B4V4jjrx99CNpNMoC-17w-GgVE11XuniweyFSno3f1dUDcNfu4LdkptnECIQ_mGuE5pvB5X1emxiy_u6ih9ivM-ng_A1wYF0_yfnWp18NEI7pL-Tw9zTC0pMo5u-ypW4x_r_b9gfDcyyWF7GKZb1CMJziY7xLemjrSsBCreYOUuTPdCGGU0bT_bwW29UOLx7zLIC1e5uDpyLSw-RxKlLV2fPD1ypc4nc0CEbpIhrhfHpBJmhtGhS7S79_OTWRY8b7PYg_n2l1R1xQuSIGouAhT-kvyYucf_6Nqakp4bC7mZOlACOiidazqkjHnvyXQfuCrgIL4cgk7SIS-9-Kt_bMA"
}
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
state=xrKndrbflp&code=QFkxyhPyp0NkLJWZUgg8qWAxzHDngyuDlY6WLuhIjvE&access_token=eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJQNFZNZkYyV3BJZXoydFJiRjF6ZGNaSERFdWhEendxelpXWWtmNnhVR1hvIn0.Ew8WSyI7s6uhLPu19iznMudB7xhwV0eZvVquKbRnOinfOaOYqlPu0_4xx__CZi5nZAvuygEWuszGfpnRH8aZNXm4DcLkeZtWkAX8EMQVu0loD2wBIwFP1oZjQYpbpTwfp3kcMC5ErlQhHMBXoAYzxK_Vfci8omPBqSNnwgiApsEKsoOsyFwSEY1MGQYdmyRT-49IROKFH2qYd0EowONYZhhb9hjbLmc2BCCI44pUoo6Pji74I2f_Msy0jyu4XFtD5muUzXOtofu3EI7u2816gQ9rrmrQktisLbMcpd2_vdgK0BDuK4F7rY7ROYT9nGwHYP-h2xtWCZS6sFkX2987Gg&token_type=Bearer&expires_in=86400&scope=offline_access+openid&id_token=eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiOUloT2x1NzBnUjRMdVRHZnJBSURzdyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTUzMzMxNjA0NjMyIl0sImNfaGFzaCI6IkJVZ3JPdDhZZFpHNkFrdm8yWnNoMWciLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MywiaWF0IjoxNTk2MTk4NjYzLCJub25jZSI6InlJSFByc3BvTVcifQ.B4V4jjrx99CNpNMoC-17w-GgVE11XuniweyFSno3f1dUDcNfu4LdkptnECIQ_mGuE5pvB5X1emxiy_u6ih9ivM-ng_A1wYF0_yfnWp18NEI7pL-Tw9zTC0pMo5u-ypW4x_r_b9gfDcyyWF7GKZb1CMJziY7xLemjrSsBCreYOUuTPdCGGU0bT_bwW29UOLx7zLIC1e5uDpyLSw-RxKlLV2fPD1ypc4nc0CEbpIhrhfHpBJmhtGhS7S79_OTWRY8b7PYg_n2l1R1xQuSIGouAhT-kvyYucf_6Nqakp4bC7mZOlACOiidazqkjHnvyXQfuCrgIL4cgk7SIS-9-Kt_bMA
2020-07-31 12:31:04 SUCCESS
CreateRandomImplicitSubmitUrl
Created random implicit submission URL
implicit_submit
{
  "path": "implicit/ARwqhhButzJwU2yQQJxa",
  "fullUrl": "https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/ARwqhhButzJwU2yQQJxa"
}
2020-07-31 12:31:04 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance AA1koCLYCJ2tyuO
outgoing
ModelAndView [view="implicitCallback"; model={implicitSubmitUrl=https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/ARwqhhButzJwU2yQQJxa, returnUrl=/log-detail.html?log=AA1koCLYCJ2tyuO}]
outgoing_path
callback
2020-07-31 12:31:04 INFO
WebRunner
Completed processing of webpage
task
Initial Login
browser
complete
response_status_text
200-
match
https://fapidev-www.authlete.net/api/authorization*
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
response_status_code
200
2020-07-31 12:31:04 INFO
WebRunner
Waiting
regexp
seconds
10
task
Verify Complete
browser
wait
action
element_type
id
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
target
submission_complete
2020-07-31 12:31:04 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance AA1koCLYCJ2tyuO
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "*/*",
  "referer": "https://www.certification.openid.net/test/a/oidf-authlete-core/callback",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003d695B4733A1BE82B9C1C66CCA78AB586F",
  "x-requested-with": "XMLHttpRequest",
  "content-type": "text/plain",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "0",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
implicit/ARwqhhButzJwU2yQQJxa
incoming_body_form_params
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
2020-07-31 12:31:04 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance AA1koCLYCJ2tyuO
outgoing
org.springframework.web.servlet.view.RedirectView: [RedirectView]; URL [/log-detail.html?log=AA1koCLYCJ2tyuO]
outgoing_path
implicit/ARwqhhButzJwU2yQQJxa
2020-07-31 12:31:04 SUCCESS
ExtractImplicitHashToCallbackResponse
implicit_hash is empty
2020-07-31 12:31:04 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 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/webp,image/apng,*/*;q\u003d0.8",
  "referer": "https://fapidev-www.authlete.net/api/authorization/decision",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003d695B4733A1BE82B9C1C66CCA78AB586F",
  "origin": "https://fapidev-www.authlete.net/api/authorization/decision",
  "cache-control": "max-age\u003d0",
  "content-type": "application/x-www-form-urlencoded",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "1623",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
http_method
POST
url_fragment
{}
post_body
{
  "state": "xrKndrbflp",
  "code": "QFkxyhPyp0NkLJWZUgg8qWAxzHDngyuDlY6WLuhIjvE",
  "access_token": "eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJQNFZNZkYyV3BJZXoydFJiRjF6ZGNaSERFdWhEendxelpXWWtmNnhVR1hvIn0.Ew8WSyI7s6uhLPu19iznMudB7xhwV0eZvVquKbRnOinfOaOYqlPu0_4xx__CZi5nZAvuygEWuszGfpnRH8aZNXm4DcLkeZtWkAX8EMQVu0loD2wBIwFP1oZjQYpbpTwfp3kcMC5ErlQhHMBXoAYzxK_Vfci8omPBqSNnwgiApsEKsoOsyFwSEY1MGQYdmyRT-49IROKFH2qYd0EowONYZhhb9hjbLmc2BCCI44pUoo6Pji74I2f_Msy0jyu4XFtD5muUzXOtofu3EI7u2816gQ9rrmrQktisLbMcpd2_vdgK0BDuK4F7rY7ROYT9nGwHYP-h2xtWCZS6sFkX2987Gg",
  "token_type": "Bearer",
  "expires_in": "86400",
  "scope": "offline_access openid",
  "id_token": "eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiOUloT2x1NzBnUjRMdVRHZnJBSURzdyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTUzMzMxNjA0NjMyIl0sImNfaGFzaCI6IkJVZ3JPdDhZZFpHNkFrdm8yWnNoMWciLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MywiaWF0IjoxNTk2MTk4NjYzLCJub25jZSI6InlJSFByc3BvTVcifQ.B4V4jjrx99CNpNMoC-17w-GgVE11XuniweyFSno3f1dUDcNfu4LdkptnECIQ_mGuE5pvB5X1emxiy_u6ih9ivM-ng_A1wYF0_yfnWp18NEI7pL-Tw9zTC0pMo5u-ypW4x_r_b9gfDcyyWF7GKZb1CMJziY7xLemjrSsBCreYOUuTPdCGGU0bT_bwW29UOLx7zLIC1e5uDpyLSw-RxKlLV2fPD1ypc4nc0CEbpIhrhfHpBJmhtGhS7S79_OTWRY8b7PYg_n2l1R1xQuSIGouAhT-kvyYucf_6Nqakp4bC7mZOlACOiidazqkjHnvyXQfuCrgIL4cgk7SIS-9-Kt_bMA"
}
Second client: Verify authorization endpoint response
2020-07-31 12:31:04 SUCCESS
CheckCallbackHttpMethodIsPost
HTTP method used at redirect_uri is 'POST'
2020-07-31 12:31:04 SUCCESS
CheckCallbackContentTypeIsFormUrlEncoded
content-type header to redirect_uri has the expected value
content_type
application/x-www-form-urlencoded
expected
application/x-www-form-urlencoded
2020-07-31 12:31:04 SUCCESS
RejectAuthCodeInUrlQuery
Authorization code is not present in URL query returned from authorization endpoint
2020-07-31 12:31:04 SUCCESS
RejectErrorInUrlQuery
'error' is not present in URL query returned from authorization endpoint
2020-07-31 12:31:04 SUCCESS
CheckMatchingCallbackParameters
Callback parameters successfully verified
2020-07-31 12:31:04 SUCCESS
CheckIfAuthorizationEndpointError
No error from authorization endpoint
2020-07-31 12:31:04 SUCCESS
CheckMatchingStateParameter
State parameter correctly returned
state
xrKndrbflp
2020-07-31 12:31:04 SUCCESS
ExtractAuthorizationCodeFromAuthorizationResponse
Found authorization code
code
QFkxyhPyp0NkLJWZUgg8qWAxzHDngyuDlY6WLuhIjvE
2020-07-31 12:31:04 SUCCESS
ExtractAccessTokenFromAuthorizationResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJQNFZNZkYyV3BJZXoydFJiRjF6ZGNaSERFdWhEendxelpXWWtmNnhVR1hvIn0.Ew8WSyI7s6uhLPu19iznMudB7xhwV0eZvVquKbRnOinfOaOYqlPu0_4xx__CZi5nZAvuygEWuszGfpnRH8aZNXm4DcLkeZtWkAX8EMQVu0loD2wBIwFP1oZjQYpbpTwfp3kcMC5ErlQhHMBXoAYzxK_Vfci8omPBqSNnwgiApsEKsoOsyFwSEY1MGQYdmyRT-49IROKFH2qYd0EowONYZhhb9hjbLmc2BCCI44pUoo6Pji74I2f_Msy0jyu4XFtD5muUzXOtofu3EI7u2816gQ9rrmrQktisLbMcpd2_vdgK0BDuK4F7rY7ROYT9nGwHYP-h2xtWCZS6sFkX2987Gg
type
Bearer
2020-07-31 12:31:04 SUCCESS
ExtractIdTokenFromAuthorizationResponse
Found and parsed the id_token from authorization_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiOUloT2x1NzBnUjRMdVRHZnJBSURzdyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTUzMzMxNjA0NjMyIl0sImNfaGFzaCI6IkJVZ3JPdDhZZFpHNkFrdm8yWnNoMWciLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MywiaWF0IjoxNTk2MTk4NjYzLCJub25jZSI6InlJSFByc3BvTVcifQ.B4V4jjrx99CNpNMoC-17w-GgVE11XuniweyFSno3f1dUDcNfu4LdkptnECIQ_mGuE5pvB5X1emxiy_u6ih9ivM-ng_A1wYF0_yfnWp18NEI7pL-Tw9zTC0pMo5u-ypW4x_r_b9gfDcyyWF7GKZb1CMJziY7xLemjrSsBCreYOUuTPdCGGU0bT_bwW29UOLx7zLIC1e5uDpyLSw-RxKlLV2fPD1ypc4nc0CEbpIhrhfHpBJmhtGhS7S79_OTWRY8b7PYg_n2l1R1xQuSIGouAhT-kvyYucf_6Nqakp4bC7mZOlACOiidazqkjHnvyXQfuCrgIL4cgk7SIS-9-Kt_bMA
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "at_hash": "9IhOlu70gR4LuTGfrAIDsw",
  "sub": "1001",
  "aud": "470553331604632",
  "c_hash": "BUgrOt8YdZG6Akvo2Zsh1g",
  "s_hash": "ERGXTWiakPGTLuZB4JMbaA",
  "auth_time": 1596198660,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198963,
  "iat": 1596198663,
  "nonce": "yIHPrspoMW"
}
2020-07-31 12:31:04 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:31:04 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
yIHPrspoMW
2020-07-31 12:31:04 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:31:04 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiOUloT2x1NzBnUjRMdVRHZnJBSURzdyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTUzMzMxNjA0NjMyIl0sImNfaGFzaCI6IkJVZ3JPdDhZZFpHNkFrdm8yWnNoMWciLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MywiaWF0IjoxNTk2MTk4NjYzLCJub25jZSI6InlJSFByc3BvTVcifQ.B4V4jjrx99CNpNMoC-17w-GgVE11XuniweyFSno3f1dUDcNfu4LdkptnECIQ_mGuE5pvB5X1emxiy_u6ih9ivM-ng_A1wYF0_yfnWp18NEI7pL-Tw9zTC0pMo5u-ypW4x_r_b9gfDcyyWF7GKZb1CMJziY7xLemjrSsBCreYOUuTPdCGGU0bT_bwW29UOLx7zLIC1e5uDpyLSw-RxKlLV2fPD1ypc4nc0CEbpIhrhfHpBJmhtGhS7S79_OTWRY8b7PYg_n2l1R1xQuSIGouAhT-kvyYucf_6Nqakp4bC7mZOlACOiidazqkjHnvyXQfuCrgIL4cgk7SIS-9-Kt_bMA
2020-07-31 12:31:04 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJhdF9oYXNoIjoiOUloT2x1NzBnUjRMdVRHZnJBSURzdyIsInN1YiI6IjEwMDEiLCJhdWQiOlsiNDcwNTUzMzMxNjA0NjMyIl0sImNfaGFzaCI6IkJVZ3JPdDhZZFpHNkFrdm8yWnNoMWciLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2MywiaWF0IjoxNTk2MTk4NjYzLCJub25jZSI6InlJSFByc3BvTVcifQ.B4V4jjrx99CNpNMoC-17w-GgVE11XuniweyFSno3f1dUDcNfu4LdkptnECIQ_mGuE5pvB5X1emxiy_u6ih9ivM-ng_A1wYF0_yfnWp18NEI7pL-Tw9zTC0pMo5u-ypW4x_r_b9gfDcyyWF7GKZb1CMJziY7xLemjrSsBCreYOUuTPdCGGU0bT_bwW29UOLx7zLIC1e5uDpyLSw-RxKlLV2fPD1ypc4nc0CEbpIhrhfHpBJmhtGhS7S79_OTWRY8b7PYg_n2l1R1xQuSIGouAhT-kvyYucf_6Nqakp4bC7mZOlACOiidazqkjHnvyXQfuCrgIL4cgk7SIS-9-Kt_bMA
2020-07-31 12:31:04 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
Second client: Userinfo endpoint tests
2020-07-31 12:31:04
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://fapidev-rs.authlete.net/api/userinfo
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2MywiaWF0IjoxNTk2MTk4NjYzLCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJQNFZNZkYyV3BJZXoydFJiRjF6ZGNaSERFdWhEendxelpXWWtmNnhVR1hvIn0.Ew8WSyI7s6uhLPu19iznMudB7xhwV0eZvVquKbRnOinfOaOYqlPu0_4xx__CZi5nZAvuygEWuszGfpnRH8aZNXm4DcLkeZtWkAX8EMQVu0loD2wBIwFP1oZjQYpbpTwfp3kcMC5ErlQhHMBXoAYzxK_Vfci8omPBqSNnwgiApsEKsoOsyFwSEY1MGQYdmyRT-49IROKFH2qYd0EowONYZhhb9hjbLmc2BCCI44pUoo6Pji74I2f_Msy0jyu4XFtD5muUzXOtofu3EI7u2816gQ9rrmrQktisLbMcpd2_vdgK0BDuK4F7rY7ROYT9nGwHYP-h2xtWCZS6sFkX2987Gg",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:31:04 INFO
WebRunner
Completed processing of webpage
task
Verify Complete
browser
complete
response_status_text
200-
match
https://*/test/a/oidf-authlete-core/callback*
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
response_status_code
200
2020-07-31 12:31:04 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:31:04 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"sub":"1001"}
2020-07-31 12:31:04 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:31:04 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
status_code
{
  "code": 200
}
body
{"sub":"1001"}
2020-07-31 12:31:04 SUCCESS
CreateTokenEndpointRequestForAuthorizationCodeGrant
grant_type
authorization_code
code
QFkxyhPyp0NkLJWZUgg8qWAxzHDngyuDlY6WLuhIjvE
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
2020-07-31 12:31:04 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB
2020-07-31 12:31:04
CallTokenEndpoint
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "177"
}
request_body
grant_type=authorization_code&code=QFkxyhPyp0NkLJWZUgg8qWAxzHDngyuDlY6WLuhIjvE&redirect_uri=https%3A%2F%2Fwww.certification.openid.net%2Ftest%2Fa%2Foidf-authlete-core%2Fcallback
2020-07-31 12:31:05 RESPONSE
CallTokenEndpoint
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:31:05 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "1547",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NSwiaWF0IjoxNTk2MTk4NjY1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJBcTRBdG5LczJLQUo5eVZ4MjhKNGVKcUppajVxM1pYYm1fV2lYM2M0R2JNIn0.mp4v1dJDVRjjRztMe6AeD-1j0zu3NhUwMH_PwcG5u1Mt4mgTkWprMiOiC5HoWStyqlieWBwHHg7a5flQVy-aODtsAmq5a5fglgt_M2oLCB33vgoiRu4F4euJ0kg_KPMThNWdOzUcqH3hpS5BX2abM0i24PVYgJs1Vho2FlexsE4WMdTxQkkkSWT5YW2vdKm4YgfH2N8A4SkjSKOVofWDXlFVXPwzEANcMXV4G45UKI7iDrfXmG2rcANU8c41i8zA5Q3OZEk4gcZjvte8JG53yAcPMKy0hlXKkbqPx86cC1nU9PLLUKjznwcMdx4k3UThGE2NDIxOMNZWKHX5G_cJ0g","refresh_token":"pl5n3e_lQMWI10iUYMy3x-TIB-skK9adh5nA93Sf2L0","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2NSwiaWF0IjoxNTk2MTk4NjY1LCJub25jZSI6InlJSFByc3BvTVcifQ.eB11YlUVnT8d91Lx69PjIZhXEGxtOQiSBiDWYQGLSjuRiUXqL1gfW2yceEfBXRqMHPriEty6oz_XmBtVTIje4WI1dRPAfrEMDcgzPdCZSs1RE5cWBVmMqxhaWVp6gA_QvJr2oBiEfHJGA7PueecHUO-cMpAcyx1y_WSQ7aPAapNPKbNLFVhW5JeNh0VK0GMcRZD-nHfGWpH7P0Oe7gV096o1piYRA6wSH5t2Pw4kJZZkS1ZpfoLAk98Zf92ogkNdDjlaCy8zydGknH9QOBqyxZOMp7bLNQGPPPOi65Y0UCidiyqXXBE_twy5mDbC7TccVDV_03jpKxym9Tjdb1UBmw","token_type":"Bearer","expires_in":86400}
2020-07-31 12:31:05
CallTokenEndpoint
Token endpoint response
token_endpoint_response
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NSwiaWF0IjoxNTk2MTk4NjY1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJBcTRBdG5LczJLQUo5eVZ4MjhKNGVKcUppajVxM1pYYm1fV2lYM2M0R2JNIn0.mp4v1dJDVRjjRztMe6AeD-1j0zu3NhUwMH_PwcG5u1Mt4mgTkWprMiOiC5HoWStyqlieWBwHHg7a5flQVy-aODtsAmq5a5fglgt_M2oLCB33vgoiRu4F4euJ0kg_KPMThNWdOzUcqH3hpS5BX2abM0i24PVYgJs1Vho2FlexsE4WMdTxQkkkSWT5YW2vdKm4YgfH2N8A4SkjSKOVofWDXlFVXPwzEANcMXV4G45UKI7iDrfXmG2rcANU8c41i8zA5Q3OZEk4gcZjvte8JG53yAcPMKy0hlXKkbqPx86cC1nU9PLLUKjznwcMdx4k3UThGE2NDIxOMNZWKHX5G_cJ0g","refresh_token":"pl5n3e_lQMWI10iUYMy3x-TIB-skK9adh5nA93Sf2L0","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2NSwiaWF0IjoxNTk2MTk4NjY1LCJub25jZSI6InlJSFByc3BvTVcifQ.eB11YlUVnT8d91Lx69PjIZhXEGxtOQiSBiDWYQGLSjuRiUXqL1gfW2yceEfBXRqMHPriEty6oz_XmBtVTIje4WI1dRPAfrEMDcgzPdCZSs1RE5cWBVmMqxhaWVp6gA_QvJr2oBiEfHJGA7PueecHUO-cMpAcyx1y_WSQ7aPAapNPKbNLFVhW5JeNh0VK0GMcRZD-nHfGWpH7P0Oe7gV096o1piYRA6wSH5t2Pw4kJZZkS1ZpfoLAk98Zf92ogkNdDjlaCy8zydGknH9QOBqyxZOMp7bLNQGPPPOi65Y0UCidiyqXXBE_twy5mDbC7TccVDV_03jpKxym9Tjdb1UBmw","token_type":"Bearer","expires_in":86400}
2020-07-31 12:31:05 SUCCESS
CallTokenEndpoint
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NSwiaWF0IjoxNTk2MTk4NjY1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJBcTRBdG5LczJLQUo5eVZ4MjhKNGVKcUppajVxM1pYYm1fV2lYM2M0R2JNIn0.mp4v1dJDVRjjRztMe6AeD-1j0zu3NhUwMH_PwcG5u1Mt4mgTkWprMiOiC5HoWStyqlieWBwHHg7a5flQVy-aODtsAmq5a5fglgt_M2oLCB33vgoiRu4F4euJ0kg_KPMThNWdOzUcqH3hpS5BX2abM0i24PVYgJs1Vho2FlexsE4WMdTxQkkkSWT5YW2vdKm4YgfH2N8A4SkjSKOVofWDXlFVXPwzEANcMXV4G45UKI7iDrfXmG2rcANU8c41i8zA5Q3OZEk4gcZjvte8JG53yAcPMKy0hlXKkbqPx86cC1nU9PLLUKjznwcMdx4k3UThGE2NDIxOMNZWKHX5G_cJ0g
refresh_token
pl5n3e_lQMWI10iUYMy3x-TIB-skK9adh5nA93Sf2L0
scope
offline_access openid
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2NSwiaWF0IjoxNTk2MTk4NjY1LCJub25jZSI6InlJSFByc3BvTVcifQ.eB11YlUVnT8d91Lx69PjIZhXEGxtOQiSBiDWYQGLSjuRiUXqL1gfW2yceEfBXRqMHPriEty6oz_XmBtVTIje4WI1dRPAfrEMDcgzPdCZSs1RE5cWBVmMqxhaWVp6gA_QvJr2oBiEfHJGA7PueecHUO-cMpAcyx1y_WSQ7aPAapNPKbNLFVhW5JeNh0VK0GMcRZD-nHfGWpH7P0Oe7gV096o1piYRA6wSH5t2Pw4kJZZkS1ZpfoLAk98Zf92ogkNdDjlaCy8zydGknH9QOBqyxZOMp7bLNQGPPPOi65Y0UCidiyqXXBE_twy5mDbC7TccVDV_03jpKxym9Tjdb1UBmw
token_type
Bearer
expires_in
86400
2020-07-31 12:31:05 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:31:05 SUCCESS
CheckForAccessTokenValue
Found an access token
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NSwiaWF0IjoxNTk2MTk4NjY1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJBcTRBdG5LczJLQUo5eVZ4MjhKNGVKcUppajVxM1pYYm1fV2lYM2M0R2JNIn0.mp4v1dJDVRjjRztMe6AeD-1j0zu3NhUwMH_PwcG5u1Mt4mgTkWprMiOiC5HoWStyqlieWBwHHg7a5flQVy-aODtsAmq5a5fglgt_M2oLCB33vgoiRu4F4euJ0kg_KPMThNWdOzUcqH3hpS5BX2abM0i24PVYgJs1Vho2FlexsE4WMdTxQkkkSWT5YW2vdKm4YgfH2N8A4SkjSKOVofWDXlFVXPwzEANcMXV4G45UKI7iDrfXmG2rcANU8c41i8zA5Q3OZEk4gcZjvte8JG53yAcPMKy0hlXKkbqPx86cC1nU9PLLUKjznwcMdx4k3UThGE2NDIxOMNZWKHX5G_cJ0g
2020-07-31 12:31:05 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NSwiaWF0IjoxNTk2MTk4NjY1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJBcTRBdG5LczJLQUo5eVZ4MjhKNGVKcUppajVxM1pYYm1fV2lYM2M0R2JNIn0.mp4v1dJDVRjjRztMe6AeD-1j0zu3NhUwMH_PwcG5u1Mt4mgTkWprMiOiC5HoWStyqlieWBwHHg7a5flQVy-aODtsAmq5a5fglgt_M2oLCB33vgoiRu4F4euJ0kg_KPMThNWdOzUcqH3hpS5BX2abM0i24PVYgJs1Vho2FlexsE4WMdTxQkkkSWT5YW2vdKm4YgfH2N8A4SkjSKOVofWDXlFVXPwzEANcMXV4G45UKI7iDrfXmG2rcANU8c41i8zA5Q3OZEk4gcZjvte8JG53yAcPMKy0hlXKkbqPx86cC1nU9PLLUKjznwcMdx4k3UThGE2NDIxOMNZWKHX5G_cJ0g
type
Bearer
2020-07-31 12:31:05 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:31:05 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:31:05 SUCCESS
CheckForRefreshTokenValue
Found a refresh token
refresh_token
pl5n3e_lQMWI10iUYMy3x-TIB-skK9adh5nA93Sf2L0
2020-07-31 12:31:05 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2NSwiaWF0IjoxNTk2MTk4NjY1LCJub25jZSI6InlJSFByc3BvTVcifQ.eB11YlUVnT8d91Lx69PjIZhXEGxtOQiSBiDWYQGLSjuRiUXqL1gfW2yceEfBXRqMHPriEty6oz_XmBtVTIje4WI1dRPAfrEMDcgzPdCZSs1RE5cWBVmMqxhaWVp6gA_QvJr2oBiEfHJGA7PueecHUO-cMpAcyx1y_WSQ7aPAapNPKbNLFVhW5JeNh0VK0GMcRZD-nHfGWpH7P0Oe7gV096o1piYRA6wSH5t2Pw4kJZZkS1ZpfoLAk98Zf92ogkNdDjlaCy8zydGknH9QOBqyxZOMp7bLNQGPPPOi65Y0UCidiyqXXBE_twy5mDbC7TccVDV_03jpKxym9Tjdb1UBmw
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "sub": "1001",
  "aud": "470553331604632",
  "s_hash": "ERGXTWiakPGTLuZB4JMbaA",
  "auth_time": 1596198660,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198965,
  "iat": 1596198665,
  "nonce": "yIHPrspoMW"
}
2020-07-31 12:31:05 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:31:05 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
yIHPrspoMW
2020-07-31 12:31:05 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:31:05 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2NSwiaWF0IjoxNTk2MTk4NjY1LCJub25jZSI6InlJSFByc3BvTVcifQ.eB11YlUVnT8d91Lx69PjIZhXEGxtOQiSBiDWYQGLSjuRiUXqL1gfW2yceEfBXRqMHPriEty6oz_XmBtVTIje4WI1dRPAfrEMDcgzPdCZSs1RE5cWBVmMqxhaWVp6gA_QvJr2oBiEfHJGA7PueecHUO-cMpAcyx1y_WSQ7aPAapNPKbNLFVhW5JeNh0VK0GMcRZD-nHfGWpH7P0Oe7gV096o1piYRA6wSH5t2Pw4kJZZkS1ZpfoLAk98Zf92ogkNdDjlaCy8zydGknH9QOBqyxZOMp7bLNQGPPPOi65Y0UCidiyqXXBE_twy5mDbC7TccVDV_03jpKxym9Tjdb1UBmw
2020-07-31 12:31:05 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJFUkdYVFdpYWtQR1RMdVpCNEpNYmFBIiwiYXV0aF90aW1lIjoxNTk2MTk4NjYwLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODk2NSwiaWF0IjoxNTk2MTk4NjY1LCJub25jZSI6InlJSFByc3BvTVcifQ.eB11YlUVnT8d91Lx69PjIZhXEGxtOQiSBiDWYQGLSjuRiUXqL1gfW2yceEfBXRqMHPriEty6oz_XmBtVTIje4WI1dRPAfrEMDcgzPdCZSs1RE5cWBVmMqxhaWVp6gA_QvJr2oBiEfHJGA7PueecHUO-cMpAcyx1y_WSQ7aPAapNPKbNLFVhW5JeNh0VK0GMcRZD-nHfGWpH7P0Oe7gV096o1piYRA6wSH5t2Pw4kJZZkS1ZpfoLAk98Zf92ogkNdDjlaCy8zydGknH9QOBqyxZOMp7bLNQGPPPOi65Y0UCidiyqXXBE_twy5mDbC7TccVDV_03jpKxym9Tjdb1UBmw
2020-07-31 12:31:05 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
2020-07-31 12:31:05 SUCCESS
VerifyIdTokenSubConsistentHybridFlow
authorization endpoint and token endpoint id_token have same sub
sub_auth_endpoint
1001
sub_token_endpoint
1001
2020-07-31 12:31:05 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
pl5n3e_lQMWI10iUYMy3x-TIB-skK9adh5nA93Sf2L0
2020-07-31 12:31:05 SUCCESS
EnsureRefreshTokenContainsAllowedCharactersOnly
Refresh token does not contain any illegal characters
Second client: Refresh Token Request
2020-07-31 12:31:05 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
pl5n3e_lQMWI10iUYMy3x-TIB-skK9adh5nA93Sf2L0
2020-07-31 12:31:05 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB
2020-07-31 12:31:05 SUCCESS
WaitForOneSecond
Pausing for 1 seconds
2020-07-31 12:31:06 SUCCESS
WaitForOneSecond
Woke up after 1 seconds sleep
2020-07-31 12:31:06
CallTokenEndpointAndReturnFullResponse
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB",
  "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=pl5n3e_lQMWI10iUYMy3x-TIB-skK9adh5nA93Sf2L0
2020-07-31 12:31:06 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:31:06 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "860",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NiwiaWF0IjoxNTk2MTk4NjY2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJPOUVSYXY4RzdiUlFZYS1qUVZDckJ6ZlBYQk5ZSlY2cjEtTmZaVE9tOGhzIn0.TcaXNeCSquL6kekWz2yXF1emGtl9Ux70ZL__bbfY40QDKYLg_S9aO_N3hAd-UBQL7PRuZ4qZSeXUkyqweCasCmhFIBIvt4xBGXuZfilV-k8Z951gkUvmd7niXgPDOLJ7C5bhVa6p-Ci-byibaXUjg3nVCDsjwZbj6qut-c8-Q1txfmPQUEH-ZyXk5Q_asqxTE0c_NujjvfTVNYSmDktbFduHeXLQPyxHujPHjyxAOXNH6S2KabBIFI1XM82Ejojc_r3eC-0Aibr7TuubbgzenxNW6DOVyw-bcKQ2NRt58SgoGDM7f-yoJGtpr-Rcd_qlM3xGuVhAfvsKFbbMcaIkYw","refresh_token":"rFwao9T7_deCFAFLEivGPyPSl-Ke2FobCJWzT6QqBAY","scope":"openid offline_access","token_type":"Bearer","expires_in":86400}
2020-07-31 12:31:06 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NiwiaWF0IjoxNTk2MTk4NjY2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJPOUVSYXY4RzdiUlFZYS1qUVZDckJ6ZlBYQk5ZSlY2cjEtTmZaVE9tOGhzIn0.TcaXNeCSquL6kekWz2yXF1emGtl9Ux70ZL__bbfY40QDKYLg_S9aO_N3hAd-UBQL7PRuZ4qZSeXUkyqweCasCmhFIBIvt4xBGXuZfilV-k8Z951gkUvmd7niXgPDOLJ7C5bhVa6p-Ci-byibaXUjg3nVCDsjwZbj6qut-c8-Q1txfmPQUEH-ZyXk5Q_asqxTE0c_NujjvfTVNYSmDktbFduHeXLQPyxHujPHjyxAOXNH6S2KabBIFI1XM82Ejojc_r3eC-0Aibr7TuubbgzenxNW6DOVyw-bcKQ2NRt58SgoGDM7f-yoJGtpr-Rcd_qlM3xGuVhAfvsKFbbMcaIkYw
refresh_token
rFwao9T7_deCFAFLEivGPyPSl-Ke2FobCJWzT6QqBAY
scope
openid offline_access
token_type
Bearer
expires_in
86400
2020-07-31 12:31:06 SUCCESS
CheckTokenEndpointHttpStatus200
Token endpoint http status code was 200
2020-07-31 12:31:06 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2020-07-31 12:31:06 SUCCESS
CheckTokenEndpointCacheHeaders
Checked 'pragma' and 'cache-control' in the headers of token_endpoint_response.
2020-07-31 12:31:06 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:31:06 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NiwiaWF0IjoxNTk2MTk4NjY2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJPOUVSYXY4RzdiUlFZYS1qUVZDckJ6ZlBYQk5ZSlY2cjEtTmZaVE9tOGhzIn0.TcaXNeCSquL6kekWz2yXF1emGtl9Ux70ZL__bbfY40QDKYLg_S9aO_N3hAd-UBQL7PRuZ4qZSeXUkyqweCasCmhFIBIvt4xBGXuZfilV-k8Z951gkUvmd7niXgPDOLJ7C5bhVa6p-Ci-byibaXUjg3nVCDsjwZbj6qut-c8-Q1txfmPQUEH-ZyXk5Q_asqxTE0c_NujjvfTVNYSmDktbFduHeXLQPyxHujPHjyxAOXNH6S2KabBIFI1XM82Ejojc_r3eC-0Aibr7TuubbgzenxNW6DOVyw-bcKQ2NRt58SgoGDM7f-yoJGtpr-Rcd_qlM3xGuVhAfvsKFbbMcaIkYw
type
Bearer
2020-07-31 12:31:06 SUCCESS
CheckTokenTypeIsBearer
Token type is bearer
2020-07-31 12:31:06 SUCCESS
EnsureMinimumAccessTokenEntropy
Calculated shannon entropy seems sufficient
actual
4148.258508596185
expected
96.0
2020-07-31 12:31:06 SUCCESS
EnsureAccessTokenContainsAllowedCharactersOnly
Access token does not contain any illegal characters
2020-07-31 12:31:06 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:31:06 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:31:06 SUCCESS
EnsureAccessTokenValuesAreDifferent
Access token values are not the same
first_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NSwiaWF0IjoxNTk2MTk4NjY1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJBcTRBdG5LczJLQUo5eVZ4MjhKNGVKcUppajVxM1pYYm1fV2lYM2M0R2JNIn0.mp4v1dJDVRjjRztMe6AeD-1j0zu3NhUwMH_PwcG5u1Mt4mgTkWprMiOiC5HoWStyqlieWBwHHg7a5flQVy-aODtsAmq5a5fglgt_M2oLCB33vgoiRu4F4euJ0kg_KPMThNWdOzUcqH3hpS5BX2abM0i24PVYgJs1Vho2FlexsE4WMdTxQkkkSWT5YW2vdKm4YgfH2N8A4SkjSKOVofWDXlFVXPwzEANcMXV4G45UKI7iDrfXmG2rcANU8c41i8zA5Q3OZEk4gcZjvte8JG53yAcPMKy0hlXKkbqPx86cC1nU9PLLUKjznwcMdx4k3UThGE2NDIxOMNZWKHX5G_cJ0g
second_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NiwiaWF0IjoxNTk2MTk4NjY2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJPOUVSYXY4RzdiUlFZYS1qUVZDckJ6ZlBYQk5ZSlY2cjEtTmZaVE9tOGhzIn0.TcaXNeCSquL6kekWz2yXF1emGtl9Ux70ZL__bbfY40QDKYLg_S9aO_N3hAd-UBQL7PRuZ4qZSeXUkyqweCasCmhFIBIvt4xBGXuZfilV-k8Z951gkUvmd7niXgPDOLJ7C5bhVa6p-Ci-byibaXUjg3nVCDsjwZbj6qut-c8-Q1txfmPQUEH-ZyXk5Q_asqxTE0c_NujjvfTVNYSmDktbFduHeXLQPyxHujPHjyxAOXNH6S2KabBIFI1XM82Ejojc_r3eC-0Aibr7TuubbgzenxNW6DOVyw-bcKQ2NRt58SgoGDM7f-yoJGtpr-Rcd_qlM3xGuVhAfvsKFbbMcaIkYw
2020-07-31 12:31:06 INFO
ExtractIdTokenFromTokenResponse
Couldn't find id_token in token_endpoint_response
2020-07-31 12:31:06 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
rFwao9T7_deCFAFLEivGPyPSl-Ke2FobCJWzT6QqBAY
2020-07-31 12:31:06 SUCCESS
EnsureMinimumRefreshTokenLength
Refresh token is of sufficient length
actual
344
required
128
2020-07-31 12:31:06 SUCCESS
EnsureMinimumRefreshTokenEntropy
Calculated shannon entropy seems sufficient
actual
213.32938445219023
expected
96.0
2020-07-31 12:31:06 INFO
CompareIdTokenClaims
Skipped evaluation due to missing required object: second_id_token
expected
second_id_token
mapped
second_id_token
Second client: Userinfo endpoint tests
2020-07-31 12:31:06
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://fapidev-rs.authlete.net/api/userinfo
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NTA2NiwiaWF0IjoxNTk2MTk4NjY2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJPOUVSYXY4RzdiUlFZYS1qUVZDckJ6ZlBYQk5ZSlY2cjEtTmZaVE9tOGhzIn0.TcaXNeCSquL6kekWz2yXF1emGtl9Ux70ZL__bbfY40QDKYLg_S9aO_N3hAd-UBQL7PRuZ4qZSeXUkyqweCasCmhFIBIvt4xBGXuZfilV-k8Z951gkUvmd7niXgPDOLJ7C5bhVa6p-Ci-byibaXUjg3nVCDsjwZbj6qut-c8-Q1txfmPQUEH-ZyXk5Q_asqxTE0c_NujjvfTVNYSmDktbFduHeXLQPyxHujPHjyxAOXNH6S2KabBIFI1XM82Ejojc_r3eC-0Aibr7TuubbgzenxNW6DOVyw-bcKQ2NRt58SgoGDM7f-yoJGtpr-Rcd_qlM3xGuVhAfvsKFbbMcaIkYw",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:31:07 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:31:06 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"sub":"1001"}
2020-07-31 12:31:07 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:31:06 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
status_code
{
  "code": 200
}
body
{"sub":"1001"}
Attempting to use refresh_token issued to client 2 with client 1
2020-07-31 12:31:07 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
rFwao9T7_deCFAFLEivGPyPSl-Ke2FobCJWzT6QqBAY
2020-07-31 12:31:07 SUCCESS
AddScopeToTokenEndpointRequest
Added scope of 'openid offline_access' to token endpoint request
grant_type
refresh_token
refresh_token
rFwao9T7_deCFAFLEivGPyPSl-Ke2FobCJWzT6QqBAY
scope
openid offline_access
2020-07-31 12:31:07 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3
2020-07-31 12:31:07
CallTokenEndpointAndReturnFullResponse
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3",
  "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=rFwao9T7_deCFAFLEivGPyPSl-Ke2FobCJWzT6QqBAY&scope=openid+offline_access
2020-07-31 12:31:07 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
400 BAD_REQUEST
response_status_text
Bad Request
response_headers
{
  "date": "Fri, 31 Jul 2020 12:31:07 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "155",
  "connection": "close"
}
response_body
{"error_description":"[A053307] The refresh token does not belong to the client.","error":"invalid_grant","error_uri":"https://docs.authlete.com/#A053307"}
2020-07-31 12:31:07 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
error_description
[A053307] The refresh token does not belong to the client.
error
invalid_grant
error_uri
https://docs.authlete.com/#A053307
2020-07-31 12:31:07 SUCCESS
ValidateErrorFromTokenEndpointResponseError
Token endpoint response error returned valid 'error' field
error
invalid_grant
2020-07-31 12:31:07 SUCCESS
CheckTokenEndpointHttpStatus400
Token endpoint http status code was 400
2020-07-31 12:31:07 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2020-07-31 12:31:07 SUCCESS
CheckErrorFromTokenEndpointResponseErrorInvalidGrant
Token Endpoint response error returned expected 'error' of 'invalid_grant'
error
invalid_grant
2020-07-31 12:31:07 FINISHED
oidcc-refresh-token
Test has run to completion
testmodule_result
PASSED
Unregister dynamically registered client
2020-07-31 12:31:07 INFO
UnregisterDynamicallyRegisteredClient
Skipped evaluation due to missing required string: registration_client_uri
expected
registration_client_uri
Second client: Unregister dynamically registered client
2020-07-31 12:31:07 INFO
UnregisterDynamicallyRegisteredClient
Skipped evaluation due to missing required string: registration_client_uri
expected
registration_client_uri
2020-07-31 12:31:13
TEST-RUNNER
Alias has now been claimed by another test
alias
oidf-authlete-core
new_test_id
6HmxaZNkCB9Rur3
Test Results