Versions
v3
Flights
Initiating Search

Getting Started with Flight Search

This page covers the essential information needed to get started with Flight Search using the ORX API. We'll explain how to use the POST /flight/search endpoint to search for flights, what the required payload is, what the expected response looks like, and how to manage your session.

Search for Flights

POST /flight/search

This endpoint specifies the criteria for your flight search. It will return a session public ID that you can use to manage your itinerary, including adding flights, passengers, and more.

Payload

The payload for POST /flight/search should include the following:

{
  "queries": [
    {
      "departure_airport": "LAX",
      "arrival_airport": "YVR",
      "departure_date": "2033-03-26"
    },
    {
      "departure_airport": "YVR",
      "arrival_airport": "LAX",
      "departure_date": "2033-03-28"
    }
  ],
  "passengers": [
    {
      "code": "ADT"
    },
    {
      "code": "CHD"
    }
  ]
}

This payload may include the following fields:

  • queries: An array of objects that represents the flight search query. The example above searches for flights from LAX to YVR on March 26th, 2023.

  • passengers: An array of objects that representing each passenger. The example above includes one adult passenger.

  • preferences: An object that represents additional search preferences. It could be used to specify a suppression method and discount codes. See advanced usage for more info.

Response

The response for POST /flight/search will include a session public ID that you can use to manage the entire itinerary. The response will look like this:

{
  "flow": "FLIGHT",
  "expireAt": "2023-03-25T01:37:28.949Z",
  "createdAt": "2023-03-24T23:37:28.949Z",
  "public": "14a010e5-6d9e-4acd-8979-625cb003ece8"
}

The public property is what you'll use to identify the session. You can retrieve the same information about your session using the GET /session endpoint.

Possible Errors

Status CodeErrorReason
400[VALIDATION ERROR]Failed Validation
500NDCx Internal ErrorUnknown

Advanced Usage

You can also pass in additional search preferences in the preferences object in the payload.

{
  "queries": [
    //query
  ],
  "passengers": [
    //versions/v3/passengers
  ],
  "preferences": {
    "suppression": "NO_SUPPRESSION",
    "discount_codes": ["discount"]
  }
}

🛎 Note that these preferences will override your default settings. We recommend only customizing these if you have a specific need.

Suppression

The suppression property controls duplicate suppression for the search results. It can take one of the following values:

  • FIRST_BOUND: This is the default behavior and will remove duplicates based on the first bound found.
  • REDEMPTIVE: This will remove duplicates based on all bounds.
  • NO_SUPPRESSION: This will not suppress duplicate flights at all.

Discount Codes

he discount_codes property can accept an array or a single string.

"preferences": {
    "discount_codes": ["discount"]
}

🛎 We recommend only using proper values as discount codes, as some sources will deny any response for invalid codes.