< Return to Summary | File Generated: Wed Feb 28 2024 15:28:01 GMT+0000 (Coordinated Universal Time)

booking-partner-authentication >> authorization-code-flow

Booking Flow:

Opportunity Type:

Feature: Authentication / Booking Partner Authentication for Multiple Seller Systems (Implemented)

Test: Authorization Code Flow

The Authorization Code Flow allows Sellers to authenticate with Booking Partners

Running only this test

npm start -- --runInBand test/features/authentication/booking-partner-authentication/implemented/authorization-code-flow-test.js

Is this test failing?

The OpenActive Reference Implementation test result for this test can be used as a reference to help with debugging.


✅ 5 passed with 0 failures, 0 warnings and 0 suggestions


✅ Open ID Connect Authentication

Credentials

The test suite is using the credentials below for this test:

These credentials were retrieved using Dynamic Client Registration by the Broker Microservice upon startup, using the following configuration within bookingPartners.primary.authentication:

Discovery Request

GET https://localhost:5003/.well-known/openid-configuration


Response status code: 200.

{
  "issuer": "https://localhost:5003",
  "jwks_uri": "https://localhost:5003/.well-known/openid-configuration/jwks",
  "authorization_endpoint": "https://localhost:5003/connect/authorize",
  "token_endpoint": "https://localhost:5003/connect/token",
  "userinfo_endpoint": "https://localhost:5003/connect/userinfo",
  "end_session_endpoint": "https://localhost:5003/connect/endsession",
  "check_session_iframe": "https://localhost:5003/connect/checksession",
  "revocation_endpoint": "https://localhost:5003/connect/revocation",
  "introspection_endpoint": "https://localhost:5003/connect/introspect",
  "device_authorization_endpoint": "https://localhost:5003/connect/deviceauthorization",
  "frontchannel_logout_supported": true,
  "frontchannel_logout_session_supported": true,
  "backchannel_logout_supported": true,
  "backchannel_logout_session_supported": true,
  "scopes_supported": [
    "openid",
    "openactive-identity",
    "openactive-openbooking",
    "openactive-ordersfeed",
    "offline_access"
  ],
  "claims_supported": [
    "sub",
    "https://openactive.io/sellerId",
    "https://openactive.io/sellerName",
    "https://openactive.io/sellerUrl",
    "https://openactive.io/sellerLogo",
    "https://openactive.io/bookingServiceName",
    "https://openactive.io/bookingServiceUrl",
    "name",
    "https://openactive.io/clientId"
  ],
  "grant_types_supported": [
    "authorization_code",
    "client_credentials",
    "refresh_token",
    "implicit",
    "urn:ietf:params:oauth:grant-type:device_code"
  ],
  "response_types_supported": [
    "code",
    "token",
    "id_token",
    "id_token token",
    "code id_token",
    "code token",
    "code id_token token"
  ],
  "response_modes_supported": [
    "form_post",
    "query",
    "fragment"
  ],
  "token_endpoint_auth_methods_supported": [
    "client_secret_basic",
    "client_secret_post"
  ],
  "id_token_signing_alg_values_supported": [
    "RS256"
  ],
  "subject_types_supported": [
    "public"
  ],
  "code_challenge_methods_supported": [
    "plain",
    "S256"
  ],
  "request_parameter_supported": true,
  "registration_endpoint": "https://localhost:5003/connect/register"
}

Authorization Code Flow - 1 Request

POST http://localhost:3000/browser-automation-for-auth

{
  "headless": true,
  "offlineAccess": true,
  "username": "test1",
  "password": "test1",
  "authorizationUrl": "https://localhost:5003/connect/authorize?client_id=18e0f969-8d66-417a-a973-e75b08b1a237&scope=openid%20openactive-openbooking%20offline_access%20openactive-identity&response_type=code&redirect_uri=http%3A%2F%2Flocalhost%3A3000%2Fcb&code_challenge=tbfBmTbb9HOnz4HEceNEZn0ZDx3IaXkJ4xQNXDd7Lvs&code_challenge_method=S256"
}

