Ancillary Shop API Reference
POST |
ancillaryshop/catalogofferingsancillaries Base path: Pre-production https://api.pp.travelport.com/11/air/ Production https://api.travelport.com/11/air/ |
Related Content: Ancillary and EMD Guide, Ancillary Workflow Diagram
The Ancillary Shop request searches for available ancillaries. It can be sent after pricing, in the initial booking workbench, or for an existing reservation. The request uses the same endpoint but a different payload for each option, per below.
See the Ancillary and EMD Guide for workflow details and specific ancillaries supported.
For paid seats use the seat requests in the Seats Guide.
Request
Also see Authorization and Common Headers.
Query Parameters
None.
Request Body
Ancillary shop request after AirPrice (no workbench; GDS only)
This request supports ancillary shop for an entire offer. It cannot be used to shop ancillaries on a segment (a segment is a product in the JSON APIs).
Object |
Description |
Required/Optional |
---|---|---|
CatalogOfferingsQueryAncillaries |
Top level object. |
Required |
AncillaryOfferings |
Top level object. |
Required |
BuildFromOfferList |
Top level object. |
Required |
OfferListIdentifier |
Top level object. |
Required |
OfferIdentifier |
Sends offer identifier. Key value pair:
|
Required |
Ancillary shop request in the initial booking workflow (pre-commit)
In the initial booking workflow, for either GDS or NDC, use the following payload.
For NDC only, you can send this same payload to shop ancillaries after AirPrice without a workbench. For GDS, see the section above for the payload to send after AirPrice.
Object |
Description |
Required/Optional |
---|---|---|
CatalogOfferingsQueryAncillaries |
Top level object. |
Required |
AncillaryOfferings |
Top level object. |
Required |
BuildFromOffer |
Top level object. |
Required |
OfferIdentifier |
Top level object. |
Required |
Identifier (for the offer) |
Sends offer identifier. Key value pair:
|
Required |
ProductIdentifier |
Sends product identifier. |
Required |
Identifier (for the product) |
Sends product identifier. Repeat for each product as needed. Key value pair:
|
Required |
Ancillary shop request for existing reservation (post-commit)
For an existing reservation, for either GDS or NDC, use the following payload.
Object |
Description |
Required/Optional |
---|---|---|
CatalogOfferingsQueryAncillaries |
Top level object. |
Required |
AncillaryOfferings |
Top level object. |
Required |
BuildFromReservationWorkbench |
Top level object. |
Required |
ReservationIdentifier |
Top level object. |
Required |
Identifier |
Sends workbench identifier. Key value pair:
|
Required |
Response
The Ancillary Shop response is the same following a request sent in either the initial booking flow or for an existing reservation.
Object |
Description |
---|---|
CatalogOfferingsAncillaryListResponse |
Top level object. Includes CatalogOfferingsID, Identifier, and ReferenceList. |
CatalogOfferingsID |
Top level object for offers. Includes CatalogOffering and TravelerIdentiferRef. Key value pairs:
|
CatalogOffering |
Array of individual ancillary offers. Key value pair:
Each instance includes Identifier, ProductOptions, Price, and TermsAndConditions objects. |
CatalogOffering/Identifier |
Identifier for the offer. Key value pairs:
CatalogOffering/Identifier/value and /authority must be sent in subsequent ancillary price and/or book requests.
|
ProductOptions |
Top level object for products in the offer. Includes Product object. |
Product |
Array. Returns one or more instances with @type ProductAncillary to detail the ancillary product. Key value pair:
Includes Quantity and Ancillary. CatalogOffering/ProductOptions/Product/id must be sent as the product identifier in any subsequent ancillary price and/or book requests.
|
Quantity |
The available number of this ancillary product. |
Ancillary |
Details of this ancillary. Includes Description and FlightRef. For each instance of Ancillary, the @type designator may be either of the following:
|
Description |
Supplier-provided description of this ancillary product. Key value pairs:
|
FlightRef |
Internal reference number for the flight on which this ancillary is available. Matches to FlightRef in ReferenceList/ReferenceListFlight. |
Price |
Price details for this ancillary product in this offer. Includes CurrencyCode, Base, TotalTaxes, TotalPrice objects. |
CurrencyCode |
The currency in which the price is returned. Unless changed in the request, the currency is the default associated with your provisioned PCC from Travelport. Key value pairs:
|
Base |
Base price before taxes. |
TotalTaxes |
Sum of all taxes for the product. |
TotalPrice |
Total price including base and taxes. |
TermsAndConditions |
Returned with @typeTermsAndConditionsAncillary. Terms and conditions for this ancillary product in this offer. Includes TravelerProduct and ApplicationLimit. |
TravelerProduct |
Includes TravelerIdentifierRef. |
TravelerIdentiferRef |
Returns details of the traveler the ancillary is requested for. Key value pairs: id: Internal system-generated traveler id. value: Internal system-generated traveler id. |
Any restrictions on the number of this ancillary product that can be purchased. Key value pairs:
|
|
CatalogOfferingsAncillaryListResponse/Identifier |
Identifier for ancillary shop response as a whole. Key value pairs:
CatalogOfferingsAncillaryListResponse/Identifier/value must be sent as the response identifier in subsequent ancillary price and/or book requests.
|
ReferenceList |
Consolidates flight details in ReferenceList/ReferenceListFlight. Includes ReferenceListFlight. See table below. |
The ancillary response returns ReferenceList/ReferenceListFlight for flight details. Does not return the AvailabilitySourceCode or IntermediateStop objects below.
Object | Description |
---|---|
ReferenceListFlight |
Returns an array of Flight objects that match to the flights that make up a product. ReferenceListFlight is a common object in the model. Not all objects in this table may be returned in this specific API. |
Flight |
One instance for one flight. Key value pairs:
For GDS, the Flight id is formatted as the letter ‘s’+ unique numeric value, as in s1. For NDC, the Flight id is formatted as the two letter NDC carrier code + s+ unique numeric value, as in QFs1. Includes Departure, Arrival, AvailabilitySourceCode, and IntermediateStop objects. |
Departure |
Departure details. Key value pairs are the location, date, time, and terminal of departure. |
Arrival |
Arrival details. Key value pairs are the location, date, time, and terminal of arrival. |
Returned to assist in troubleshooting. Returned in Search, Air Availability, Exchange Search, AirPrice, and AirReservation commit responses. Recommended to be sent in the AirPrice Full Payload and Add Offer Full Payload requests. Supported values and definitions for AvailabilitySourceCode are as follows:
|
|
IntermediateStop |
Returned if the flight has a technical stop but does not incur a change in flight number. Returned only in Search and Exchange Search responses. Key value pairs:
|
Example Request
Ancillary shop request after AirPrice (no workbench; GDS only)
{
"CatalogOfferingsQueryAncillaries": {
"AncillaryOfferings": {
"@type": "AncillaryOfferingsBuildFromOfferList",
"BuildFromOfferList": {
"OfferListIdentifier": "238ef294-4d0f-4d6f-838e-154ddaf2c7be_PC",
"OfferIdentifier": [
{
"id": "o0"
}
]
}
}
}
}
Ancillary shop request in the initial booking workflow (pre-commit)
The following example payload, sent for a new reservation, sends offer and product identifiers from the Search response.
{
"CatalogOfferingsQueryAncillaries": {
"AncillaryOfferings": {
"@type": "AncillaryOfferingsBuildFromOffer",
"BuildFromOffer": {
"@type": "BuildFromOfferAir",
"OfferIdentifier": {
"Identifier": {
"value": "653f9c6f-4618-44e5-8f2d-2a23dd6fcc40_PC"
}
},
"ProductIdentifier": [
{
"Identifier": {
"value": "p0"
}
}
]
}
}
}
}
Ancillary shop request for existing reservation (post-commit)
The following example payload, sent for an existing reservation, sends the workbench identifier.
{
"CatalogOfferingsQueryAncillaries": {
"AncillaryOfferings": {
"@type": "AncillaryOfferingsBuildFromReservationWorkbench",
"BuildFromReservationWorkbench": {
"ReservationIdentifier": {
"Identifier": {
"value": "85d34008-c5ad-42f6-99ee-a7c0e6d5a2a3"
}
}
}
}
}
}
Example Response
The Ancillary Shop response is the same regardless of where in the workflow the shop request is sent.
The following example response returns several offers for paid baggage.
{
"CatalogOfferingsAncillaryListResponse": {
"@type": "CatalogOfferingsAncillaryListResponse",
"transactionId": "0ff0ccfd-5118-4428-b8c5-208a1ed1034d",
"CatalogOfferingsID": [
{
"@type": "CatalogOfferingsTraveler",
"id": "CT1",
"CatalogOffering": [
{
"@type": "CatalogOffering",
"id": "anc_off1",
"ProductOptions": [
{
"@type": "ProductOptions",
"Product": [
{
"@type": "ProductAncillary",
"id": "an1",
"Quantity": 1,
"Ancillary": {
"@type": "AncillaryAirBaggage",
"Description": [
{
"code": "BG",
"subCode": "0C1",
"value": "EXTRA 15KG FOR KG ALLOWANCE"
}
],
"FlightRef": [
"s1"
]
}
}
]
}
],
"Price": {
"@type": "PriceDetail",
"CurrencyCode": {
"value": "AUD"
},
"Base": 187.5,
"TotalTaxes": 18.75,
"TotalPrice": 206.25,
"PriceBreakdown": [
{
"@type": "PriceBreakdownAncillaryAir",
"Amount": {
"@type": "Amount",
"Taxes": {
"@type": "TaxesDetail",
"Tax": [
{
"taxCode": "UO",
"value": 18.75
}
]
}
}
}
]
},
"TermsAndConditions": {
"@type": "TermsAndConditionsAncillary",
"ExpiryDate": "2049-12-12T00:00:00Z",
"ApplicationLimit": {
"value": "PassengerSegment"
}
}
},
{
"@type": "CatalogOffering",
"id": "anc_off2",
"ProductOptions": [
{
"@type": "ProductOptions",
"Product": [
{
"@type": "ProductAncillary",
"id": "an2",
"Quantity": 1,
"Ancillary": {
"@type": "AncillaryAirBaggage",
"Description": [
{
"code": "BG",
"subCode": "0C4",
"value": "EXTRA 25KG FOR KG ALLOWANCE"
}
],
"FlightRef": [
"s1"
]
}
}
]
}
],
"Price": {
"@type": "PriceDetail",
"CurrencyCode": {
"value": "AUD"
},
"Base": 312.5,
"TotalTaxes": 31.25,
"TotalPrice": 343.75,
"PriceBreakdown": [
{
"@type": "PriceBreakdownAncillaryAir",
"Amount": {
"@type": "Amount",
"Taxes": {
"@type": "TaxesDetail",
"Tax": [
{
"taxCode": "UO",
"value": 31.25
}
]
}
}
}
]
},
"TermsAndConditions": {
"@type": "TermsAndConditionsAncillary",
"ExpiryDate": "2049-12-12T00:00:00Z",
"ApplicationLimit": {
"value": "PassengerSegment"
}
}
},
{
"@type": "CatalogOffering",
"id": "anc_off3",
"ProductOptions": [
{
"@type": "ProductOptions",
"Product": [
{
"@type": "ProductAncillary",
"id": "an3",
"Quantity": 1,
"Ancillary": {
"@type": "AncillaryAirBaggage",
"Description": [
{
"code": "BG",
"subCode": "0C7",
"value": "EXTRA 35KG FOR KG ALLOWANCE"
}
],
"FlightRef": [
"s1"
]
}
}
]
}
],
"Price": {
"@type": "PriceDetail",
"CurrencyCode": {
"value": "AUD"
},
"Base": 437.5,
"TotalTaxes": 43.75,
"TotalPrice": 481.25,
"PriceBreakdown": [
{
"@type": "PriceBreakdownAncillaryAir",
"Amount": {
"@type": "Amount",
"Taxes": {
"@type": "TaxesDetail",
"Tax": [
{
"taxCode": "UO",
"value": 43.75
}
]
}
}
}
]
},
"TermsAndConditions": {
"@type": "TermsAndConditionsAncillary",
"ExpiryDate": "2049-12-12T00:00:00Z",
"ApplicationLimit": {
"value": "PassengerSegment"
}
}
}
],
"TravelerIdentifierRef": [
{
"passengerTypeCode": "ADT",
"id": "travelerRefId_1"
}
]
}
],
"Identifier": {
"authority": "Travelport",
"value": "238ef294-4d0f-4d6f-838e-154ddaf2c7be_PC"
},
"ReferenceList": [
{
"@type": "ReferenceListFlight",
"Flight": [
{
"@type": "Flight",
"carrier": "QF",
"number": "406",
"operatingCarrier": "QF",
"operatingCarrierName": "Qantas Airways",
"id": "s1",
"Departure": {
"@type": "Departure",
"location": "MEL",
"date": "2024-12-20",
"time": "06:30:00"
},
"Arrival": {
"@type": "Arrival",
"location": "SYD",
"date": "2024-12-20",
"time": "07:55:00"
}
}
]
}
]
}
}