Test Summary

Test Results

Expand All Collapse All
All times are UTC
2020-07-31 12:26:02 INFO
TEST-RUNNER
Test instance xv94uIvx4TRw9O8 created
baseUrl
https://www.certification.openid.net/test/a/oidf-authlete-core
variant
{
  "client_auth_type": "client_secret_basic",
  "response_type": "code id_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:26:02 SUCCESS
CreateRedirectUri
Created redirect URI
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
2020-07-31 12:26:02 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:26:02 SUCCESS
CheckServerConfiguration
Found required server configuration keys
required
[
  "authorization_endpoint",
  "token_endpoint",
  "issuer"
]
2020-07-31 12:26:02 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:26:02
FetchServerKeys
Fetching server key
jwks_uri
https://fapidev-as.authlete.net/api/jwks
2020-07-31 12:26:02
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:26:02 RESPONSE
FetchServerKeys
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:26: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": "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:26:02
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:26:02 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:26:02 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:26:02 SUCCESS
ValidateServerJWKs
Valid server JWKs: keys are valid JSON, contain the required fields and are correctly encoded using unpadded base64url
2020-07-31 12:26:02 SUCCESS
CheckForKeyIdInServerJWKs
All keys contain kids
2020-07-31 12:26:02 SUCCESS
CheckDistinctKeyIdValueInServerJWKs
Distinct 'kid' value in all keys of server_jwks
see
https://bitbucket.org/openid/connect/issues/1127
2020-07-31 12:26:02 SUCCESS
EnsureServerJwksDoesNotContainPrivateOrSymmetricKeys
Jwks does not contain any private or symmetric keys
2020-07-31 12:26:02 SUCCESS
GetStaticClientConfiguration
Found a static client object
client_id
470519824180317
client_secret
Ek2CiuOrmfdhvsjGl037_pscCmYseks4bzSSxc3UZUcr-9Ki2rlCRdg_Mt-Ukc9b-LpajnMUcwmzqgXs-eDKzw
2020-07-31 12:26:02
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:26:02 SUCCESS
GetStaticClient2Configuration
Found a static second client object
client_id
470553331604632
client_secret
3NLezSFOjyxuERp_cH3zFMbym9oNur3NMdYIJWimiTHEKROvsDTT1-BVfo8AbLNiUgyIbbGcr79n7fkTL7D8qA
2020-07-31 12:26:02
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:26:02 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:26:02
oidcc-refresh-token
Setup Done
Make request to authorization endpoint
2020-07-31 12:26:02 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:26:02
CreateRandomStateValue
Created state value
requested_state_length
10
state
buMNCaQbrW
2020-07-31 12:26:02 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
buMNCaQbrW
2020-07-31 12:26:02
CreateRandomNonceValue
Created nonce value
requested_nonce_length
10
nonce
cDWSPOs0Oh
2020-07-31 12:26:02 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
buMNCaQbrW
nonce
cDWSPOs0Oh
2020-07-31 12:26:02 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
buMNCaQbrW
nonce
cDWSPOs0Oh
response_type
code id_token
2020-07-31 12:26:02
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
buMNCaQbrW
nonce
cDWSPOs0Oh
response_type
code id_token
response_mode
form_post
2020-07-31 12:26:02 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
buMNCaQbrW
nonce
cDWSPOs0Oh
response_type
code id_token
response_mode
form_post
prompt
consent
2020-07-31 12:26:02 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=buMNCaQbrW&nonce=cDWSPOs0Oh&response_type=code%20id_token&response_mode=form_post&prompt=consent
2020-07-31 12:26:02 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=buMNCaQbrW&nonce=cDWSPOs0Oh&response_type=code%20id_token&response_mode=form_post&prompt=consent
2020-07-31 12:26:02
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=buMNCaQbrW&nonce=cDWSPOs0Oh&response_type=code%20id_token&response_mode=form_post&prompt=consent
2020-07-31 12:26: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</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:26: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=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=buMNCaQbrW&nonce=cDWSPOs0Oh&response_type=code%20id_token&response_mode=form_post&prompt=consent
target
loginId
2020-07-31 12:26: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=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=buMNCaQbrW&nonce=cDWSPOs0Oh&response_type=code%20id_token&response_mode=form_post&prompt=consent
target
password
2020-07-31 12:26:03 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=buMNCaQbrW&nonce=cDWSPOs0Oh&response_type=code%20id_token&response_mode=form_post&prompt=consent
target
authorized
2020-07-31 12:26:03 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance xv94uIvx4TRw9O8
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": "793",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
callback
incoming_body_form_params
{
  "state": "buMNCaQbrW",
  "code": "oEaDZbKgU6_tc0eRCh1lq96qDCjRUqnadEgpYDZ5Lcc",
  "id_token": "eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJjX2hhc2giOiI4RWpidzVVVHdyaURPT0tKUElvOUdRIiwic19oYXNoIjoiTGYzbUpLLVEtTDBFTy1tVXVjU0FHdyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjMsImlhdCI6MTU5NjE5ODM2Mywibm9uY2UiOiJjRFdTUE9zME9oIn0.czgG6LganFi61brStnNCiK2hhTH0BI5QTl05XZJ2kOcxme4cIt5poynYTKyU03NKHdtNUReYG55qRCyS-LKihBtLkjGnZGVm6zgTiOIZ2luRYvbCLFB-kZXpzIpVQSoYx3386Fc1gSDuW8n39KN4TvxDWwsum64DvZKsnxrWEleaIMXwqMG2yZ7yXI2e-ELcKnNU5mUfTrnM1VytzR2IDPsxv34cf6NMfzczcaMUcyudCq7ETjVelMqcDq6UhPJswjqIzb3n0_FxDPLISQiSnSrKyd-vxiy11Zvun5spuAho4dIWRM4o1q9d8D9ZoD7_br6IoYAC6W6fLpj71BrMrg"
}
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
state=buMNCaQbrW&code=oEaDZbKgU6_tc0eRCh1lq96qDCjRUqnadEgpYDZ5Lcc&id_token=eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJjX2hhc2giOiI4RWpidzVVVHdyaURPT0tKUElvOUdRIiwic19oYXNoIjoiTGYzbUpLLVEtTDBFTy1tVXVjU0FHdyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjMsImlhdCI6MTU5NjE5ODM2Mywibm9uY2UiOiJjRFdTUE9zME9oIn0.czgG6LganFi61brStnNCiK2hhTH0BI5QTl05XZJ2kOcxme4cIt5poynYTKyU03NKHdtNUReYG55qRCyS-LKihBtLkjGnZGVm6zgTiOIZ2luRYvbCLFB-kZXpzIpVQSoYx3386Fc1gSDuW8n39KN4TvxDWwsum64DvZKsnxrWEleaIMXwqMG2yZ7yXI2e-ELcKnNU5mUfTrnM1VytzR2IDPsxv34cf6NMfzczcaMUcyudCq7ETjVelMqcDq6UhPJswjqIzb3n0_FxDPLISQiSnSrKyd-vxiy11Zvun5spuAho4dIWRM4o1q9d8D9ZoD7_br6IoYAC6W6fLpj71BrMrg
2020-07-31 12:26:03 SUCCESS
CreateRandomImplicitSubmitUrl
Created random implicit submission URL
implicit_submit
{
  "path": "implicit/NMEOEfhHhntYCTAiM8vh",
  "fullUrl": "https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/NMEOEfhHhntYCTAiM8vh"
}
2020-07-31 12:26:03 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance xv94uIvx4TRw9O8
outgoing
ModelAndView [view="implicitCallback"; model={implicitSubmitUrl=https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/NMEOEfhHhntYCTAiM8vh, returnUrl=/log-detail.html?log=xv94uIvx4TRw9O8}]
outgoing_path
callback
2020-07-31 12:26:03 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:26:03 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:26:03 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance xv94uIvx4TRw9O8
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\u003dB9172D272A0003B54A0E25E7EF5445C6",
  "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/NMEOEfhHhntYCTAiM8vh
incoming_body_form_params
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
2020-07-31 12:26:03 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance xv94uIvx4TRw9O8
outgoing
org.springframework.web.servlet.view.RedirectView: [RedirectView]; URL [/log-detail.html?log=xv94uIvx4TRw9O8]
outgoing_path
implicit/NMEOEfhHhntYCTAiM8vh
2020-07-31 12:26:03 SUCCESS
ExtractImplicitHashToCallbackResponse
implicit_hash is empty
2020-07-31 12:26:03 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": "793",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
http_method
POST
url_fragment
{}
post_body
{
  "state": "buMNCaQbrW",
  "code": "oEaDZbKgU6_tc0eRCh1lq96qDCjRUqnadEgpYDZ5Lcc",
  "id_token": "eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJjX2hhc2giOiI4RWpidzVVVHdyaURPT0tKUElvOUdRIiwic19oYXNoIjoiTGYzbUpLLVEtTDBFTy1tVXVjU0FHdyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjMsImlhdCI6MTU5NjE5ODM2Mywibm9uY2UiOiJjRFdTUE9zME9oIn0.czgG6LganFi61brStnNCiK2hhTH0BI5QTl05XZJ2kOcxme4cIt5poynYTKyU03NKHdtNUReYG55qRCyS-LKihBtLkjGnZGVm6zgTiOIZ2luRYvbCLFB-kZXpzIpVQSoYx3386Fc1gSDuW8n39KN4TvxDWwsum64DvZKsnxrWEleaIMXwqMG2yZ7yXI2e-ELcKnNU5mUfTrnM1VytzR2IDPsxv34cf6NMfzczcaMUcyudCq7ETjVelMqcDq6UhPJswjqIzb3n0_FxDPLISQiSnSrKyd-vxiy11Zvun5spuAho4dIWRM4o1q9d8D9ZoD7_br6IoYAC6W6fLpj71BrMrg"
}
Verify authorization endpoint response
2020-07-31 12:26:03 SUCCESS
CheckCallbackHttpMethodIsPost
HTTP method used at redirect_uri is 'POST'
2020-07-31 12:26:03 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:26:03 SUCCESS
RejectAuthCodeInUrlQuery
Authorization code is not present in URL query returned from authorization endpoint
2020-07-31 12:26:03 SUCCESS
RejectErrorInUrlQuery
'error' is not present in URL query returned from authorization endpoint
2020-07-31 12:26:03 SUCCESS
CheckMatchingCallbackParameters
Callback parameters successfully verified
2020-07-31 12:26:03 SUCCESS
CheckIfAuthorizationEndpointError
No error from authorization endpoint
2020-07-31 12:26:03 SUCCESS
CheckMatchingStateParameter
State parameter correctly returned
state
buMNCaQbrW
2020-07-31 12:26:03 SUCCESS
ExtractAuthorizationCodeFromAuthorizationResponse
Found authorization code
code
oEaDZbKgU6_tc0eRCh1lq96qDCjRUqnadEgpYDZ5Lcc
2020-07-31 12:26:03 SUCCESS
ExtractIdTokenFromAuthorizationResponse
Found and parsed the id_token from authorization_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJjX2hhc2giOiI4RWpidzVVVHdyaURPT0tKUElvOUdRIiwic19oYXNoIjoiTGYzbUpLLVEtTDBFTy1tVXVjU0FHdyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjMsImlhdCI6MTU5NjE5ODM2Mywibm9uY2UiOiJjRFdTUE9zME9oIn0.czgG6LganFi61brStnNCiK2hhTH0BI5QTl05XZJ2kOcxme4cIt5poynYTKyU03NKHdtNUReYG55qRCyS-LKihBtLkjGnZGVm6zgTiOIZ2luRYvbCLFB-kZXpzIpVQSoYx3386Fc1gSDuW8n39KN4TvxDWwsum64DvZKsnxrWEleaIMXwqMG2yZ7yXI2e-ELcKnNU5mUfTrnM1VytzR2IDPsxv34cf6NMfzczcaMUcyudCq7ETjVelMqcDq6UhPJswjqIzb3n0_FxDPLISQiSnSrKyd-vxiy11Zvun5spuAho4dIWRM4o1q9d8D9ZoD7_br6IoYAC6W6fLpj71BrMrg
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "sub": "1001",
  "aud": "470519824180317",
  "c_hash": "8Ejbw5UTwriDOOKJPIo9GQ",
  "s_hash": "Lf3mJK-Q-L0EO-mUucSAGw",
  "auth_time": 1596198363,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198663,
  "iat": 1596198363,
  "nonce": "cDWSPOs0Oh"
}
2020-07-31 12:26:03 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:26:03 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
cDWSPOs0Oh
2020-07-31 12:26:03 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:26:03 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJjX2hhc2giOiI4RWpidzVVVHdyaURPT0tKUElvOUdRIiwic19oYXNoIjoiTGYzbUpLLVEtTDBFTy1tVXVjU0FHdyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjMsImlhdCI6MTU5NjE5ODM2Mywibm9uY2UiOiJjRFdTUE9zME9oIn0.czgG6LganFi61brStnNCiK2hhTH0BI5QTl05XZJ2kOcxme4cIt5poynYTKyU03NKHdtNUReYG55qRCyS-LKihBtLkjGnZGVm6zgTiOIZ2luRYvbCLFB-kZXpzIpVQSoYx3386Fc1gSDuW8n39KN4TvxDWwsum64DvZKsnxrWEleaIMXwqMG2yZ7yXI2e-ELcKnNU5mUfTrnM1VytzR2IDPsxv34cf6NMfzczcaMUcyudCq7ETjVelMqcDq6UhPJswjqIzb3n0_FxDPLISQiSnSrKyd-vxiy11Zvun5spuAho4dIWRM4o1q9d8D9ZoD7_br6IoYAC6W6fLpj71BrMrg
2020-07-31 12:26:03 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJjX2hhc2giOiI4RWpidzVVVHdyaURPT0tKUElvOUdRIiwic19oYXNoIjoiTGYzbUpLLVEtTDBFTy1tVXVjU0FHdyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjMsImlhdCI6MTU5NjE5ODM2Mywibm9uY2UiOiJjRFdTUE9zME9oIn0.czgG6LganFi61brStnNCiK2hhTH0BI5QTl05XZJ2kOcxme4cIt5poynYTKyU03NKHdtNUReYG55qRCyS-LKihBtLkjGnZGVm6zgTiOIZ2luRYvbCLFB-kZXpzIpVQSoYx3386Fc1gSDuW8n39KN4TvxDWwsum64DvZKsnxrWEleaIMXwqMG2yZ7yXI2e-ELcKnNU5mUfTrnM1VytzR2IDPsxv34cf6NMfzczcaMUcyudCq7ETjVelMqcDq6UhPJswjqIzb3n0_FxDPLISQiSnSrKyd-vxiy11Zvun5spuAho4dIWRM4o1q9d8D9ZoD7_br6IoYAC6W6fLpj71BrMrg
2020-07-31 12:26:03 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
2020-07-31 12:26:03 SUCCESS
CreateTokenEndpointRequestForAuthorizationCodeGrant
grant_type
authorization_code
code
oEaDZbKgU6_tc0eRCh1lq96qDCjRUqnadEgpYDZ5Lcc
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
2020-07-31 12:26:03 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3
2020-07-31 12:26:03
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=oEaDZbKgU6_tc0eRCh1lq96qDCjRUqnadEgpYDZ5Lcc&redirect_uri=https%3A%2F%2Fwww.certification.openid.net%2Ftest%2Fa%2Foidf-authlete-core%2Fcallback
2020-07-31 12:26:03 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:26:04 RESPONSE
CallTokenEndpoint
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:26: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": "1547",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NCwiaWF0IjoxNTk2MTk4MzY0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJVTHBjaU81NTVXczlxRXQydUlxZ1h5VmNsc3JzVUZ3U0RuMEFsR1R1ZVY4In0.l-waKOB0GxT1TQaadZ8fpGNHZGD_hs3CZJ-NexOggF9vZwSD3PcErNmLM35-CXJgdHihiiqZ6QVH50gaA_nC_3cRDtzbc2mdnEtHVi1XzS8ZbSDJmMB4aMAv-vHPRER14iTelhUOiE5v7cT1WStpbgm1K_18CTkXnqpqkFKFVFVe_P57WJNmFYJQZodhw00wGar1_ZbCelMOdcBvY6MX1FxJBWt1VwZ6qfd81Rn20S2-qwVbyIemDQZubZm2Kx3QBJYIuhBGjlg7SEV_hSzwTLjKnJTOvSfGBIvV5MBEaTVaiEM4TTaEnst9jQblE5iZ7n02Kdw_v-JGUN6OF2cjuA","refresh_token":"4WuYJxHrnRFNzxifNf5pVDDKqTRBpf5i--BlH1jwnpU","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJMZjNtSkstUS1MMEVPLW1VdWNTQUd3IiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NCwiaWF0IjoxNTk2MTk4MzY0LCJub25jZSI6ImNEV1NQT3MwT2gifQ.CFH_HqCb-fCjOJi7vJ9lmWa2wjcWZMG_yCo7EFvZQr7wESvlldP1RIujV5ksUXbAs-BdaB5zsb26dKj3CpbQHnhglNj-DarOAORG72nVh7MuAuTjHJfsRwg7u23mTfA94B-4ptAkZpVNmlenficY50C0MVcw7YnTheAJXB1yyCWzD39Xk_rHr-ydJn1CIhTjTONdFr1pCG1d1DIBNt-PgIEmrFU20_CGdOVxu-j5cmOq1V1c1URCst2OQSqWeOUor3vjFcDsrcGpydGstpAXPCz8tWxnPikZDCdroj_RAHo71Sr7IkDL7UIxyKLmDm2tIiGZFy8UrCbJ2RYOiBqFfg","token_type":"Bearer","expires_in":86400}
2020-07-31 12:26:04
CallTokenEndpoint
Token endpoint response
token_endpoint_response
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NCwiaWF0IjoxNTk2MTk4MzY0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJVTHBjaU81NTVXczlxRXQydUlxZ1h5VmNsc3JzVUZ3U0RuMEFsR1R1ZVY4In0.l-waKOB0GxT1TQaadZ8fpGNHZGD_hs3CZJ-NexOggF9vZwSD3PcErNmLM35-CXJgdHihiiqZ6QVH50gaA_nC_3cRDtzbc2mdnEtHVi1XzS8ZbSDJmMB4aMAv-vHPRER14iTelhUOiE5v7cT1WStpbgm1K_18CTkXnqpqkFKFVFVe_P57WJNmFYJQZodhw00wGar1_ZbCelMOdcBvY6MX1FxJBWt1VwZ6qfd81Rn20S2-qwVbyIemDQZubZm2Kx3QBJYIuhBGjlg7SEV_hSzwTLjKnJTOvSfGBIvV5MBEaTVaiEM4TTaEnst9jQblE5iZ7n02Kdw_v-JGUN6OF2cjuA","refresh_token":"4WuYJxHrnRFNzxifNf5pVDDKqTRBpf5i--BlH1jwnpU","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJMZjNtSkstUS1MMEVPLW1VdWNTQUd3IiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NCwiaWF0IjoxNTk2MTk4MzY0LCJub25jZSI6ImNEV1NQT3MwT2gifQ.CFH_HqCb-fCjOJi7vJ9lmWa2wjcWZMG_yCo7EFvZQr7wESvlldP1RIujV5ksUXbAs-BdaB5zsb26dKj3CpbQHnhglNj-DarOAORG72nVh7MuAuTjHJfsRwg7u23mTfA94B-4ptAkZpVNmlenficY50C0MVcw7YnTheAJXB1yyCWzD39Xk_rHr-ydJn1CIhTjTONdFr1pCG1d1DIBNt-PgIEmrFU20_CGdOVxu-j5cmOq1V1c1URCst2OQSqWeOUor3vjFcDsrcGpydGstpAXPCz8tWxnPikZDCdroj_RAHo71Sr7IkDL7UIxyKLmDm2tIiGZFy8UrCbJ2RYOiBqFfg","token_type":"Bearer","expires_in":86400}
2020-07-31 12:26:04 SUCCESS
CallTokenEndpoint
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NCwiaWF0IjoxNTk2MTk4MzY0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJVTHBjaU81NTVXczlxRXQydUlxZ1h5VmNsc3JzVUZ3U0RuMEFsR1R1ZVY4In0.l-waKOB0GxT1TQaadZ8fpGNHZGD_hs3CZJ-NexOggF9vZwSD3PcErNmLM35-CXJgdHihiiqZ6QVH50gaA_nC_3cRDtzbc2mdnEtHVi1XzS8ZbSDJmMB4aMAv-vHPRER14iTelhUOiE5v7cT1WStpbgm1K_18CTkXnqpqkFKFVFVe_P57WJNmFYJQZodhw00wGar1_ZbCelMOdcBvY6MX1FxJBWt1VwZ6qfd81Rn20S2-qwVbyIemDQZubZm2Kx3QBJYIuhBGjlg7SEV_hSzwTLjKnJTOvSfGBIvV5MBEaTVaiEM4TTaEnst9jQblE5iZ7n02Kdw_v-JGUN6OF2cjuA
refresh_token
4WuYJxHrnRFNzxifNf5pVDDKqTRBpf5i--BlH1jwnpU
scope
offline_access openid
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJMZjNtSkstUS1MMEVPLW1VdWNTQUd3IiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NCwiaWF0IjoxNTk2MTk4MzY0LCJub25jZSI6ImNEV1NQT3MwT2gifQ.CFH_HqCb-fCjOJi7vJ9lmWa2wjcWZMG_yCo7EFvZQr7wESvlldP1RIujV5ksUXbAs-BdaB5zsb26dKj3CpbQHnhglNj-DarOAORG72nVh7MuAuTjHJfsRwg7u23mTfA94B-4ptAkZpVNmlenficY50C0MVcw7YnTheAJXB1yyCWzD39Xk_rHr-ydJn1CIhTjTONdFr1pCG1d1DIBNt-PgIEmrFU20_CGdOVxu-j5cmOq1V1c1URCst2OQSqWeOUor3vjFcDsrcGpydGstpAXPCz8tWxnPikZDCdroj_RAHo71Sr7IkDL7UIxyKLmDm2tIiGZFy8UrCbJ2RYOiBqFfg
token_type
Bearer
expires_in
86400
2020-07-31 12:26:04 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:26:04 SUCCESS
CheckForAccessTokenValue
Found an access token
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NCwiaWF0IjoxNTk2MTk4MzY0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJVTHBjaU81NTVXczlxRXQydUlxZ1h5VmNsc3JzVUZ3U0RuMEFsR1R1ZVY4In0.l-waKOB0GxT1TQaadZ8fpGNHZGD_hs3CZJ-NexOggF9vZwSD3PcErNmLM35-CXJgdHihiiqZ6QVH50gaA_nC_3cRDtzbc2mdnEtHVi1XzS8ZbSDJmMB4aMAv-vHPRER14iTelhUOiE5v7cT1WStpbgm1K_18CTkXnqpqkFKFVFVe_P57WJNmFYJQZodhw00wGar1_ZbCelMOdcBvY6MX1FxJBWt1VwZ6qfd81Rn20S2-qwVbyIemDQZubZm2Kx3QBJYIuhBGjlg7SEV_hSzwTLjKnJTOvSfGBIvV5MBEaTVaiEM4TTaEnst9jQblE5iZ7n02Kdw_v-JGUN6OF2cjuA
2020-07-31 12:26:04 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NCwiaWF0IjoxNTk2MTk4MzY0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJVTHBjaU81NTVXczlxRXQydUlxZ1h5VmNsc3JzVUZ3U0RuMEFsR1R1ZVY4In0.l-waKOB0GxT1TQaadZ8fpGNHZGD_hs3CZJ-NexOggF9vZwSD3PcErNmLM35-CXJgdHihiiqZ6QVH50gaA_nC_3cRDtzbc2mdnEtHVi1XzS8ZbSDJmMB4aMAv-vHPRER14iTelhUOiE5v7cT1WStpbgm1K_18CTkXnqpqkFKFVFVe_P57WJNmFYJQZodhw00wGar1_ZbCelMOdcBvY6MX1FxJBWt1VwZ6qfd81Rn20S2-qwVbyIemDQZubZm2Kx3QBJYIuhBGjlg7SEV_hSzwTLjKnJTOvSfGBIvV5MBEaTVaiEM4TTaEnst9jQblE5iZ7n02Kdw_v-JGUN6OF2cjuA
type
Bearer
2020-07-31 12:26:04 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:26:04 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:26:04 SUCCESS
CheckForRefreshTokenValue
Found a refresh token
refresh_token
4WuYJxHrnRFNzxifNf5pVDDKqTRBpf5i--BlH1jwnpU
2020-07-31 12:26:04 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJMZjNtSkstUS1MMEVPLW1VdWNTQUd3IiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NCwiaWF0IjoxNTk2MTk4MzY0LCJub25jZSI6ImNEV1NQT3MwT2gifQ.CFH_HqCb-fCjOJi7vJ9lmWa2wjcWZMG_yCo7EFvZQr7wESvlldP1RIujV5ksUXbAs-BdaB5zsb26dKj3CpbQHnhglNj-DarOAORG72nVh7MuAuTjHJfsRwg7u23mTfA94B-4ptAkZpVNmlenficY50C0MVcw7YnTheAJXB1yyCWzD39Xk_rHr-ydJn1CIhTjTONdFr1pCG1d1DIBNt-PgIEmrFU20_CGdOVxu-j5cmOq1V1c1URCst2OQSqWeOUor3vjFcDsrcGpydGstpAXPCz8tWxnPikZDCdroj_RAHo71Sr7IkDL7UIxyKLmDm2tIiGZFy8UrCbJ2RYOiBqFfg
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "sub": "1001",
  "aud": "470519824180317",
  "s_hash": "Lf3mJK-Q-L0EO-mUucSAGw",
  "auth_time": 1596198363,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198664,
  "iat": 1596198364,
  "nonce": "cDWSPOs0Oh"
}
2020-07-31 12:26:04 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:26:04 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
cDWSPOs0Oh
2020-07-31 12:26:04 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:26:04 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJMZjNtSkstUS1MMEVPLW1VdWNTQUd3IiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NCwiaWF0IjoxNTk2MTk4MzY0LCJub25jZSI6ImNEV1NQT3MwT2gifQ.CFH_HqCb-fCjOJi7vJ9lmWa2wjcWZMG_yCo7EFvZQr7wESvlldP1RIujV5ksUXbAs-BdaB5zsb26dKj3CpbQHnhglNj-DarOAORG72nVh7MuAuTjHJfsRwg7u23mTfA94B-4ptAkZpVNmlenficY50C0MVcw7YnTheAJXB1yyCWzD39Xk_rHr-ydJn1CIhTjTONdFr1pCG1d1DIBNt-PgIEmrFU20_CGdOVxu-j5cmOq1V1c1URCst2OQSqWeOUor3vjFcDsrcGpydGstpAXPCz8tWxnPikZDCdroj_RAHo71Sr7IkDL7UIxyKLmDm2tIiGZFy8UrCbJ2RYOiBqFfg
2020-07-31 12:26:04 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJMZjNtSkstUS1MMEVPLW1VdWNTQUd3IiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NCwiaWF0IjoxNTk2MTk4MzY0LCJub25jZSI6ImNEV1NQT3MwT2gifQ.CFH_HqCb-fCjOJi7vJ9lmWa2wjcWZMG_yCo7EFvZQr7wESvlldP1RIujV5ksUXbAs-BdaB5zsb26dKj3CpbQHnhglNj-DarOAORG72nVh7MuAuTjHJfsRwg7u23mTfA94B-4ptAkZpVNmlenficY50C0MVcw7YnTheAJXB1yyCWzD39Xk_rHr-ydJn1CIhTjTONdFr1pCG1d1DIBNt-PgIEmrFU20_CGdOVxu-j5cmOq1V1c1URCst2OQSqWeOUor3vjFcDsrcGpydGstpAXPCz8tWxnPikZDCdroj_RAHo71Sr7IkDL7UIxyKLmDm2tIiGZFy8UrCbJ2RYOiBqFfg
2020-07-31 12:26:04 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
2020-07-31 12:26:04 SUCCESS
VerifyIdTokenSubConsistentHybridFlow
authorization endpoint and token endpoint id_token have same sub
sub_auth_endpoint
1001
sub_token_endpoint
1001
2020-07-31 12:26:04 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
4WuYJxHrnRFNzxifNf5pVDDKqTRBpf5i--BlH1jwnpU
2020-07-31 12:26:04 SUCCESS
EnsureRefreshTokenContainsAllowedCharactersOnly
Refresh token does not contain any illegal characters
Refresh Token Request
2020-07-31 12:26:04 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
4WuYJxHrnRFNzxifNf5pVDDKqTRBpf5i--BlH1jwnpU
2020-07-31 12:26:04 SUCCESS
AddScopeToTokenEndpointRequest
Added scope of 'openid offline_access' to token endpoint request
grant_type
refresh_token
refresh_token
4WuYJxHrnRFNzxifNf5pVDDKqTRBpf5i--BlH1jwnpU
scope
openid offline_access
2020-07-31 12:26:04 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3
2020-07-31 12:26:04 SUCCESS
WaitForOneSecond
Pausing for 1 seconds
2020-07-31 12:26:05 SUCCESS
WaitForOneSecond
Woke up after 1 seconds sleep
2020-07-31 12:26:05
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=4WuYJxHrnRFNzxifNf5pVDDKqTRBpf5i--BlH1jwnpU&scope=openid+offline_access
2020-07-31 12:26:05 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:26: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": "860",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NSwiaWF0IjoxNTk2MTk4MzY1LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiIyeE04b0ZmQnZla0VLVFdpVGdwbktjRjFGM3drcDg4SU9EeS14aHc4MGRZIn0.BKhUYTnGUa6HZc9WUAmFSOtaZVxOgDKi64WhH3Vf-hpOQtbLXAfGO8OYbQLb0gdLUySgFL80L8wC6kiTvEw9oYdprt2xqpjz3geyLi8ffKxokTttX8vPWO3NMZxVb-LKwQ0et8bPXzHnmyF8UiDLMYbKsocd44ZAdyK_am1Unnq5v6Rmkt_w0nxHhdcCipQ7fpye2kwOOeV--ClSeoJJ5V9YA7W1jlC0PAnK9J70qZXnQRAGesLs-VJnzW-TqsmDyLFmdbA_LAAIznLKoCjiemCOga2k5dqxmDODIEa2dBWonZNGHRM8_EYqGl3qAXXIRDqsw0n-YWMcHZosP0DE1w","refresh_token":"Xjjs6VRXxu2pU7FnR5ooIFhuMJSIqiRZ9FhFMZvT218","scope":"openid offline_access","token_type":"Bearer","expires_in":86400}
2020-07-31 12:26:05 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NSwiaWF0IjoxNTk2MTk4MzY1LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiIyeE04b0ZmQnZla0VLVFdpVGdwbktjRjFGM3drcDg4SU9EeS14aHc4MGRZIn0.BKhUYTnGUa6HZc9WUAmFSOtaZVxOgDKi64WhH3Vf-hpOQtbLXAfGO8OYbQLb0gdLUySgFL80L8wC6kiTvEw9oYdprt2xqpjz3geyLi8ffKxokTttX8vPWO3NMZxVb-LKwQ0et8bPXzHnmyF8UiDLMYbKsocd44ZAdyK_am1Unnq5v6Rmkt_w0nxHhdcCipQ7fpye2kwOOeV--ClSeoJJ5V9YA7W1jlC0PAnK9J70qZXnQRAGesLs-VJnzW-TqsmDyLFmdbA_LAAIznLKoCjiemCOga2k5dqxmDODIEa2dBWonZNGHRM8_EYqGl3qAXXIRDqsw0n-YWMcHZosP0DE1w
refresh_token
Xjjs6VRXxu2pU7FnR5ooIFhuMJSIqiRZ9FhFMZvT218
scope
openid offline_access
token_type
Bearer
expires_in
86400
2020-07-31 12:26:05 SUCCESS
CheckTokenEndpointHttpStatus200
Token endpoint http status code was 200
2020-07-31 12:26:05 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2020-07-31 12:26:05 SUCCESS
CheckTokenEndpointCacheHeaders
Checked 'pragma' and 'cache-control' in the headers of token_endpoint_response.
2020-07-31 12:26:05 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:26:05 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NSwiaWF0IjoxNTk2MTk4MzY1LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiIyeE04b0ZmQnZla0VLVFdpVGdwbktjRjFGM3drcDg4SU9EeS14aHc4MGRZIn0.BKhUYTnGUa6HZc9WUAmFSOtaZVxOgDKi64WhH3Vf-hpOQtbLXAfGO8OYbQLb0gdLUySgFL80L8wC6kiTvEw9oYdprt2xqpjz3geyLi8ffKxokTttX8vPWO3NMZxVb-LKwQ0et8bPXzHnmyF8UiDLMYbKsocd44ZAdyK_am1Unnq5v6Rmkt_w0nxHhdcCipQ7fpye2kwOOeV--ClSeoJJ5V9YA7W1jlC0PAnK9J70qZXnQRAGesLs-VJnzW-TqsmDyLFmdbA_LAAIznLKoCjiemCOga2k5dqxmDODIEa2dBWonZNGHRM8_EYqGl3qAXXIRDqsw0n-YWMcHZosP0DE1w
type
Bearer
2020-07-31 12:26:05 SUCCESS
CheckTokenTypeIsBearer
Token type is bearer
2020-07-31 12:26:05 SUCCESS
EnsureMinimumAccessTokenEntropy
Calculated shannon entropy seems sufficient
actual
4143.024303640106
expected
96.0
2020-07-31 12:26:05 SUCCESS
EnsureAccessTokenContainsAllowedCharactersOnly
Access token does not contain any illegal characters
2020-07-31 12:26:05 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:26:05 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:26:05 SUCCESS
EnsureAccessTokenValuesAreDifferent
Access token values are not the same
first_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NCwiaWF0IjoxNTk2MTk4MzY0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJVTHBjaU81NTVXczlxRXQydUlxZ1h5VmNsc3JzVUZ3U0RuMEFsR1R1ZVY4In0.l-waKOB0GxT1TQaadZ8fpGNHZGD_hs3CZJ-NexOggF9vZwSD3PcErNmLM35-CXJgdHihiiqZ6QVH50gaA_nC_3cRDtzbc2mdnEtHVi1XzS8ZbSDJmMB4aMAv-vHPRER14iTelhUOiE5v7cT1WStpbgm1K_18CTkXnqpqkFKFVFVe_P57WJNmFYJQZodhw00wGar1_ZbCelMOdcBvY6MX1FxJBWt1VwZ6qfd81Rn20S2-qwVbyIemDQZubZm2Kx3QBJYIuhBGjlg7SEV_hSzwTLjKnJTOvSfGBIvV5MBEaTVaiEM4TTaEnst9jQblE5iZ7n02Kdw_v-JGUN6OF2cjuA
second_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NSwiaWF0IjoxNTk2MTk4MzY1LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiIyeE04b0ZmQnZla0VLVFdpVGdwbktjRjFGM3drcDg4SU9EeS14aHc4MGRZIn0.BKhUYTnGUa6HZc9WUAmFSOtaZVxOgDKi64WhH3Vf-hpOQtbLXAfGO8OYbQLb0gdLUySgFL80L8wC6kiTvEw9oYdprt2xqpjz3geyLi8ffKxokTttX8vPWO3NMZxVb-LKwQ0et8bPXzHnmyF8UiDLMYbKsocd44ZAdyK_am1Unnq5v6Rmkt_w0nxHhdcCipQ7fpye2kwOOeV--ClSeoJJ5V9YA7W1jlC0PAnK9J70qZXnQRAGesLs-VJnzW-TqsmDyLFmdbA_LAAIznLKoCjiemCOga2k5dqxmDODIEa2dBWonZNGHRM8_EYqGl3qAXXIRDqsw0n-YWMcHZosP0DE1w
2020-07-31 12:26:05 INFO
ExtractIdTokenFromTokenResponse
Couldn't find id_token in token_endpoint_response
2020-07-31 12:26:05 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
Xjjs6VRXxu2pU7FnR5ooIFhuMJSIqiRZ9FhFMZvT218
2020-07-31 12:26:05 SUCCESS
EnsureMinimumRefreshTokenLength
Refresh token is of sufficient length
actual
344
required
128
2020-07-31 12:26:05 SUCCESS
EnsureMinimumRefreshTokenEntropy
Calculated shannon entropy seems sufficient
actual
202.57449695002674
expected
96.0
2020-07-31 12:26:05 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:26:05
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.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NSwiaWF0IjoxNTk2MTk4MzY1LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiIyeE04b0ZmQnZla0VLVFdpVGdwbktjRjFGM3drcDg4SU9EeS14aHc4MGRZIn0.BKhUYTnGUa6HZc9WUAmFSOtaZVxOgDKi64WhH3Vf-hpOQtbLXAfGO8OYbQLb0gdLUySgFL80L8wC6kiTvEw9oYdprt2xqpjz3geyLi8ffKxokTttX8vPWO3NMZxVb-LKwQ0et8bPXzHnmyF8UiDLMYbKsocd44ZAdyK_am1Unnq5v6Rmkt_w0nxHhdcCipQ7fpye2kwOOeV--ClSeoJJ5V9YA7W1jlC0PAnK9J70qZXnQRAGesLs-VJnzW-TqsmDyLFmdbA_LAAIznLKoCjiemCOga2k5dqxmDODIEa2dBWonZNGHRM8_EYqGl3qAXXIRDqsw0n-YWMcHZosP0DE1w",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:26:05 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:26: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": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"sub":"1001"}
2020-07-31 12:26:05 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:26: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": "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:26:05 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:26:05
CreateRandomStateValue
Created state value
requested_state_length
10
state
Z5h9uqCJgr
2020-07-31 12:26:05 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
Z5h9uqCJgr
2020-07-31 12:26:05
CreateRandomNonceValue
Created nonce value
requested_nonce_length
10
nonce
uO2Hub0uQi
2020-07-31 12:26:05 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
Z5h9uqCJgr
nonce
uO2Hub0uQi
2020-07-31 12:26:05 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
Z5h9uqCJgr
nonce
uO2Hub0uQi
response_type
code id_token
2020-07-31 12:26:05
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
Z5h9uqCJgr
nonce
uO2Hub0uQi
response_type
code id_token
response_mode
form_post
2020-07-31 12:26:05 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
Z5h9uqCJgr
nonce
uO2Hub0uQi
response_type
code id_token
response_mode
form_post
prompt
consent
2020-07-31 12:26:05 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=Z5h9uqCJgr&nonce=uO2Hub0uQi&response_type=code%20id_token&response_mode=form_post&prompt=consent
2020-07-31 12:26:05 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=Z5h9uqCJgr&nonce=uO2Hub0uQi&response_type=code%20id_token&response_mode=form_post&prompt=consent
2020-07-31 12:26:05
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=Z5h9uqCJgr&nonce=uO2Hub0uQi&response_type=code%20id_token&response_mode=form_post&prompt=consent
2020-07-31 12:26:06 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:26:06 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=Z5h9uqCJgr&nonce=uO2Hub0uQi&response_type=code%20id_token&response_mode=form_post&prompt=consent
target
loginId
2020-07-31 12:26:06 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=Z5h9uqCJgr&nonce=uO2Hub0uQi&response_type=code%20id_token&response_mode=form_post&prompt=consent
target
loginId
2020-07-31 12:26:06 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=Z5h9uqCJgr&nonce=uO2Hub0uQi&response_type=code%20id_token&response_mode=form_post&prompt=consent
target
password
2020-07-31 12:26:06 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=Z5h9uqCJgr&nonce=uO2Hub0uQi&response_type=code%20id_token&response_mode=form_post&prompt=consent
target
password
2020-07-31 12:26:06 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=Z5h9uqCJgr&nonce=uO2Hub0uQi&response_type=code%20id_token&response_mode=form_post&prompt=consent
target
authorized
2020-07-31 12:26:06 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance xv94uIvx4TRw9O8
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\u003dB9172D272A0003B54A0E25E7EF5445C6",
  "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": "793",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