Screenshot: Login page

"https://localhost:5003/Account/Login?ReturnUrl=%2Fconnect%2Fauthorize%2Fcallback%3Fclient_id%3D18e0f969-8d66-417a-a973-e75b08b1a237%26scope%3Dopenid%2520openactive-openbooking%2520offline_access%2520openactive-identity%26response_type%3Dcode%26redirect_uri%3Dhttp%253A%252F%252Flocalhost%253A3000%252Fcb%26code_challenge%3DtbfBmTbb9HOnz4HEceNEZn0ZDx3IaXkJ4xQNXDd7Lvs%26code_challenge_method%3DS256"

Screenshot: Login page

Screenshot: Authorization page

"https://localhost:5003/consent?returnUrl=%2Fconnect%2Fauthorize%2Fcallback%3Fclient_id%3D18e0f969-8d66-417a-a973-e75b08b1a237%26scope%3Dopenid%2520openactive-openbooking%2520offline_access%2520openactive-identity%26response_type%3Dcode%26redirect_uri%3Dhttp%253A%252F%252Flocalhost%253A3000%252Fcb%26code_challenge%3DtbfBmTbb9HOnz4HEceNEZn0ZDx3IaXkJ4xQNXDd7Lvs%26code_challenge_method%3DS256"

Screenshot: Authorization page

Callback URL

"/cb?code=57626A7B0B2A9856F36005FE7C6B88B73D46985CC159C3844FD679AFBEB1A805&scope=openid%20openactive-openbooking%20offline_access%20openactive-identity&session_state=RSD_dWTvknVScgpNqX7YwqzyhR4FJk32yp8tnf_cbRA.DF6AE48412AD4DE58C640182C5DF38FC"

Authorization Code Flow - 2 Request

POST https://localhost:5003/connect/token

"grant_type=authorization_code&code=57626A7B0B2A9856F36005FE7C6B88B73D46985CC159C3844FD679AFBEB1A805&redirect_uri=http%3A%2F%2Flocalhost%3A3000%2Fcb&code_verifier=yCqPNNFcGfLPTgiVbJSKEXlowQORZ770KAmDiKfez0s"

Response status code: 200.

