< Return to Summary | File Generated: Thu May 09 2024 14:37:56 GMT+0000 (Coordinated Universal Time)
Booking Flow: OpenBookingApprovalFlow
Opportunity Type: ScheduledSession
Feature: Core / Multiple Sellers (Implemented)
Test: Credentials for Seller (a) must not provide access to make bookings for Seller (b)
Using primary seller auth, make a call to C1, C2, and P/B for the secondary seller, expecting all calls to fail with InvalidAuthorizationDetailsError
npm start -- --runInBand test/features/core/multiple-sellers/implemented/seller-access-restricted-by-auth-test.js
The OpenActive Reference Implementation test result for this test can be used as a reference to help with debugging.
⚠️ 8 passed with 0 failures, 33 warnings and 18 suggestions
POST http://localhost:3000/test-interface/datasets/uat-ci/opportunities
{
"@type": "ScheduledSession",
"superEvent": {
"@type": "SessionSeries",
"organizer": {
"@type": "Organization",
"@id": "https://localhost:5001/api/identifiers/sellers/2"
}
},
"@context": [
"https://openactive.io/",
"https://openactive.io/test-interface"
],
"test:testOpportunityCriteria": "https://openactive.io/test-interface#TestOpportunityBookable",
"test:testOpenBookingFlow": "https://openactive.io/test-interface#OpenBookingApprovalFlow"
}
Response status code: 200 OK. Responded in 12.758868ms.
{
"@context": "https://openactive.io/",
"@type": "ScheduledSession",
"@id": "https://localhost:5001/api/identifiers/scheduled-sessions/1062/events/10613"
}
GET http://localhost:3000/opportunity/https%3A%2F%2Flocalhost%3A5001%2Fapi%2Fidentifiers%2Fscheduled-sessions%2F1062%2Fevents%2F10613?useCacheIfAvailable=true
Response status code: 200 OK. Responded in 3.383848ms.
{
"data": {
"@context": [
"https://openactive.io/"
],
"@type": "ScheduledSession",
"@id": "https://localhost:5001/api/identifiers/scheduled-sessions/1062/events/10613",
"startDate": "2024-05-15T13:06:18+00:00",
"endDate": "2024-05-15T14:51:18+00:00",
"superEvent": {
"@type": "SessionSeries",
"@id": "https://localhost:5001/api/identifiers/session-series/1062",
"identifier": 1062,
"name": "GOLDEN: Wooden Jumping",
"activity": [
{
"@type": "Concept",
"@id": "https://openactive.io/activity-list#8a4abff3-c616-4f33-80a1-398b88c672a3",
"inScheme": "https://openactive.io/activity-list",
"prefLabel": "World Jumping®"
}
],
"eventAttendanceMode": "https://schema.org/OnlineEventAttendanceMode",
"offers": [
{
"@type": "Offer",
"@id": "https://localhost:5001/api/identifiers/session-series/1062#/offers/0",
"name": "Adult",
"acceptedPaymentMethod": [
"http://purl.org/goodrelations/v1#Cash",
"http://purl.org/goodrelations/v1#PaymentMethodCreditCard"
],
"ageRestriction": {
"@type": "QuantitativeValue",
"name": "Adult",
"maxValue": 59,
"minValue": 18
},
"allowCustomerCancellationFullRefund": false,
"openBookingFlowRequirement": [
"https://openactive.io/OpenBookingApproval"
],
"openBookingPrepayment": "https://openactive.io/Required",
"price": 3.37,
"priceCurrency": "GBP"
},
{
"@type": "Offer",
"@id": "https://localhost:5001/api/identifiers/session-series/1062#/offers/0",
"name": "Junior",
"acceptedPaymentMethod": [
"http://purl.org/goodrelations/v1#Cash",
"http://purl.org/goodrelations/v1#PaymentMethodCreditCard"
],
"ageRestriction": {
"@type": "QuantitativeValue",
"name": "Junior",
"maxValue": 17
},
"allowCustomerCancellationFullRefund": false,
"openBookingFlowRequirement": [
"https://openactive.io/OpenBookingApproval"
],
"openBookingPrepayment": "https://openactive.io/Required",
"price": 3.37,
"priceCurrency": "GBP"
},
{
"@type": "Offer",
"@id": "https://localhost:5001/api/identifiers/session-series/1062#/offers/0",
"name": "Senior",
"acceptedPaymentMethod": [
"http://purl.org/goodrelations/v1#Cash",
"http://purl.org/goodrelations/v1#PaymentMethodCreditCard"
],
"ageRestriction": {
"@type": "QuantitativeValue",
"name": "Senior",
"minValue": 60
},
"allowCustomerCancellationFullRefund": false,
"openBookingFlowRequirement": [
"https://openactive.io/OpenBookingApproval"
],
"openBookingPrepayment": "https://openactive.io/Required",
"price": 3.37,
"priceCurrency": "GBP"
},
{
"@type": "Offer",
"@id": "https://localhost:5001/api/identifiers/session-series/1062#/offers/0",
"name": "Adult (off-peak)",
"acceptedPaymentMethod": [
"http://purl.org/goodrelations/v1#Cash",
"http://purl.org/goodrelations/v1#PaymentMethodCreditCard"
],
"ageRestriction": {
"@type": "QuantitativeValue",
"name": "Adult (off-peak)",
"maxValue": 59,
"minValue": 18
},
"allowCustomerCancellationFullRefund": false,
"openBookingFlowRequirement": [
"https://openactive.io/OpenBookingApproval"
],
"openBookingPrepayment": "https://openactive.io/Required",
"price": 3.37,
"priceCurrency": "GBP"
}
],
"organizer": {
"@type": "Organization",
"@id": "https://localhost:5001/api/identifiers/sellers/2",
"name": "Road Runner Bookcamp Ltd",
"isOpenBookingAllowed": true,
"sameAs": [
"https://socialmedia.com/RoadRunnerBookcampLtd"
],
"taxMode": "https://openactive.io/TaxNet",
"telephone": "06672 386579",
"termsOfService": [
{
"@type": "PrivacyPolicy",
"name": "Privacy Policy",
"requiresExplicitConsent": false,
"url": "https://example.com/privacy.html"
}
],
"url": "http://augustine.biz"
},
"url": "https://www.example.com/sessions/1062"
},
"duration": "PT1H45M",
"maximumAttendeeCapacity": 14,
"remainingAttendeeCapacity": 14
}
}
eventStatus
is missing from ScheduledSession
.leader
is missing from ScheduledSession
.url
is missing from ScheduledSession
.description
is missing from SessionSeries
.image
is missing from SessionSeries
.ageRange
is missing from SessionSeries
.genderRestriction
is missing from SessionSeries
.leader
is missing from SessionSeries
.level
is missing from SessionSeries
.genderRestriction
is supplied on a ScheduledSession
.ageRange
is 18+ when not specified.eventStatus
is scheduled if not specified or invalid.genderRestriction
is supplied on a SessionSeries
.ageRange
is 18+ when not specified.eventStatus
is scheduled if not specified or invalid.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.PUT https://localhost:5001/api/openbooking/order-quote-templates/09998b98-9042-49d5-a2cb-76939c40a21f
"application/vnd.openactive.booking+json; version=1"
"Bearer eyJhbGciOiJSUzI1NiIsImtpZCI6IkIwNEY3QjkxREUzQjk0NzhDNjE4MzNGQjI0QUE1Q0RCIiwidHlwIjoiYXQrand0In0.eyJuYmYiOjE3MTUyNjQ5MDQsImV4cCI6MTcxNTI2ODUwNCwiaXNzIjoiaHR0cHM6Ly9sb2NhbGhvc3Q6NTAwMyIsImF1ZCI6Im9wZW5ib29raW5nIiwiY2xpZW50X2lkIjoiNjg3ZWZiNWQtZTI4ZS00MWMzLWE0MjItODJjMDhkODU1NGVlIiwiaHR0cHM6Ly9vcGVuYWN0aXZlLmlvL2NsaWVudElkIjoiNjg3ZWZiNWQtZTI4ZS00MWMzLWE0MjItODJjMDhkODU1NGVlIiwic3ViIjoiMTAwIiwiYXV0aF90aW1lIjoxNzE1MjY0OTA0LCJpZHAiOiJsb2NhbCIsImh0dHBzOi8vb3BlbmFjdGl2ZS5pby9zZWxsZXJJZCI6Imh0dHBzOi8vbG9jYWxob3N0OjUwMDEvYXBpL2lkZW50aWZpZXJzL3NlbGxlcnMvMSIsImp0aSI6IkRGNDg2MTYzQ0UxMTM0RkQ5RTMxRkVDOUUzQ0U0NkRBIiwic2lkIjoiNkY2NkM3RjY5Mzk3RDM0QzU0OENGRjlGQkFBRTQ5QTYiLCJpYXQiOjE3MTUyNjQ5MDQsInNjb3BlIjpbIm9wZW5pZCIsIm9wZW5hY3RpdmUtb3BlbmJvb2tpbmciLCJvcGVuYWN0aXZlLWlkZW50aXR5Iiwib2ZmbGluZV9hY2Nlc3MiXSwiYW1yIjpbInB3ZCJdfQ.nyj8TG9lTXIxqP7DYGLEMzQzXalaYxwGIgDrmJPGb2pnUVlc5uy5m7jG06JDIPSBTRqvMucZ-77mNWytjaIpbEc57zuWtxJXjWhXTl_PWzhCIoKeysRI3TpdvFbMDVMuwwDZj0D5QlJuB26ZhxRg5M3OERZb6e8LYqu9qiqyEj-1Fnu0_ehw8w7s7gshxLaYuDk4ohcqgNLTB_ky5oX_T27TxEZxznR5FpelBC072i1l0Z5jQs-bK2KDjMLFdN-OKb5vDNr9Db6woB0EzN3t3R8xtoKeZxBx-AiEbRhiaduwkV2qoVmxKizc-ia86O_KcCI2Jrn8yzFAoVdTrc4JCA"
{
"@context": "https://openactive.io/",
"@type": "OrderQuote",
"brokerRole": "https://openactive.io/AgentBroker",
"broker": {
"@type": "Organization",
"name": "MyFitnessApp",
"url": "https://myfitnessapp.example.com",
"description": "A fitness app for all the community",
"logo": {
"@type": "ImageObject",
"url": "http://data.myfitnessapp.org.uk/images/logo.png"
},
"address": {
"@type": "PostalAddress",
"streetAddress": "Alan Peacock Way",
"addressLocality": "Village East",
"addressRegion": "Middlesbrough",
"postalCode": "TS4 3AE",
"addressCountry": "GB"
}
},
"seller": "https://localhost:5001/api/identifiers/sellers/2",
"orderedItem": [
{
"@type": "OrderItem",
"position": 0,
"acceptedOffer": "https://localhost:5001/api/identifiers/session-series/1062#/offers/0",
"orderedItem": "https://localhost:5001/api/identifiers/scheduled-sessions/1062/events/10613"
}
],
"payment": {
"@type": "Payment",
"name": "AcmeBroker Points",
"accountId": "SN1593",
"paymentProviderId": "STRIPE"
}
}
Response status code: 401 Unauthorized. Responded in 17.180727ms.
{
"@context": "https://openactive.io/",
"@type": "InvalidAuthorizationDetailsError",
"name": "The Broker supplied an invalid set of authorization details, either malformed or expired.",
"statusCode": 401
}
description
is missing from InvalidAuthorizationDetailsError
.instance
is missing from InvalidAuthorizationDetailsError
."@type": "InvalidAuthorizationDetailsError"
with status code 401
eventStatus
is missing from ScheduledSession
.leader
is missing from ScheduledSession
.url
is missing from ScheduledSession
.description
is missing from SessionSeries
.image
is missing from SessionSeries
.ageRange
is missing from SessionSeries
.genderRestriction
is missing from SessionSeries
.leader
is missing from SessionSeries
.level
is missing from SessionSeries
.genderRestriction
is supplied on a ScheduledSession
.ageRange
is 18+ when not specified.eventStatus
is scheduled if not specified or invalid.genderRestriction
is supplied on a SessionSeries
.ageRange
is 18+ when not specified.eventStatus
is scheduled if not specified or invalid.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.PUT https://localhost:5001/api/openbooking/order-quotes/09998b98-9042-49d5-a2cb-76939c40a21f
"application/vnd.openactive.booking+json; version=1"
"Bearer eyJhbGciOiJSUzI1NiIsImtpZCI6IkIwNEY3QjkxREUzQjk0NzhDNjE4MzNGQjI0QUE1Q0RCIiwidHlwIjoiYXQrand0In0.eyJuYmYiOjE3MTUyNjQ5MDQsImV4cCI6MTcxNTI2ODUwNCwiaXNzIjoiaHR0cHM6Ly9sb2NhbGhvc3Q6NTAwMyIsImF1ZCI6Im9wZW5ib29raW5nIiwiY2xpZW50X2lkIjoiNjg3ZWZiNWQtZTI4ZS00MWMzLWE0MjItODJjMDhkODU1NGVlIiwiaHR0cHM6Ly9vcGVuYWN0aXZlLmlvL2NsaWVudElkIjoiNjg3ZWZiNWQtZTI4ZS00MWMzLWE0MjItODJjMDhkODU1NGVlIiwic3ViIjoiMTAwIiwiYXV0aF90aW1lIjoxNzE1MjY0OTA0LCJpZHAiOiJsb2NhbCIsImh0dHBzOi8vb3BlbmFjdGl2ZS5pby9zZWxsZXJJZCI6Imh0dHBzOi8vbG9jYWxob3N0OjUwMDEvYXBpL2lkZW50aWZpZXJzL3NlbGxlcnMvMSIsImp0aSI6IkRGNDg2MTYzQ0UxMTM0RkQ5RTMxRkVDOUUzQ0U0NkRBIiwic2lkIjoiNkY2NkM3RjY5Mzk3RDM0QzU0OENGRjlGQkFBRTQ5QTYiLCJpYXQiOjE3MTUyNjQ5MDQsInNjb3BlIjpbIm9wZW5pZCIsIm9wZW5hY3RpdmUtb3BlbmJvb2tpbmciLCJvcGVuYWN0aXZlLWlkZW50aXR5Iiwib2ZmbGluZV9hY2Nlc3MiXSwiYW1yIjpbInB3ZCJdfQ.nyj8TG9lTXIxqP7DYGLEMzQzXalaYxwGIgDrmJPGb2pnUVlc5uy5m7jG06JDIPSBTRqvMucZ-77mNWytjaIpbEc57zuWtxJXjWhXTl_PWzhCIoKeysRI3TpdvFbMDVMuwwDZj0D5QlJuB26ZhxRg5M3OERZb6e8LYqu9qiqyEj-1Fnu0_ehw8w7s7gshxLaYuDk4ohcqgNLTB_ky5oX_T27TxEZxznR5FpelBC072i1l0Z5jQs-bK2KDjMLFdN-OKb5vDNr9Db6woB0EzN3t3R8xtoKeZxBx-AiEbRhiaduwkV2qoVmxKizc-ia86O_KcCI2Jrn8yzFAoVdTrc4JCA"
{
"@context": "https://openactive.io/",
"@type": "OrderQuote",
"brokerRole": "https://openactive.io/AgentBroker",
"broker": {
"@type": "Organization",
"name": "MyFitnessApp",
"url": "https://myfitnessapp.example.com",
"description": "A fitness app for all the community",
"logo": {
"@type": "ImageObject",
"url": "http://data.myfitnessapp.org.uk/images/logo.png"
},
"address": {
"@type": "PostalAddress",
"streetAddress": "Alan Peacock Way",
"addressLocality": "Village East",
"addressRegion": "Middlesbrough",
"postalCode": "TS4 3AE",
"addressCountry": "GB"
}
},
"seller": "https://localhost:5001/api/identifiers/sellers/2",
"customer": {
"@type": "Person",
"email": "[email protected]",
"telephone": "(532) 869-7607 x790",
"familyName": "Ward",
"identifier": "920bf7b2-94bb-4ab4-a6d8-2bb336f4fc93"
},
"orderedItem": [
{
"@type": "OrderItem",
"position": 0,
"acceptedOffer": "https://localhost:5001/api/identifiers/session-series/1062#/offers/0",
"orderedItem": "https://localhost:5001/api/identifiers/scheduled-sessions/1062/events/10613"
}
],
"payment": {
"@type": "Payment",
"name": "AcmeBroker Points",
"accountId": "SN1593",
"paymentProviderId": "STRIPE"
}
}
Response status code: 401 Unauthorized. Responded in 9.207097ms.
{
"@context": "https://openactive.io/",
"@type": "InvalidAuthorizationDetailsError",
"name": "The Broker supplied an invalid set of authorization details, either malformed or expired.",
"statusCode": 401
}
description
is missing from InvalidAuthorizationDetailsError
.instance
is missing from InvalidAuthorizationDetailsError
."@type": "InvalidAuthorizationDetailsError"
with status code 401
eventStatus
is missing from ScheduledSession
.leader
is missing from ScheduledSession
.url
is missing from ScheduledSession
.description
is missing from SessionSeries
.image
is missing from SessionSeries
.ageRange
is missing from SessionSeries
.genderRestriction
is missing from SessionSeries
.leader
is missing from SessionSeries
.level
is missing from SessionSeries
.genderRestriction
is supplied on a ScheduledSession
.ageRange
is 18+ when not specified.eventStatus
is scheduled if not specified or invalid.genderRestriction
is supplied on a SessionSeries
.ageRange
is 18+ when not specified.eventStatus
is scheduled if not specified or invalid.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.schema:name
is declared in schema.org but this validator is not yet capable of checking whether they have the right format or values. You should refer to the schema.org documentation for schema:name for additional guidance.PUT https://localhost:5001/api/openbooking/order-proposals/09998b98-9042-49d5-a2cb-76939c40a21f
"application/vnd.openactive.booking+json; version=1"
"Bearer eyJhbGciOiJSUzI1NiIsImtpZCI6IkIwNEY3QjkxREUzQjk0NzhDNjE4MzNGQjI0QUE1Q0RCIiwidHlwIjoiYXQrand0In0.eyJuYmYiOjE3MTUyNjQ5MDQsImV4cCI6MTcxNTI2ODUwNCwiaXNzIjoiaHR0cHM6Ly9sb2NhbGhvc3Q6NTAwMyIsImF1ZCI6Im9wZW5ib29raW5nIiwiY2xpZW50X2lkIjoiNjg3ZWZiNWQtZTI4ZS00MWMzLWE0MjItODJjMDhkODU1NGVlIiwiaHR0cHM6Ly9vcGVuYWN0aXZlLmlvL2NsaWVudElkIjoiNjg3ZWZiNWQtZTI4ZS00MWMzLWE0MjItODJjMDhkODU1NGVlIiwic3ViIjoiMTAwIiwiYXV0aF90aW1lIjoxNzE1MjY0OTA0LCJpZHAiOiJsb2NhbCIsImh0dHBzOi8vb3BlbmFjdGl2ZS5pby9zZWxsZXJJZCI6Imh0dHBzOi8vbG9jYWxob3N0OjUwMDEvYXBpL2lkZW50aWZpZXJzL3NlbGxlcnMvMSIsImp0aSI6IkRGNDg2MTYzQ0UxMTM0RkQ5RTMxRkVDOUUzQ0U0NkRBIiwic2lkIjoiNkY2NkM3RjY5Mzk3RDM0QzU0OENGRjlGQkFBRTQ5QTYiLCJpYXQiOjE3MTUyNjQ5MDQsInNjb3BlIjpbIm9wZW5pZCIsIm9wZW5hY3RpdmUtb3BlbmJvb2tpbmciLCJvcGVuYWN0aXZlLWlkZW50aXR5Iiwib2ZmbGluZV9hY2Nlc3MiXSwiYW1yIjpbInB3ZCJdfQ.nyj8TG9lTXIxqP7DYGLEMzQzXalaYxwGIgDrmJPGb2pnUVlc5uy5m7jG06JDIPSBTRqvMucZ-77mNWytjaIpbEc57zuWtxJXjWhXTl_PWzhCIoKeysRI3TpdvFbMDVMuwwDZj0D5QlJuB26ZhxRg5M3OERZb6e8LYqu9qiqyEj-1Fnu0_ehw8w7s7gshxLaYuDk4ohcqgNLTB_ky5oX_T27TxEZxznR5FpelBC072i1l0Z5jQs-bK2KDjMLFdN-OKb5vDNr9Db6woB0EzN3t3R8xtoKeZxBx-AiEbRhiaduwkV2qoVmxKizc-ia86O_KcCI2Jrn8yzFAoVdTrc4JCA"
{
"@context": "https://openactive.io/",
"@type": "OrderProposal",
"brokerRole": "https://openactive.io/AgentBroker",
"broker": {
"@type": "Organization",
"name": "MyFitnessApp",
"url": "https://myfitnessapp.example.com",
"description": "A fitness app for all the community",
"logo": {
"@type": "ImageObject",
"url": "http://data.myfitnessapp.org.uk/images/logo.png"
},
"address": {
"@type": "PostalAddress",
"streetAddress": "Alan Peacock Way",
"addressLocality": "Village East",
"addressRegion": "Middlesbrough",
"postalCode": "TS4 3AE",
"addressCountry": "GB"
}
},
"seller": "https://localhost:5001/api/identifiers/sellers/2",
"customer": {
"@type": "Person",
"email": "[email protected]",
"telephone": "(532) 869-7607 x790",
"familyName": "Ward",
"identifier": "920bf7b2-94bb-4ab4-a6d8-2bb336f4fc93"
},
"orderedItem": [
{
"@type": "OrderItem",
"position": 0,
"acceptedOffer": "https://localhost:5001/api/identifiers/session-series/1062#/offers/0",
"orderedItem": "https://localhost:5001/api/identifiers/scheduled-sessions/1062/events/10613"
}
],
"totalPaymentDue": {
"@type": "PriceSpecification",
"price": 0,
"priceCurrency": "GBP"
}
}
Response status code: 401 Unauthorized. Responded in 11.58544ms.
{
"@context": "https://openactive.io/",
"@type": "InvalidAuthorizationDetailsError",
"name": "The Broker supplied an invalid set of authorization details, either malformed or expired.",
"statusCode": 401
}
"@type": "InvalidAuthorizationDetailsError"
with status code 401
description
is missing from InvalidAuthorizationDetailsError
.instance
is missing from InvalidAuthorizationDetailsError
.