callback
incoming_body_form_params
{
  "state": "Z5h9uqCJgr",
  "code": "SsVkhly9uTrLpQnpwsXexPVpx9kdUkYg67nsNyp936o",
  "id_token": "eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJjX2hhc2giOiJKWmxGY0Z1X2ZraXJHVm9id09GemxBIiwic19oYXNoIjoiUFczaEctRU5zcHdvVGJXZGhzQVRpZyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjYsImlhdCI6MTU5NjE5ODM2Niwibm9uY2UiOiJ1TzJIdWIwdVFpIn0.R_SqkiR3wEG-BW2WoRAZ36W9Gd1Skcj4n1_QyphSXkt31blsffxJgmBY9Zpvsgo8Jrj7Al8DVRIblGzWrb1E0NKKphHFo465m8_c0TEbkarzf6CKf4ysC8Lm5OiSOP7AvFZyrgm18DXSPe8r61TjbxXCv_Qt4ZU9sxXeG5kuzhuuwE8Zu2B-Cr3p19BPIQ75PXoH47OLn7PjZ2Qk7Jn-QkfmugEAvUg-sDppCXi1VaP1XIYhNFGme3eLUBUwFimGCQBIMzJZBuHpoxwv7FYCnt1uH2D5rwNfoXJfEWMZsrzs6IHkAM8u6pt9MK5gGyWZzZwsDqIJ5Fwn0ZLyrmOERg"
}
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
state=Z5h9uqCJgr&code=SsVkhly9uTrLpQnpwsXexPVpx9kdUkYg67nsNyp936o&id_token=eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJjX2hhc2giOiJKWmxGY0Z1X2ZraXJHVm9id09GemxBIiwic19oYXNoIjoiUFczaEctRU5zcHdvVGJXZGhzQVRpZyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjYsImlhdCI6MTU5NjE5ODM2Niwibm9uY2UiOiJ1TzJIdWIwdVFpIn0.R_SqkiR3wEG-BW2WoRAZ36W9Gd1Skcj4n1_QyphSXkt31blsffxJgmBY9Zpvsgo8Jrj7Al8DVRIblGzWrb1E0NKKphHFo465m8_c0TEbkarzf6CKf4ysC8Lm5OiSOP7AvFZyrgm18DXSPe8r61TjbxXCv_Qt4ZU9sxXeG5kuzhuuwE8Zu2B-Cr3p19BPIQ75PXoH47OLn7PjZ2Qk7Jn-QkfmugEAvUg-sDppCXi1VaP1XIYhNFGme3eLUBUwFimGCQBIMzJZBuHpoxwv7FYCnt1uH2D5rwNfoXJfEWMZsrzs6IHkAM8u6pt9MK5gGyWZzZwsDqIJ5Fwn0ZLyrmOERg
2020-07-31 12:26:06 SUCCESS
CreateRandomImplicitSubmitUrl
Created random implicit submission URL
implicit_submit
{
  "path": "implicit/RieOGiW0Wl2Zm31zktuc",
  "fullUrl": "https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/RieOGiW0Wl2Zm31zktuc"
}
2020-07-31 12:26:06 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance xv94uIvx4TRw9O8
outgoing
ModelAndView [view="implicitCallback"; model={implicitSubmitUrl=https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/RieOGiW0Wl2Zm31zktuc, returnUrl=/log-detail.html?log=xv94uIvx4TRw9O8}]
outgoing_path
callback
2020-07-31 12:26:06 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:26:06 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:26:06 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance xv94uIvx4TRw9O8
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\u003dB9172D272A0003B54A0E25E7EF5445C6",
  "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/RieOGiW0Wl2Zm31zktuc