{
  "id_token": "eyJhbGciOiJSUzI1NiIsImtpZCI6IkIwNEY3QjkxREUzQjk0NzhDNjE4MzNGQjI0QUE1Q0RCIiwidHlwIjoiSldUIn0.eyJuYmYiOjE3MDkxMzQwODMsImV4cCI6MTcwOTEzNDM4MywiaXNzIjoiaHR0cHM6Ly9sb2NhbGhvc3Q6NTAwMyIsImF1ZCI6IjE4ZTBmOTY5LThkNjYtNDE3YS1hOTczLWU3NWIwOGIxYTIzNyIsImlhdCI6MTcwOTEzNDA4MywiYXRfaGFzaCI6ImRmS1hOaFl4YUpqWDdnZW11MDVOS3ciLCJzaWQiOiI1NDU2Rjc4NkRCMzlFREUyRkQ0OEE3QkI1RDcyRjc5NiIsInN1YiI6IjEwMCIsImF1dGhfdGltZSI6MTcwOTEzNDA4MiwiaWRwIjoibG9jYWwiLCJodHRwczovL29wZW5hY3RpdmUuaW8vc2VsbGVyTmFtZSI6IkFjbWUgRml0bmVzcyBMdGQiLCJodHRwczovL29wZW5hY3RpdmUuaW8vc2VsbGVySWQiOiJodHRwczovL2xvY2FsaG9zdDo1MDAxL2FwaS9pZGVudGlmaWVycy9zZWxsZXJzLzEiLCJodHRwczovL29wZW5hY3RpdmUuaW8vc2VsbGVyVXJsIjoiaHR0cHM6Ly93d3cuZXhhbXBsZS5jb20iLCJodHRwczovL29wZW5hY3RpdmUuaW8vc2VsbGVyTG9nbyI6Imh0dHBzOi8vcGxhY2VraXR0ZW4uY29tLzY0MC8zNjAiLCJhbXIiOlsicHdkIl19.eRivvMLmluyZFLK_XIQGkta5XBQxxBmVajmewkZs-UFCm4YT_-mmDv1STrqDcMG4fn-Pu90g2_v1PSxWLjvQ8D1LLZZkUa-QJOK_lazHBaaaHk9nvvWJOIxCFzzmy74mgTkGoPNUuQAsu6qw3Dr0zp4FL3XXGa7hT4jigtuvARanxOkm1rtA8rzzfHBoLAIPTcmTjTAkIImeulHsqRKSGTA2YxS-6I4EEAvQz2wMbLN8IfxGbplQ2LfQ4g-lpp3xcBJZm6kbQ83ZcpMtrN4QoKUDq-fOgj4W7QzN2scZYQ8Q-ulFRuX5IRpjNyw5B3sucOxvBRuLYW4DNcZIghltLA",
  "access_token": "eyJhbGciOiJSUzI1NiIsImtpZCI6IkIwNEY3QjkxREUzQjk0NzhDNjE4MzNGQjI0QUE1Q0RCIiwidHlwIjoiYXQrand0In0.eyJuYmYiOjE3MDkxMzQwODMsImV4cCI6MTcwOTEzNzY4MywiaXNzIjoiaHR0cHM6Ly9sb2NhbGhvc3Q6NTAwMyIsImF1ZCI6Im9wZW5ib29raW5nIiwiY2xpZW50X2lkIjoiMThlMGY5NjktOGQ2Ni00MTdhLWE5NzMtZTc1YjA4YjFhMjM3IiwiaHR0cHM6Ly9vcGVuYWN0aXZlLmlvL2NsaWVudElkIjoiMThlMGY5NjktOGQ2Ni00MTdhLWE5NzMtZTc1YjA4YjFhMjM3Iiwic3ViIjoiMTAwIiwiYXV0aF90aW1lIjoxNzA5MTM0MDgyLCJpZHAiOiJsb2NhbCIsImh0dHBzOi8vb3BlbmFjdGl2ZS5pby9zZWxsZXJJZCI6Imh0dHBzOi8vbG9jYWxob3N0OjUwMDEvYXBpL2lkZW50aWZpZXJzL3NlbGxlcnMvMSIsImp0aSI6IkZBNzdENjZGODcxQjY4MjQ2NTY1QjZFMTE0QUFBRjQ5Iiwic2lkIjoiNTQ1NkY3ODZEQjM5RURFMkZENDhBN0JCNUQ3MkY3OTYiLCJpYXQiOjE3MDkxMzQwODMsInNjb3BlIjpbIm9wZW5pZCIsIm9wZW5hY3RpdmUtb3BlbmJvb2tpbmciLCJvcGVuYWN0aXZlLWlkZW50aXR5Iiwib2ZmbGluZV9hY2Nlc3MiXSwiYW1yIjpbInB3ZCJdfQ.SYVmZcymLsV06gznaQAevYOZZkHL6OiLKcB6XHtH6hDEfx8b2XnN_kdpSeXPuy5gf1kWfiqACoM9TFzlucZ9dHjgaBECpvfOgV2S-XiPhI0R6O94GMIXAkAAunEqKsVwLbsUUlIYMXOWhH8a5tiIlMOPV-Mm4vZShCnYfOmJ3zfrxxaZ3PlUZg0taJ8Zmi7u7ar7IlJEPxKg76iU64jFbzvSZJ8Wi4Zew3DG8C7TYby3xrfR6sG5m41HudtjpdGwf4SyOG44DvitQCK1AaZIcHqJQPXLZI4e2KB4UG321mSvbLOkUCAeqKyYLD2iczuoDvwNh2W_R4YMeECMkFhJpw",
  "expires_in": 3600,
  "token_type": "Bearer",
  "refresh_token": "B5AF4670B46C7ACE561C689C9C67BFAAB4FF501E0501F1718978942C9A038B91",
  "scope": "openid openactive-openbooking offline_access openactive-identity"
}

