Overview
Take advantage of the new Merchandising API to identify deals more easily and benefit from machine learning techniques
Leverage machine learning to help you identify the most relevant deals and discounts for travelers from Expedia Group’s vast, global promotions inventory. By using the Merchandising API, you can access a variety of campaign content and deals with data to build out a winning year-long strategy and traveler-facing experiences such as promotional emails, app widgets, website banners, and carousel experience.
We have also added a new app in the Partner Portal that you can use to build your merchandising strategies and plan, execute, and track campaigns. This app is located in a new section called the Portal Marketing Hub. Please reach out to your account manager for more information.
Campaign content endpoint
- Delivers upcoming campaign details including campaign ID, booking and stay start and end dates, and number of properties participating.
- Enables direct access to Expedia-curated campaign assets such as campaign thematic images, destination imagery, suggested copy, etc.
- Receive information about limited time offer (LTO) campaigns with a booking window within the next six months as well as evergreen campaigns available throughout the year.
You can use the Campaign Content endpoint to search upcoming campaigns using request parameters including:
- Bookable date range
- Stay date range
- At or above values for minimum discount
- LTO versus evergreen offers
For LTO campaigns with a booking window beyond six months, the following fields will be excluded:
- Booking and travel dates
- Min and max discount %
Other details
The Campaign Content endpoint can help you leverage Expedia-curated assets to create traveler-facing merchandising experiences such as promotional emails, app widgets, website banners, etc.
You can use the property_count field in the Campaign Content response to determine the most up-to-date number of properties providing deals within a campaign. We recommend you check the property_count close to the campaign booking start date since property participation in merchandising campaigns is dynamic and participation from properties tends to be most complete and reliable as the campaign launch approaches.
Promotions endpoint
- Delivers all available deals and discounts associated with a specific campaign.
- Ability to search and filter deals with the help of multiple request parameters, including the ability to request deals for a specific campaign or across multiple campaigns.
- Enables you to always surface the most up-to-date, appealing property deals to build a high-converting campaign.
You can use the Promotions endpoint to easily filter and search for deals using request parameters such as:
- Campaign ID and/or property ID
- Bookable date range
- Stay date range
- At or above values for minimum review score, minimum star rating, and/or minimum discount
- Limited time vs evergreen distinction
- Member-only and mobile-only deal flags
- Super region or specific destinations
- Machine learning relevancy score sort order
The below details will be returned in the Promotions API response:
- Deal ID, corresponding campaign ID, and property ID
- Bookable date range, stay date range, blackout dates, and advance purchase window
- Limited time vs. evergreen distinction
- Machine learning-powered relevancy scores unique to your business for the deals, properties, and destinations returned in the response
- Specific destinations and chain ID information
- Tokenized link to the existing Rapid Property Content API to pull property-level imagery to feature in your merchandising experiences
Other details
You can easily search and filter the Promotions response for more targeted deals, so you have full control over what deals you surface to travelers. You can also curate these deals to build your own campaign themes instead of using Expedia-defined campaigns and associated assets.
If you want to search deals for a set booking window you can pass values for both bookable_start and bookable_end date. For example, by passing 2025-10-15 (October 15th 2025) in the bookable_start field and passing 2025-10-30 (October 30th 2025) in the bookable_end field, you will receive all deals that are bookable between October 15th and October 30th inclusive. However, if you who want to see a larger set of deals you can use either bookable_start or bookable_end date.
For example:
- By passing 2025-10-15 (October 15th 2025) in the - bookable_startfield, you will receive all deals that are bookable on and after October 15th. This will provide a larger set of deals.
- By only passing 2025-10-30 (October 30th 2025) in the - bookable_endfield, you will receive all deals that are bookable on and before October 30th. Again, this will provide a larger set of deals.
Deals go live (i.e. become available to book) according to the property's time zone. So, if a deal starts on 21st March for a property in Sydney, Australia, the deal will become live for booking at 12:01am Sydney time for all partners in the world.
You can use the include request parameter on the Promotions endpoint to customize the size of the response you receive. So instead of receiving all response fields, if you only need a few fields returned, you can add those specific field names in the include parameter.
You can start making requests to the promotions API in advance but should also request as close to the campaign bookable start date as possible for the most accurate and up-to date representation of the deals from properties. This is because participation from properties tends to be most complete and reliable as the campaign launch approaches.
We also suggest you request promotions a few days after the campaign starts such that you always get the refreshed latest deals list. Additionally, we suggest you request the promotions API daily to get a refreshed and latest list of deals provided by properties.
If you’re interested in building destination-based merchandising campaigns, you can make a region-specific Promotions API request using the relevant region_id from the Rapid Geography API. The only region type accepted by the promotions endpoint is city. Other region types such as multi_city_vicinity, point_of_interest, neighbourhood, etc. will return a blank response.
Machine learning recommendations
The Machine learning-powered relevancy scores delivered in the Promotions response are unique to each organization, so the score/rankings you receive will differ from what anyone else receives. You can use the machine learning recommendations to identify the best deals, properties, and destinations to promote in your merchandising campaigns. Higher-scoring deals, properties, and destinations will have a likelihood of driving conversion among your unique traveler base.
Currently, you will receive relevancy scores for the top 10k deals in each campaign. In our testing, we found the value and impact of this score became negligible beyond the first 10k deals.
Based on your use case, you can use the sort_by parameter to define the sort order of the Promotions response, choosing to order based on deal, property, or destination relevancy as determined by our machine learning model for you to get the maximum value from merchandising in terms of visibility and bookings from the travelers.
- If you pass sort_by = promotionyou will receive all the deal results ranked high-to-low (1 to 10,000) per our proprietary machine learning algorithm. You can use this sort to get the top recommended deals that our model expects to convert more.
- If you pass sort_by = propertyyou will receive all the deal results from the properties ranked high-to-low per our proprietary machine learning algorithm.
- If you pass sort_by = destinationyou will receive all the deal results from the destinations ranked high-to-low per our proprietary machine learning algorithm.
Note: Machine learning recommendations are also available on the Portal Marketing Hub. Please reach out to your account manager for more details.
Changes made to the Shopping Availability API
To get the latest details on availability, live pricing, refundability, commissions info, etc. you should make a standard request to Rapid’s Shopping Availability API We have made the following changes to the Shopping API to support merchandising flows and make your integration of the Merchandising API as smooth as possible:
- Use the new dealfilter available in the Rapid Shopping Availability endpoint to only receive rates that feature active promotions. This gives you the flexibility to create a Shopping request with an exclusively merchandising focus and ensure that the all the rates returned have adealattribute.
- A new request header named Campaign-Idis available on Rapid’s Shopping Availability endpoint for you to indicate that the specific Shopping Availability API call you are making is not a regular call and it is in fact due to your merchandising promotional efforts (in other words, this will signify that a Shopping Availability API request was made as the traveler entered the Shop experience due to a campaign promotion). We will accept only one Campaign ID per Shopping API call. This Campaign ID is going to help us track your campaign performance and design better machine learning models and API enhancements for you.
- If you want to see your campaign performance on the Portal Marketing Hub, you will need to pass the Campaign ID parameter in your Shopping API call. If you have any questions, please reach out to your account manager.
Note: You can request details from the Shopping Availability API for up to 250 properties at a time.
Example response
"promotions": {
. "deal": {
.   "id": "999abc",
.   "description": "Book early and save 15%"
. }
}Note: The id and description available in the Merchandising API response are different to those returned in the Shopping API response. We strongly advise that you use the id and description returned by the Merchandising API.
API details
Explore the merchandising-related endpoint definitions on this page, then use the API Explorer or another testing software to get an understanding of how the examples and schema definitions compare to the actual output.
Additional resources
Whether you're looking to try out all the Rapid API endpoints or to download its OpenAPI specs or our Postman collection, we have you covered.