incoming_body_form_params
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
2020-07-31 12:26:06 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance xv94uIvx4TRw9O8
outgoing
org.springframework.web.servlet.view.RedirectView: [RedirectView]; URL [/log-detail.html?log=xv94uIvx4TRw9O8]
outgoing_path
implicit/RieOGiW0Wl2Zm31zktuc
2020-07-31 12:26:06 SUCCESS
ExtractImplicitHashToCallbackResponse
implicit_hash is empty
2020-07-31 12:26:06 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\u003dB9172D272A0003B54A0E25E7EF5445C6",
  "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": "793",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
http_method
POST
url_fragment
{}
post_body
{
  "state": "Z5h9uqCJgr",
  "code": "SsVkhly9uTrLpQnpwsXexPVpx9kdUkYg67nsNyp936o",
  "id_token": "eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJjX2hhc2giOiJKWmxGY0Z1X2ZraXJHVm9id09GemxBIiwic19oYXNoIjoiUFczaEctRU5zcHdvVGJXZGhzQVRpZyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjYsImlhdCI6MTU5NjE5ODM2Niwibm9uY2UiOiJ1TzJIdWIwdVFpIn0.R_SqkiR3wEG-BW2WoRAZ36W9Gd1Skcj4n1_QyphSXkt31blsffxJgmBY9Zpvsgo8Jrj7Al8DVRIblGzWrb1E0NKKphHFo465m8_c0TEbkarzf6CKf4ysC8Lm5OiSOP7AvFZyrgm18DXSPe8r61TjbxXCv_Qt4ZU9sxXeG5kuzhuuwE8Zu2B-Cr3p19BPIQ75PXoH47OLn7PjZ2Qk7Jn-QkfmugEAvUg-sDppCXi1VaP1XIYhNFGme3eLUBUwFimGCQBIMzJZBuHpoxwv7FYCnt1uH2D5rwNfoXJfEWMZsrzs6IHkAM8u6pt9MK5gGyWZzZwsDqIJ5Fwn0ZLyrmOERg"
}
Second client: Verify authorization endpoint response
2020-07-31 12:26:06 SUCCESS
CheckCallbackHttpMethodIsPost
HTTP method used at redirect_uri is 'POST'
2020-07-31 12:26:06 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:26:06 SUCCESS
RejectAuthCodeInUrlQuery
Authorization code is not present in URL query returned from authorization endpoint
2020-07-31 12:26:06 SUCCESS
RejectErrorInUrlQuery
'error' is not present in URL query returned from authorization endpoint
2020-07-31 12:26:06 SUCCESS
CheckMatchingCallbackParameters
Callback parameters successfully verified
2020-07-31 12:26:06 SUCCESS
CheckIfAuthorizationEndpointError
No error from authorization endpoint
2020-07-31 12:26:06 SUCCESS
CheckMatchingStateParameter
State parameter correctly returned
state
Z5h9uqCJgr
2020-07-31 12:26:06 SUCCESS
ExtractAuthorizationCodeFromAuthorizationResponse
Found authorization code
code
SsVkhly9uTrLpQnpwsXexPVpx9kdUkYg67nsNyp936o
2020-07-31 12:26:06 SUCCESS
ExtractIdTokenFromAuthorizationResponse
Found and parsed the id_token from authorization_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJjX2hhc2giOiJKWmxGY0Z1X2ZraXJHVm9id09GemxBIiwic19oYXNoIjoiUFczaEctRU5zcHdvVGJXZGhzQVRpZyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjYsImlhdCI6MTU5NjE5ODM2Niwibm9uY2UiOiJ1TzJIdWIwdVFpIn0.R_SqkiR3wEG-BW2WoRAZ36W9Gd1Skcj4n1_QyphSXkt31blsffxJgmBY9Zpvsgo8Jrj7Al8DVRIblGzWrb1E0NKKphHFo465m8_c0TEbkarzf6CKf4ysC8Lm5OiSOP7AvFZyrgm18DXSPe8r61TjbxXCv_Qt4ZU9sxXeG5kuzhuuwE8Zu2B-Cr3p19BPIQ75PXoH47OLn7PjZ2Qk7Jn-QkfmugEAvUg-sDppCXi1VaP1XIYhNFGme3eLUBUwFimGCQBIMzJZBuHpoxwv7FYCnt1uH2D5rwNfoXJfEWMZsrzs6IHkAM8u6pt9MK5gGyWZzZwsDqIJ5Fwn0ZLyrmOERg
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "sub": "1001",
  "aud": "470553331604632",
  "c_hash": "JZlFcFu_fkirGVobwOFzlA",
  "s_hash": "PW3hG-ENspwoTbWdhsATig",
  "auth_time": 1596198363,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198666,
  "iat": 1596198366,
  "nonce": "uO2Hub0uQi"
}
2020-07-31 12:26:06 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:26:06 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
uO2Hub0uQi
2020-07-31 12:26:06 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:26:06 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJjX2hhc2giOiJKWmxGY0Z1X2ZraXJHVm9id09GemxBIiwic19oYXNoIjoiUFczaEctRU5zcHdvVGJXZGhzQVRpZyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjYsImlhdCI6MTU5NjE5ODM2Niwibm9uY2UiOiJ1TzJIdWIwdVFpIn0.R_SqkiR3wEG-BW2WoRAZ36W9Gd1Skcj4n1_QyphSXkt31blsffxJgmBY9Zpvsgo8Jrj7Al8DVRIblGzWrb1E0NKKphHFo465m8_c0TEbkarzf6CKf4ysC8Lm5OiSOP7AvFZyrgm18DXSPe8r61TjbxXCv_Qt4ZU9sxXeG5kuzhuuwE8Zu2B-Cr3p19BPIQ75PXoH47OLn7PjZ2Qk7Jn-QkfmugEAvUg-sDppCXi1VaP1XIYhNFGme3eLUBUwFimGCQBIMzJZBuHpoxwv7FYCnt1uH2D5rwNfoXJfEWMZsrzs6IHkAM8u6pt9MK5gGyWZzZwsDqIJ5Fwn0ZLyrmOERg
2020-07-31 12:26:06 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJjX2hhc2giOiJKWmxGY0Z1X2ZraXJHVm9id09GemxBIiwic19oYXNoIjoiUFczaEctRU5zcHdvVGJXZGhzQVRpZyIsImF1dGhfdGltZSI6MTU5NjE5ODM2MywiaXNzIjoiaHR0cHM6Ly9mYXBpZGV2LWFzLmF1dGhsZXRlLm5ldC8iLCJleHAiOjE1OTYxOTg2NjYsImlhdCI6MTU5NjE5ODM2Niwibm9uY2UiOiJ1TzJIdWIwdVFpIn0.R_SqkiR3wEG-BW2WoRAZ36W9Gd1Skcj4n1_QyphSXkt31blsffxJgmBY9Zpvsgo8Jrj7Al8DVRIblGzWrb1E0NKKphHFo465m8_c0TEbkarzf6CKf4ysC8Lm5OiSOP7AvFZyrgm18DXSPe8r61TjbxXCv_Qt4ZU9sxXeG5kuzhuuwE8Zu2B-Cr3p19BPIQ75PXoH47OLn7PjZ2Qk7Jn-QkfmugEAvUg-sDppCXi1VaP1XIYhNFGme3eLUBUwFimGCQBIMzJZBuHpoxwv7FYCnt1uH2D5rwNfoXJfEWMZsrzs6IHkAM8u6pt9MK5gGyWZzZwsDqIJ5Fwn0ZLyrmOERg
2020-07-31 12:26:06 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
2020-07-31 12:26:06 SUCCESS
CreateTokenEndpointRequestForAuthorizationCodeGrant
grant_type
authorization_code
code
SsVkhly9uTrLpQnpwsXexPVpx9kdUkYg67nsNyp936o
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
2020-07-31 12:26:06 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB
2020-07-31 12:26:06
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=SsVkhly9uTrLpQnpwsXexPVpx9kdUkYg67nsNyp936o&redirect_uri=https%3A%2F%2Fwww.certification.openid.net%2Ftest%2Fa%2Foidf-authlete-core%2Fcallback
2020-07-31 12:26:06 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:26:07 RESPONSE
CallTokenEndpoint
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:26: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": "1547",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NywiaWF0IjoxNTk2MTk4MzY3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ0QzRWeXZCRXRjbFo5ejhhZC10c1lmWTNSZFAtTjBFWDBvRHUtWXBoUjFvIn0.bt_jZRuA-GDntthZftSSj6teXN0tWtxzYXzPD2L-mYXsnXSrnkIKYzuJuqw5KEa6c-i6dkLFEigVx6Z_tkak66FKDxmoasLWJ8hg9qk9rqXyux5hMZG5_jLKcCDQ-b8_Z3qCxW_WLV6Cye5Ro6BrTvKgsQ0aZ5LPnEjJrHbubLegQFO5GwYZdJxqZNVhqex7UlT3qvIbILHP_lC-CR3KSA6lo8nOGcbDjbTbX27YPdI4ptyShVFEMjhQJwfAGRCIN-GBhjpDXDUbNcPgyxkGafcVT4RW-NwVd0TUtsbtH6QRdYvXyEyNLbhj5p0Bproc4H01LULKH2FpoIg6S2k8HQ","refresh_token":"2kq6ojozbE-IVDOBdGk4Uvpwa8r7_vzdMHN_HDpx_hQ","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJQVzNoRy1FTnNwd29UYldkaHNBVGlnIiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NywiaWF0IjoxNTk2MTk4MzY3LCJub25jZSI6InVPMkh1YjB1UWkifQ.b6cZufPt_6f8FNlItdRw2uLYCdYVOspCYvTtVDxtthiAjrfNL3rtN2OzOcpgfxAylhshkXQdlwLIEKY5UjNbf7eS6H960eFQtlkbDxduYwrIWe7cSD9QbFV_yKjvISA8edmaGIfaCF2mwUL7mCk_DTXawE96_95BD9XO_nqFjcrz__gL9MgkXugV7XJzFiW3xaUEa4nqyBQ7DXG9PFTp-pD0fPejBo1um7oqncEBjE7K6PCKhjsW4IQ-5a3AsLu84qXokeej-g1Fxss62isuSUgKw38N5tUdpwIp_ByPdfzuk1ftEGQjrBokJrLtyoEHdyLbMF6-JwnlZ62AEDv3DA","token_type":"Bearer","expires_in":86400}
2020-07-31 12:26:07
CallTokenEndpoint
Token endpoint response
token_endpoint_response
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NywiaWF0IjoxNTk2MTk4MzY3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ0QzRWeXZCRXRjbFo5ejhhZC10c1lmWTNSZFAtTjBFWDBvRHUtWXBoUjFvIn0.bt_jZRuA-GDntthZftSSj6teXN0tWtxzYXzPD2L-mYXsnXSrnkIKYzuJuqw5KEa6c-i6dkLFEigVx6Z_tkak66FKDxmoasLWJ8hg9qk9rqXyux5hMZG5_jLKcCDQ-b8_Z3qCxW_WLV6Cye5Ro6BrTvKgsQ0aZ5LPnEjJrHbubLegQFO5GwYZdJxqZNVhqex7UlT3qvIbILHP_lC-CR3KSA6lo8nOGcbDjbTbX27YPdI4ptyShVFEMjhQJwfAGRCIN-GBhjpDXDUbNcPgyxkGafcVT4RW-NwVd0TUtsbtH6QRdYvXyEyNLbhj5p0Bproc4H01LULKH2FpoIg6S2k8HQ","refresh_token":"2kq6ojozbE-IVDOBdGk4Uvpwa8r7_vzdMHN_HDpx_hQ","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJQVzNoRy1FTnNwd29UYldkaHNBVGlnIiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NywiaWF0IjoxNTk2MTk4MzY3LCJub25jZSI6InVPMkh1YjB1UWkifQ.b6cZufPt_6f8FNlItdRw2uLYCdYVOspCYvTtVDxtthiAjrfNL3rtN2OzOcpgfxAylhshkXQdlwLIEKY5UjNbf7eS6H960eFQtlkbDxduYwrIWe7cSD9QbFV_yKjvISA8edmaGIfaCF2mwUL7mCk_DTXawE96_95BD9XO_nqFjcrz__gL9MgkXugV7XJzFiW3xaUEa4nqyBQ7DXG9PFTp-pD0fPejBo1um7oqncEBjE7K6PCKhjsW4IQ-5a3AsLu84qXokeej-g1Fxss62isuSUgKw38N5tUdpwIp_ByPdfzuk1ftEGQjrBokJrLtyoEHdyLbMF6-JwnlZ62AEDv3DA","token_type":"Bearer","expires_in":86400}
2020-07-31 12:26:07 SUCCESS
CallTokenEndpoint
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NywiaWF0IjoxNTk2MTk4MzY3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ0QzRWeXZCRXRjbFo5ejhhZC10c1lmWTNSZFAtTjBFWDBvRHUtWXBoUjFvIn0.bt_jZRuA-GDntthZftSSj6teXN0tWtxzYXzPD2L-mYXsnXSrnkIKYzuJuqw5KEa6c-i6dkLFEigVx6Z_tkak66FKDxmoasLWJ8hg9qk9rqXyux5hMZG5_jLKcCDQ-b8_Z3qCxW_WLV6Cye5Ro6BrTvKgsQ0aZ5LPnEjJrHbubLegQFO5GwYZdJxqZNVhqex7UlT3qvIbILHP_lC-CR3KSA6lo8nOGcbDjbTbX27YPdI4ptyShVFEMjhQJwfAGRCIN-GBhjpDXDUbNcPgyxkGafcVT4RW-NwVd0TUtsbtH6QRdYvXyEyNLbhj5p0Bproc4H01LULKH2FpoIg6S2k8HQ
refresh_token
2kq6ojozbE-IVDOBdGk4Uvpwa8r7_vzdMHN_HDpx_hQ
scope
offline_access openid
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJQVzNoRy1FTnNwd29UYldkaHNBVGlnIiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NywiaWF0IjoxNTk2MTk4MzY3LCJub25jZSI6InVPMkh1YjB1UWkifQ.b6cZufPt_6f8FNlItdRw2uLYCdYVOspCYvTtVDxtthiAjrfNL3rtN2OzOcpgfxAylhshkXQdlwLIEKY5UjNbf7eS6H960eFQtlkbDxduYwrIWe7cSD9QbFV_yKjvISA8edmaGIfaCF2mwUL7mCk_DTXawE96_95BD9XO_nqFjcrz__gL9MgkXugV7XJzFiW3xaUEa4nqyBQ7DXG9PFTp-pD0fPejBo1um7oqncEBjE7K6PCKhjsW4IQ-5a3AsLu84qXokeej-g1Fxss62isuSUgKw38N5tUdpwIp_ByPdfzuk1ftEGQjrBokJrLtyoEHdyLbMF6-JwnlZ62AEDv3DA
token_type
Bearer
expires_in
86400
2020-07-31 12:26:07 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:26:07 SUCCESS
CheckForAccessTokenValue
Found an access token
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NywiaWF0IjoxNTk2MTk4MzY3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ0QzRWeXZCRXRjbFo5ejhhZC10c1lmWTNSZFAtTjBFWDBvRHUtWXBoUjFvIn0.bt_jZRuA-GDntthZftSSj6teXN0tWtxzYXzPD2L-mYXsnXSrnkIKYzuJuqw5KEa6c-i6dkLFEigVx6Z_tkak66FKDxmoasLWJ8hg9qk9rqXyux5hMZG5_jLKcCDQ-b8_Z3qCxW_WLV6Cye5Ro6BrTvKgsQ0aZ5LPnEjJrHbubLegQFO5GwYZdJxqZNVhqex7UlT3qvIbILHP_lC-CR3KSA6lo8nOGcbDjbTbX27YPdI4ptyShVFEMjhQJwfAGRCIN-GBhjpDXDUbNcPgyxkGafcVT4RW-NwVd0TUtsbtH6QRdYvXyEyNLbhj5p0Bproc4H01LULKH2FpoIg6S2k8HQ
2020-07-31 12:26:07 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NywiaWF0IjoxNTk2MTk4MzY3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ0QzRWeXZCRXRjbFo5ejhhZC10c1lmWTNSZFAtTjBFWDBvRHUtWXBoUjFvIn0.bt_jZRuA-GDntthZftSSj6teXN0tWtxzYXzPD2L-mYXsnXSrnkIKYzuJuqw5KEa6c-i6dkLFEigVx6Z_tkak66FKDxmoasLWJ8hg9qk9rqXyux5hMZG5_jLKcCDQ-b8_Z3qCxW_WLV6Cye5Ro6BrTvKgsQ0aZ5LPnEjJrHbubLegQFO5GwYZdJxqZNVhqex7UlT3qvIbILHP_lC-CR3KSA6lo8nOGcbDjbTbX27YPdI4ptyShVFEMjhQJwfAGRCIN-GBhjpDXDUbNcPgyxkGafcVT4RW-NwVd0TUtsbtH6QRdYvXyEyNLbhj5p0Bproc4H01LULKH2FpoIg6S2k8HQ
type
Bearer
2020-07-31 12:26:07 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:26:07 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:26:07 SUCCESS
CheckForRefreshTokenValue
Found a refresh token
refresh_token
2kq6ojozbE-IVDOBdGk4Uvpwa8r7_vzdMHN_HDpx_hQ
2020-07-31 12:26:07 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJQVzNoRy1FTnNwd29UYldkaHNBVGlnIiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NywiaWF0IjoxNTk2MTk4MzY3LCJub25jZSI6InVPMkh1YjB1UWkifQ.b6cZufPt_6f8FNlItdRw2uLYCdYVOspCYvTtVDxtthiAjrfNL3rtN2OzOcpgfxAylhshkXQdlwLIEKY5UjNbf7eS6H960eFQtlkbDxduYwrIWe7cSD9QbFV_yKjvISA8edmaGIfaCF2mwUL7mCk_DTXawE96_95BD9XO_nqFjcrz__gL9MgkXugV7XJzFiW3xaUEa4nqyBQ7DXG9PFTp-pD0fPejBo1um7oqncEBjE7K6PCKhjsW4IQ-5a3AsLu84qXokeej-g1Fxss62isuSUgKw38N5tUdpwIp_ByPdfzuk1ftEGQjrBokJrLtyoEHdyLbMF6-JwnlZ62AEDv3DA
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "sub": "1001",
  "aud": "470553331604632",
  "s_hash": "PW3hG-ENspwoTbWdhsATig",
  "auth_time": 1596198363,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198667,
  "iat": 1596198367,
  "nonce": "uO2Hub0uQi"
}
2020-07-31 12:26:07 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:26:07 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
uO2Hub0uQi
2020-07-31 12:26:07 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:26:07 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJQVzNoRy1FTnNwd29UYldkaHNBVGlnIiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NywiaWF0IjoxNTk2MTk4MzY3LCJub25jZSI6InVPMkh1YjB1UWkifQ.b6cZufPt_6f8FNlItdRw2uLYCdYVOspCYvTtVDxtthiAjrfNL3rtN2OzOcpgfxAylhshkXQdlwLIEKY5UjNbf7eS6H960eFQtlkbDxduYwrIWe7cSD9QbFV_yKjvISA8edmaGIfaCF2mwUL7mCk_DTXawE96_95BD9XO_nqFjcrz__gL9MgkXugV7XJzFiW3xaUEa4nqyBQ7DXG9PFTp-pD0fPejBo1um7oqncEBjE7K6PCKhjsW4IQ-5a3AsLu84qXokeej-g1Fxss62isuSUgKw38N5tUdpwIp_ByPdfzuk1ftEGQjrBokJrLtyoEHdyLbMF6-JwnlZ62AEDv3DA
2020-07-31 12:26:07 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJQVzNoRy1FTnNwd29UYldkaHNBVGlnIiwiYXV0aF90aW1lIjoxNTk2MTk4MzYzLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODY2NywiaWF0IjoxNTk2MTk4MzY3LCJub25jZSI6InVPMkh1YjB1UWkifQ.b6cZufPt_6f8FNlItdRw2uLYCdYVOspCYvTtVDxtthiAjrfNL3rtN2OzOcpgfxAylhshkXQdlwLIEKY5UjNbf7eS6H960eFQtlkbDxduYwrIWe7cSD9QbFV_yKjvISA8edmaGIfaCF2mwUL7mCk_DTXawE96_95BD9XO_nqFjcrz__gL9MgkXugV7XJzFiW3xaUEa4nqyBQ7DXG9PFTp-pD0fPejBo1um7oqncEBjE7K6PCKhjsW4IQ-5a3AsLu84qXokeej-g1Fxss62isuSUgKw38N5tUdpwIp_ByPdfzuk1ftEGQjrBokJrLtyoEHdyLbMF6-JwnlZ62AEDv3DA
2020-07-31 12:26:07 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
2020-07-31 12:26:07 SUCCESS
VerifyIdTokenSubConsistentHybridFlow
authorization endpoint and token endpoint id_token have same sub
sub_auth_endpoint
1001
sub_token_endpoint
1001
2020-07-31 12:26:07 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
2kq6ojozbE-IVDOBdGk4Uvpwa8r7_vzdMHN_HDpx_hQ
2020-07-31 12:26:07 SUCCESS
EnsureRefreshTokenContainsAllowedCharactersOnly
Refresh token does not contain any illegal characters
Second client: Refresh Token Request
2020-07-31 12:26:07 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
2kq6ojozbE-IVDOBdGk4Uvpwa8r7_vzdMHN_HDpx_hQ
2020-07-31 12:26:07 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB
2020-07-31 12:26:07 SUCCESS
WaitForOneSecond
Pausing for 1 seconds
2020-07-31 12:26:08 SUCCESS
WaitForOneSecond
Woke up after 1 seconds sleep
2020-07-31 12:26:08
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=2kq6ojozbE-IVDOBdGk4Uvpwa8r7_vzdMHN_HDpx_hQ
2020-07-31 12:26:08 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:26:08 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.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2OCwiaWF0IjoxNTk2MTk4MzY4LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJxcjBiaUFqX1Bka0lHck1pRFBLRWltczNYelBuZHAzUUpzWXJUNEVXVUEwIn0.fjYSqLEGbGNJANW8AAcntHDPOLx4DX3th5CXZVXS8eLftjNYcyrd762zdHP-142Qwk-AtPAYvkmzyWiHXN0Py0Nha55FxoG2G8WWnR4kIbKfYWrYCubFzy08DClRD9abnmYk58QjYXBp3cJg9AslcqJATdCLZtdAoOzwRLBCcCZ-V5lPevZC0iVvu9yYaMotNYIl4qbxoDkbEGH5Teklo9KleuWSzebI-bqnrmZEFT63pQUxWbIFlY8BPiyea4ZWLj62y4vAsUMSafA5AWe-x7g6vNAenN-cCx8IzIGK4g9_6dWNx7paeCcTAiDdFX1JpwlyZH38Xk2AxoBgcg-N6A","refresh_token":"6uv-VyfzwKcHnUjapXb7-XiqRrYD5ZvEieXf5B-MY5c","scope":"openid offline_access","token_type":"Bearer","expires_in":86400}
2020-07-31 12:26:08 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2OCwiaWF0IjoxNTk2MTk4MzY4LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJxcjBiaUFqX1Bka0lHck1pRFBLRWltczNYelBuZHAzUUpzWXJUNEVXVUEwIn0.fjYSqLEGbGNJANW8AAcntHDPOLx4DX3th5CXZVXS8eLftjNYcyrd762zdHP-142Qwk-AtPAYvkmzyWiHXN0Py0Nha55FxoG2G8WWnR4kIbKfYWrYCubFzy08DClRD9abnmYk58QjYXBp3cJg9AslcqJATdCLZtdAoOzwRLBCcCZ-V5lPevZC0iVvu9yYaMotNYIl4qbxoDkbEGH5Teklo9KleuWSzebI-bqnrmZEFT63pQUxWbIFlY8BPiyea4ZWLj62y4vAsUMSafA5AWe-x7g6vNAenN-cCx8IzIGK4g9_6dWNx7paeCcTAiDdFX1JpwlyZH38Xk2AxoBgcg-N6A
refresh_token
6uv-VyfzwKcHnUjapXb7-XiqRrYD5ZvEieXf5B-MY5c
scope
openid offline_access
token_type
Bearer
expires_in
86400
2020-07-31 12:26:08 SUCCESS
CheckTokenEndpointHttpStatus200
Token endpoint http status code was 200
2020-07-31 12:26:08 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2020-07-31 12:26:08 SUCCESS
CheckTokenEndpointCacheHeaders
Checked 'pragma' and 'cache-control' in the headers of token_endpoint_response.
2020-07-31 12:26:08 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:26:08 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2OCwiaWF0IjoxNTk2MTk4MzY4LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJxcjBiaUFqX1Bka0lHck1pRFBLRWltczNYelBuZHAzUUpzWXJUNEVXVUEwIn0.fjYSqLEGbGNJANW8AAcntHDPOLx4DX3th5CXZVXS8eLftjNYcyrd762zdHP-142Qwk-AtPAYvkmzyWiHXN0Py0Nha55FxoG2G8WWnR4kIbKfYWrYCubFzy08DClRD9abnmYk58QjYXBp3cJg9AslcqJATdCLZtdAoOzwRLBCcCZ-V5lPevZC0iVvu9yYaMotNYIl4qbxoDkbEGH5Teklo9KleuWSzebI-bqnrmZEFT63pQUxWbIFlY8BPiyea4ZWLj62y4vAsUMSafA5AWe-x7g6vNAenN-cCx8IzIGK4g9_6dWNx7paeCcTAiDdFX1JpwlyZH38Xk2AxoBgcg-N6A
type
Bearer
2020-07-31 12:26:08 SUCCESS
CheckTokenTypeIsBearer
Token type is bearer
2020-07-31 12:26:08 SUCCESS
EnsureMinimumAccessTokenEntropy
Calculated shannon entropy seems sufficient
actual
4127.917998253452
expected
96.0
2020-07-31 12:26:08 SUCCESS
EnsureAccessTokenContainsAllowedCharactersOnly
Access token does not contain any illegal characters
2020-07-31 12:26:08 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:26:08 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:26:08 SUCCESS
EnsureAccessTokenValuesAreDifferent
Access token values are not the same
first_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2NywiaWF0IjoxNTk2MTk4MzY3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ0QzRWeXZCRXRjbFo5ejhhZC10c1lmWTNSZFAtTjBFWDBvRHUtWXBoUjFvIn0.bt_jZRuA-GDntthZftSSj6teXN0tWtxzYXzPD2L-mYXsnXSrnkIKYzuJuqw5KEa6c-i6dkLFEigVx6Z_tkak66FKDxmoasLWJ8hg9qk9rqXyux5hMZG5_jLKcCDQ-b8_Z3qCxW_WLV6Cye5Ro6BrTvKgsQ0aZ5LPnEjJrHbubLegQFO5GwYZdJxqZNVhqex7UlT3qvIbILHP_lC-CR3KSA6lo8nOGcbDjbTbX27YPdI4ptyShVFEMjhQJwfAGRCIN-GBhjpDXDUbNcPgyxkGafcVT4RW-NwVd0TUtsbtH6QRdYvXyEyNLbhj5p0Bproc4H01LULKH2FpoIg6S2k8HQ
second_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2OCwiaWF0IjoxNTk2MTk4MzY4LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJxcjBiaUFqX1Bka0lHck1pRFBLRWltczNYelBuZHAzUUpzWXJUNEVXVUEwIn0.fjYSqLEGbGNJANW8AAcntHDPOLx4DX3th5CXZVXS8eLftjNYcyrd762zdHP-142Qwk-AtPAYvkmzyWiHXN0Py0Nha55FxoG2G8WWnR4kIbKfYWrYCubFzy08DClRD9abnmYk58QjYXBp3cJg9AslcqJATdCLZtdAoOzwRLBCcCZ-V5lPevZC0iVvu9yYaMotNYIl4qbxoDkbEGH5Teklo9KleuWSzebI-bqnrmZEFT63pQUxWbIFlY8BPiyea4ZWLj62y4vAsUMSafA5AWe-x7g6vNAenN-cCx8IzIGK4g9_6dWNx7paeCcTAiDdFX1JpwlyZH38Xk2AxoBgcg-N6A
2020-07-31 12:26:08 INFO
ExtractIdTokenFromTokenResponse
Couldn't find id_token in token_endpoint_response
2020-07-31 12:26:08 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
6uv-VyfzwKcHnUjapXb7-XiqRrYD5ZvEieXf5B-MY5c
2020-07-31 12:26:08 SUCCESS
EnsureMinimumRefreshTokenLength
Refresh token is of sufficient length
actual
344
required
128
2020-07-31 12:26:08 SUCCESS
EnsureMinimumRefreshTokenEntropy
Calculated shannon entropy seems sufficient
actual
209.06472194569977
expected
96.0
2020-07-31 12:26:08 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:26:08
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.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDc2OCwiaWF0IjoxNTk2MTk4MzY4LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJxcjBiaUFqX1Bka0lHck1pRFBLRWltczNYelBuZHAzUUpzWXJUNEVXVUEwIn0.fjYSqLEGbGNJANW8AAcntHDPOLx4DX3th5CXZVXS8eLftjNYcyrd762zdHP-142Qwk-AtPAYvkmzyWiHXN0Py0Nha55FxoG2G8WWnR4kIbKfYWrYCubFzy08DClRD9abnmYk58QjYXBp3cJg9AslcqJATdCLZtdAoOzwRLBCcCZ-V5lPevZC0iVvu9yYaMotNYIl4qbxoDkbEGH5Teklo9KleuWSzebI-bqnrmZEFT63pQUxWbIFlY8BPiyea4ZWLj62y4vAsUMSafA5AWe-x7g6vNAenN-cCx8IzIGK4g9_6dWNx7paeCcTAiDdFX1JpwlyZH38Xk2AxoBgcg-N6A",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:26:08 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:26:08 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:26:08 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:26:08 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:26:08 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
6uv-VyfzwKcHnUjapXb7-XiqRrYD5ZvEieXf5B-MY5c
2020-07-31 12:26:08 SUCCESS
AddScopeToTokenEndpointRequest
Added scope of 'openid offline_access' to token endpoint request
grant_type
refresh_token
refresh_token
6uv-VyfzwKcHnUjapXb7-XiqRrYD5ZvEieXf5B-MY5c
scope
openid offline_access
2020-07-31 12:26:08 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3
2020-07-31 12:26:08
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=6uv-VyfzwKcHnUjapXb7-XiqRrYD5ZvEieXf5B-MY5c&scope=openid+offline_access
2020-07-31 12:26:09 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
400 BAD_REQUEST
response_status_text
Bad Request
response_headers
{
  "date": "Fri, 31 Jul 2020 12:26:09 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:26:09 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:26:09 SUCCESS
ValidateErrorFromTokenEndpointResponseError
Token endpoint response error returned valid 'error' field
error
invalid_grant
2020-07-31 12:26:09 SUCCESS
CheckTokenEndpointHttpStatus400
Token endpoint http status code was 400
2020-07-31 12:26:09 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2020-07-31 12:26:09 SUCCESS
CheckErrorFromTokenEndpointResponseErrorInvalidGrant
Token Endpoint response error returned expected 'error' of 'invalid_grant'
error
invalid_grant
2020-07-31 12:26:09 FINISHED
oidcc-refresh-token
Test has run to completion
testmodule_result
PASSED
Unregister dynamically registered client
2020-07-31 12:26:09 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:26:09 INFO
UnregisterDynamicallyRegisteredClient
Skipped evaluation due to missing required string: registration_client_uri
expected
registration_client_uri
2020-07-31 12:26:09
TEST-RUNNER
Alias has now been claimed by another test
alias
oidf-authlete-core
new_test_id
n1TjoWD7EF2XKlh
Test Results