Authorization Code Flow - 3 Request

GET https://localhost:5003/.well-known/openid-configuration/jwks


Response status code: 200.

{
  "keys": [
    {
      "kty": "RSA",
      "use": "sig",
      "kid": "B04F7B91DE3B9478C61833FB24AA5CDB",
      "e": "AQAB",
      "n": "yZO68vCGrvfBQ5R1z0DVCRAADOWeF3aLlhOaz1Je1SnmohmmlO-1F1hkRM_4MJtR5aECMxMz-MUW1nBCPmUrH0h_rrdCdDdlk8vTHki0ixK-gO73W2ZscOCZ6L2fZ2Oqz0_I840cnSCv55zpiOk9oGJL9TEsLAWYAIyQheaqZO3BkqImuBFmaLVTckvaZeONjHDQa01rxEjRQByir6oYSZPJy54XuRQJaPuCVNeOW8r0R9rKUQf9nl7tnVvhCsU3q1-UPrs8ZW_kaYXuYQJJMk392jX6XNm6czehIYM-O8Z5eGFdR3WW7IAWYEmqTCxrCRuuKU-EEcKOwksx8gBPgQ",
      "alg": "RS256"
    }
  ]
}

Authorization Code Flow - Claims Result

id_token claims:

{
  "nbf": 1709134083,
  "exp": 1709134383,
  "iss": "https://localhost:5003",
  "aud": "18e0f969-8d66-417a-a973-e75b08b1a237",
  "iat": 1709134083,
  "at_hash": "dfKXNhYxaJjX7gemu05NKw",
  "sid": "5456F786DB39EDE2FD48A7BB5D72F796",
  "sub": "100",
  "auth_time": 1709134082,
  "idp": "local",
  "https://openactive.io/sellerName": "Acme Fitness Ltd",
  "https://openactive.io/sellerId": "https://localhost:5001/api/identifiers/sellers/1",
  "https://openactive.io/sellerUrl": "https://www.example.com",
  "https://openactive.io/sellerLogo": "https://placekitten.com/640/360",
  "amr": [
    "pwd"
  ]
}

Refresh Token Request

POST https://localhost:5003/connect/token

"grant_type=refresh_token&refresh_token=B5AF4670B46C7ACE561C689C9C67BFAAB4FF501E0501F1718978942C9A038B91"

Response status code: 200.

{
  "id_token": "eyJhbGciOiJSUzI1NiIsImtpZCI6IkIwNEY3QjkxREUzQjk0NzhDNjE4MzNGQjI0QUE1Q0RCIiwidHlwIjoiSldUIn0.eyJuYmYiOjE3MDkxMzQwODMsImV4cCI6MTcwOTEzNDM4MywiaXNzIjoiaHR0cHM6Ly9sb2NhbGhvc3Q6NTAwMyIsImF1ZCI6IjE4ZTBmOTY5LThkNjYtNDE3YS1hOTczLWU3NWIwOGIxYTIzNyIsImlhdCI6MTcwOTEzNDA4MywiYXRfaGFzaCI6Ind0ZHlwa1ZKb0F1aFRYM0J6Ul9ucGciLCJzdWIiOiIxMDAiLCJhdXRoX3RpbWUiOjE3MDkxMzQwODIsImlkcCI6ImxvY2FsIiwiaHR0cHM6Ly9vcGVuYWN0aXZlLmlvL3NlbGxlck5hbWUiOiJBY21lIEZpdG5lc3MgTHRkIiwiaHR0cHM6Ly9vcGVuYWN0aXZlLmlvL3NlbGxlcklkIjoiaHR0cHM6Ly9sb2NhbGhvc3Q6NTAwMS9hcGkvaWRlbnRpZmllcnMvc2VsbGVycy8xIiwiaHR0cHM6Ly9vcGVuYWN0aXZlLmlvL3NlbGxlclVybCI6Imh0dHBzOi8vd3d3LmV4YW1wbGUuY29tIiwiaHR0cHM6Ly9vcGVuYWN0aXZlLmlvL3NlbGxlckxvZ28iOiJodHRwczovL3BsYWNla2l0dGVuLmNvbS82NDAvMzYwIiwiYW1yIjpbInB3ZCJdfQ.GIL1ri3sTY0yT2xSjyJ6T9zDFV2VVgRCIdhIH-aqav14yuKzInTS5sqTDq1HIqi5RwcpyP9meTEM7d65xNqwCSmoX67cuHMfTrP589u3I7PaliIGEjCiQP1I8FPHk2RYReFVaZzZK0MuK2Q1oraTr6_SNtFm_F36R1HjoL2ptYIClD3yOZH9hw258zRo-IGdQgJuOykP9b3WyfMOEK03ftK1J4vVXUp5QDEuc-Zy_ZbSKUhX4Taz_1FZAivI0G_AlIS0YeTMlUisa2cJBum02vizBfhjedFYdTADDp5bXkhjV-A5byMQh9kpCFY2zg-XvlOCFgixywxoneQan6hDMw",
  "access_token": "eyJhbGciOiJSUzI1NiIsImtpZCI6IkIwNEY3QjkxREUzQjk0NzhDNjE4MzNGQjI0QUE1Q0RCIiwidHlwIjoiYXQrand0In0.eyJuYmYiOjE3MDkxMzQwODMsImV4cCI6MTcwOTEzNzY4MywiaXNzIjoiaHR0cHM6Ly9sb2NhbGhvc3Q6NTAwMyIsImF1ZCI6Im9wZW5ib29raW5nIiwiY2xpZW50X2lkIjoiMThlMGY5NjktOGQ2Ni00MTdhLWE5NzMtZTc1YjA4YjFhMjM3IiwiaHR0cHM6Ly9vcGVuYWN0aXZlLmlvL2NsaWVudElkIjoiMThlMGY5NjktOGQ2Ni00MTdhLWE5NzMtZTc1YjA4YjFhMjM3Iiwic3ViIjoiMTAwIiwiYXV0aF90aW1lIjoxNzA5MTM0MDgyLCJpZHAiOiJsb2NhbCIsImh0dHBzOi8vb3BlbmFjdGl2ZS5pby9zZWxsZXJJZCI6Imh0dHBzOi8vbG9jYWxob3N0OjUwMDEvYXBpL2lkZW50aWZpZXJzL3NlbGxlcnMvMSIsImp0aSI6IkQ1QjlGRUM3RjY0NjI4NDg5MjcwQzg5MjVBOTk3QUE1IiwiaWF0IjoxNzA5MTM0MDgzLCJzY29wZSI6WyJvcGVuaWQiLCJvcGVuYWN0aXZlLW9wZW5ib29raW5nIiwib3BlbmFjdGl2ZS1pZGVudGl0eSIsIm9mZmxpbmVfYWNjZXNzIl0sImFtciI6WyJwd2QiXX0.AjUZUNWCoMGCLBMrU73AplOInscy8KV-P9jgoodpBcdZjDCMH_yY_s-PjaK_0GtrqVpF68UT_6qicB0bO_OGYedk2L-KsYA9rZiVw9tUuS-_wZGUqHXKmlRHvrImyMqJDvgYC2MkojBmRANVw9M6bnwBlxjfcvHe9_y435SzZ1DK6I_oIONmlPPU6nUFgus3hRQ-8y6zBiAbx4Twkjz3exgzHbpdt4-qAAAIFbmDh9W8LQuO8ttcQbEhc3lNbhuMbtiHxYMycEzWyLOUtxhZo5Bw_EG6N6unH5dRR7CW5Fr_1hrk95Ho8PbIMG9txyTt00da39gKKXE8I0u5yVmg7A",
  "expires_in": 3600,
  "token_type": "Bearer",
  "refresh_token": "8CF3A0CB08E70B8D5BE1A757D2CDE3735E6B44E87A29F3FD13FBD7C61E7EDD8F",
  "scope": "openid openactive-openbooking openactive-identity offline_access"
}

Specs