Product management
ReferenceProduct management

createRatePlan mutation

Creates a rate plan for a property. When a rate plan is created, it is associated with a unit, cancellation policy, and fee set.

Best practices when creating rate plans

  • Compensation When a new rate plan is created, Expedia Group automatically attaches the compensation to the rate plan based on what is defined in the contractual agreement with Expedia Group. As such, compensation will not need to be directly managed when creating a rate plan.

  • Rate plan targeting Rate plans can be targeted to specific travelers, including those in specific geographic regions, mobile app users, and members. For targeting geographic regions, a 3-letter country code or super region must be provided along with an indication that these regions are “Available” or “Unavailable”. Additional targeting is permitted based on contractual agreements with Expedia Group. Contact your account manager, if applicable, for more information on how to use this additional targeting.

  • B2B distribution and business rates Expedia Group offers B2B distribution rate plans, which are distributed across Expedia’s distribution partner network. Expedia Group also offers business rate plans, which are distributed to business and corporate travelers. Program terms and conditions must be signed first in order to create and use these rate plans.

  • Value adds In the legacy Product API, up to three distinct value adds can be included for a given rate plan. With the introduction of this capability, there is no limit to the number of value adds that can be included for a given rate plan.

Sending the correct rate type

Expedia Group accepts sell rate, net rate, or lowest available rate (LAR or Sell LAR) for rate updates. Rate acquisition type settings are confirmed at the property level and cannot be modified with this capability. Refer to Rate acquisition to learn more about the type of rate to send to Expedia Group. The rates sent must be in sync with the configuration in our system. Verify which type of rate is being used using the property query.

Units and rate plans available for properties using the Expedia Traveler Preference business model are available to travelers with both the "pay now" at the time of booking (Expedia Collect) and "pay later" at the hotel (Hotel Collect) options.

Identifying a property's business model

To identify whether a property has Expedia Traveler Preference enabled, retrieve inventoryConfig : businessModels using the property query.

Identifying Expedia Traveler Preference rate plans

When properties opt into the program, at least one of their standalone rate plans must be enabled for the Expedia Traveler Preference program. This translates into having two different business models configured for each rate plan. For example, when retrieving a rate plan enabled for the program, something like this should be returned:

1-need example-

Creating Expedia Traveler Preference rate plans

When a property opts into the program, all of its standalone rate plans must be enabled for Expedia Traveler Preference. The minimum information needed to create an Expedia Traveler Preference-enabled rate plan is two distribution rules, along with a partner code for each. The partner code does not have to be different between the Expedia Collect and Hotel Collect rules, but it has to be unique across all the rate plans under the unit it belongs to.

Example:

1-need example-

If two distinct rate plans are used to support the Expedia Traveler Preference program, these will need to be combined into one rate plan creation request to Expedia Group. The codes for their Expedia Collect and Hotel Collect versions should be provided under the appropriate distribution rules. Then, Expedia Group’s response is consumed and the returned Expedia rate plan IDs are mapped and returned (resource ID) as part of each distribution rule. These IDs will also be used to interpret booking messages or push availability/rate messages to Expedia Group.

Updating rate plans to require deposits

The Deposit API enables you to create, read, or update a deposit policy for a given property. To indicate the rate plans that should make use of a deposit policy, set the paymentScheduleApplicable field (on the agencyModelConfig input object) to “true”.

Note: It is important to know that only Hotel Collect or Expedia Traveler Preference (Hotel Collect/Expedia Collect) rate plans can be updated to require a deposit.

Syntax

1mutation {
3}

Example

1mutation {
2 createRatePlan(
3 input: {
4 clientMutationId: "Dilp_rp"
5 propertyId: 4112478
6 unitId: 318413944
7 name: "Dilip_RatePlan_3"
8 type: PACKAGE
9 cancellationPolicyConfigId: 450074950
10 pricingModel: PER_DAY_PRICING_BY_LENGTH_OF_STAY
11 baseRateGuestCount: 1
12 merchantModelConfig: {
13 taxInclusive: true
14 supplierCode: "101"
15 }
16 restrictions: {
17 reservationDates: { from: "2024-08-01", to: "2024-08-15" }
18 travelDates: { from: "2024-10-01", to: "2024-12-31" }
19 advanceBookingDays: { min: 7, max: 30 }
20 lengthOfStay: { min: 2, max: 7 }
21 membershipOnly: true
22 mobileOnly: true
23 regions: {
24 regionIds: ["USA", "NORAM"]
25 type: AVAILABLE
26 }
27 channels: {
28 channelRestrictionCodes: ["amex-fhr", "amex-thc", "mobile-app", "negotiated-hilton-getaways", "amex-gbt-distribution-unavailable"]
29 }
30 }
31 valueAdds:[]
32 }
33 ) {
34 clientMutationId
35 ratePlan {
36 propertyId
37 unitId
38 id
39 name
40 type
41 pricingModel
42 baseRateGuestCount
43 status
44 merchantModelConfig: {
45 ratePlanCode
46 taxInclusive
47 }
48 agencyModelConfig: {
49 ratePlanCode
50 paymentScheduleApplicable
51 agencyRatePlanId
52 }
53 restrictions {
54 reservationDates {
55 from
56 to
57 }
58 travelDates {
59 from
60 to
61 }
62 advanceBookingDays {
63 min
64 max
65 }
66 lengthOfStay {
67 min
68 max
69 }
70 membershipOnly
71 mobileOnly
72 regions {
73 regionIds
74 type
75 }
76 channels {
77 channelRestrictionCodes
78 }
79 }
80 cancellationPolicyConfig {
81 id
82 name
83 }
84 feeSet {
85 id
86 }
87 valueAdds
88 }
89 }
90}

Arguments

NameDescription

input

Required.
Type: CreateRatePlanInput

Types


Name
Type
AcceptedPaymentForms
Object

Default payment forms that are permitted for the property manager.

FieldDescription
paymentCardDescriptorsNot nullable.

Information about the accepted credit cards.

Type: Array of non nullable PaymentCardDescriptor
paymentInvoiceDescriptorsNot nullable.

Information about the invoice payment type.

Type: Array of non nullable PaymentInvoiceDescriptor
AcknowledgementRecord
Object

Acknowledgement record for a bookable unit.

FieldDescription
acknowledgementType

Type of acknowledgement record.

Type: AcknowledgementType
id

ID of the acknowledgement record.

Type: String
lastUpdated

Date when the acknowledgment record was last updated.

Type: String
AcknowledgementType
Enum

Acknowledgement type values.

NameDescription
PLATFORM
LTR_POLICY
PLATFORM_ACK
PLATFORM_ACK_STATEMENT
PLATFORM_ATTESTATION
PLATFORM_ATTESTATION_LEGAL
PLATFORM_ATTESTATION_LINK
PLATFORM_ATTESTATION_NEVADA
PLATFORM_ATTESTATION_VER
PLATFORM_CERTIFY
PLATFORM_COMPLY
PLATFORM_JAPAN
PLATFORM_LEGAL
PLATFORM_READ
ActiveStatus
Object

Status of the property, including its checkpoints.

FieldDescription
activeNot nullable.

Whether the property is live on Expedia sites. An Expedia property is inactive if one of these conditions is true:

  • Payment issues or overdue invoices
  • Compliance issues due to regulatory or tax mandates
  • Recontracting or change of ownership
  • Incomplete onboarding
  • Renovations
Type: Boolean
statusCheckpointNot nullable.

Top-level property status derived from supporting checkpoints. Use this to determine if the property is inactive for reasons that are not content related.

Type: StatusCheckpoint
AdditionalDataRequirement
Object

Additional parameters to meet onboarding requirements.

FieldDescription
group

Grouping to which the field belongs, for UI layout purposes.

Type: String
groupLocalized

Description of the group, to be localized.

Type: String
isOptional

Whether the data is optional.

Type: String
keyNot nullable.

Field name for the information to be captured.

Type: String
keyLocalized

Description of the key, to be localized.

Type: String
subtype

Subtype of data.

Type: String
subtypeLocalized

Description of the subtype, to be localized.

Type: String
type

Type of data.

Type: String
typeLocalized

Description of the type, to be localized.

Type: String
Address
Object

Property address information.

FieldDescription
addressLinesNot nullable.

Lines that describe the physical street address.

Type: Array of non nullable String
administrativeArea

State or province of the property.

Type: String
countryCodeNot nullable.

Three-character ISO-3166-1 country code.

Type: CountryCode
localityNot nullable.

City or locality where the property is located.

Type: String
postalCodeNot nullable.

Postal code of the address.

Type: String
AgeCategory
Enum

Age categories of guests allowed in a reservation.

NameDescription
ADULT
CHILD_A
CHILD_B
CHILD_C
CHILD_D
INFANT
AgencyModelConfig
Object

Details about the Hotel Collect (agency) model configured on the rate plan.

FieldDescription
agencyRatePlanIdNot nullable.

Rate plan ID.

Type: ID
paymentScheduleApplicableNot nullable.

Whether a payment schedule (deposit) is required upon booking. This flag is only available for rate plans with the Hotel Collect or Expedia Traveler Preference business models.

Type: Boolean
supplierCodeNot nullable.

Supplier's rate plan code.

Type: String
AggregatedReviewBrandScore
Object

Rating details by brand (website) where the reviews were collected.

FieldDescription
brandNameNot nullable.

Brand to which the aggregated score belongs.

Type: ReviewBrand
categoriesWithScoreNot nullable.

Aggregated (average) rating for each category of the review.

Type: Array of non nullable ReviewCategoryScore
totalReviewsCountNot nullable.

Total number of reviews collected.

Type: Int
AggregatedReviewsFiltersInput
InputObject

Parameters to filter aggregated ratings.

FieldDescription
brandNamesNot nullable.

Brands (websites) where the reviews were collected.

Type: Array of non nullable ReviewBrand
AggregatedReviewsResponse
Object

Details about the aggregated ratings.

FieldDescription
brandsWithScoresNot nullable.

Details by brand (website) where the reviews were collected.

Type: Array of non nullable AggregatedReviewBrandScore
AmenitiesFiltersInput
InputObject

Filter for results based on amenity availability or name.

FieldDescription
available

Whether the results should include available amenities.

Type: Boolean
keys

Amenities name on which to filter results.

Type: OneOfStringFilterInput
Amenity
Object

Key-value pair that defines the amenity.

FieldDescription
keyNot nullable.

Amenity name.

Type: String
valueNot nullable.

Amenity attributes.

Type: AmenityValue
AmenityField
Object

Details about the amenity attribute.

FieldDescription
keyNot nullable.

Attribute name.

Type: String
typeNot nullable.

Attribute value's type.

Type: String
valueNot nullable.

Attribute value.

Type: AmenityFieldValue
AmenityFieldFeeType
Enum

Fee type values for amenities.

NameDescription
FREE
SPECIFIC_AMOUNT
UNSPECIFIED_AMOUNT
AmenityFieldFeeValue
Object

Fee type of an amenity.

FieldDescription
typeNot nullable.

Fee type of an amenity.

Type: AmenityFieldFeeType
AmenityFieldMeasurementValue
Object

Amenity measurement value and unit.

FieldDescription
unitOfMeasureNot nullable.

Type of measurement.

Type: String
valueNot nullable.

Value (size).

Type: String
AmenityFieldValue
Object

Amenity field value.

FieldDescription
feeValue

Fee value; used for field type fee. Allowed values include FREE and UNSPECIFIED_AMOUNT.

Type: AmenityFieldFeeValue
measurementValue

Measurement value.

Type: AmenityFieldMeasurementValue
textValue

Text value; used for field type text.

Type: Array of non nullable LocalizedString
value

Field value used for these field types: enum, string, trilean, int, and decimal. When the amenity type is trilean and the value is set to true, the amenity is included on the PDP. When set to false, the amenity definition is stored but disabled it on the PDP, similar to how amenities are disabled using AmenityValueInput : available.

Type: String
AmenityValue
Object

Amenity attributes.

FieldDescription
availableNot nullable.

Whether the amenity is available. false indicates that the amenity is defined but disabled (not shown to travelers).

Type: Boolean
fieldsNot nullable.

Amenity attributes.

Type: Array of non nullable AmenityField
ApplicableRegulations
Object

Additional registration information required by some districts.

FieldDescription
key

Identifier for additional information required by the district.

Type: ApplicableRegulationsKey
value

Value of the key required by the district.

Type: String
ApplicableRegulationsKey
Enum

Regulation key values.

NameDescription
LICENSE_DEPARTMENT_NAME

Name of the department in the issuing government body that approved the attribute (registration number).

LICENSE_GOVERNMENT_NAME

Name of the government body that issued the attribute.

LICENSE_HOLDER_NAME

Name of the person (holder) who holds the license, which may be different from the lodging partner.

LICENSE_HOLDER_STREET_ADDRESS_1

Street address of the person (holder) who holds the license, which may be different from the lodging partner.

LICENSE_HOLDER_STREET_ADDRESS_2

Secondary street address of the person (holder) who holds the license, which may be different from the lodging partner.

LICENSE_HOLDER_CITY

City of the person (holder) who holds the license, which may be different from the lodging partner.

LICENSE_HOLDER_PREFECTURE

Prefecture of the person (holder) who holds the license, which may be different from the lodging partner.

LICENSE_HOLDER_COUNTRY

County of the person (holder) who holds the license, which may be different from the lodging partner.

LICENSE_HOLDER_POSTAL

Postal code of the person (holder) who holds the license, which may be different from the lodging partner.

IS_VACATION_RENTAL
REGISTRATION_NUMBER
REGISTRATION_NUMBER_TYPE
AreaUnit
Enum

Unit of measure used to indicate the size of a property's unit.

NameDescription
SQUARE_FEET
SQUARE_METERS
AttachmentType
Enum

Exemption category types.

NameDescription
DRIVERS_LICENSE
AttachmentUrl
Object

Registration document information.

FieldDescription
key

Type of document referenced.

Type: AttachmentType
value

URL of the registration document file.

Type: String
AvailabilityRestrictionType
Enum

Values for availability restriction type.

NameDescription
AVAILABLE
UNAVAILABLE
BedGroup
Object

Bed types offered in the room. Vacation rentals are limited to a single bed group with multiple bed types. Conventional lodging may have two bed groups to represent alternatives. For example, a hotel might have a room type with 1 king bed or 2 full beds.

FieldDescription
bedsNot nullable.

Bed types offered in the room.

Type: Array of non nullable BedType
Bedroom
Object

Details about this bedroom.

FieldDescription
bedGroupsNot nullable.

Bed types offered in the room.

Type: Array of non nullable BedGroup
idNot nullable.

ID of this bedroom.

Type: ID
orderNot nullable.

Where the bedroom appears in the list of bedrooms (minimum value is 1).

Type: Int
text

Text that describes this bedroom.

Type: Array of non nullable Text
BedType
Object

Details about the bed.

FieldDescription
quantityNot nullable.

Number of beds in the bed group.

Type: Int
size

Bed size, such as FULL, KING, or TWIN.

Type: String
typeNot nullable.

Bed type, such as KINGBed or SofaBed.

Type: String
BlackoutDateRange
Object
FieldDescription
travelDateFromNot nullable.

Travel start date for the exception (blackout) window in the YYYY-MM-DD format.

Type: LocalDate
travelDateToNot nullable.

Travel end date for the exception (blackout) window in the YYYY-MM-DD format.

Type: LocalDate
BookingLocalDateTimeInput
InputObject

Information about the booking date and time.

FieldDescription
from

Beginning date of the booking window (in the YYYY:MM:DDThhh:mm:ss format, in the property’s local time zone).

Type: LocalDateTime
to

End date of the booking window (in the YYYY:MM:DDThhh:mm:ss format, in the property’s local time zone).

Type: LocalDateTime
BookingPolicy
Object

Details about accepted payment types and the booking type supported by the property manager.

FieldDescription
acceptedPaymentForms

Default payment forms that are permitted for the property manager.

Type: AcceptedPaymentForms
allowedAgeCategoriesNot nullable.

Age categories of guests allowed in a reservation.

Type: Array of non nullable AgeCategory
bookingType

Default booking policy for the lodging partner - INSTANT or QUOTEHOLD. With INSTANT, the reservation is immediately confirmed and no action is required by the partner. With QUOTEHOLD, the reservation is not confirmed until the partner manually confirms the reservation in their software.

Type: String
cancellationTimeNot nullable.

Time of day when a cancellation must be processed before cancellation charges apply.

Type: LocalTime
cutoffDayNot nullable.

Day when the property makes its inventory available after which same-day bookings can occur.

Type: CutoffDayType
cutoffTimeNot nullable.

Time on the cutoffDay when the property makes its inventory available after which same-day bookings can occur.

Type: LocalTime
Boolean
Boolean

The Boolean scalar type represents true or false.

BusinessModel
Enum

Entity that collects payment.

NameDescription
EXPEDIA_COLLECT

Expedia collects payment.

HOTEL_COLLECT

Property collects payment.

CancellationPenaltyRule
Object

Penalty type and amount.

FieldDescription
applicabilityNot nullable.

The booking value to which the cancellation penalty is applied.

Type: CancellationPenaltyRuleApplicability
flatAmount

Penalty amount for a flat amount penalty.

Type: Money
numberOfNights

Number of nights for which the penalty is applied.

Type: Int
percentage

Percentage of the total booking amount that is charged as a penalty. Represented as a fraction of 1 (for example,: 15% should be represented as 0.15). Note that to charge 100% penalty, specify 0.00.

Type: Decimal
typeNot nullable.

How the cancellation penalty is applied.

Type: CancellationPenaltyRuleType
CancellationPenaltyRuleApplicability
Enum

Line item in the rental fee to which the cancellation penalty is applied.

NameDescription
BOOKING_TOTAL
CLEANING_FEE
DEPOSIT
CancellationPenaltyRuleType
Enum

How the cancellation penalty (fee) is applied.

NameDescription
FLAT_AMOUNT
NUMBER_OF_NIGHTS
PERCENTAGE
CancellationPolicy
Object

Default policy types and tiers (cancellation window and penalty rules) for which they are applied.

FieldDescription
tiers

Penalty or penalties applied based on cancellation window.

Type: Array of non nullable CancellationPolicyTier
typeNot nullable.

Type of cancellation policy (enforcement level), such as STRICT or MODERATE.

Type: CancellationPolicyType
CancellationPolicyCancellationWindow
Object

Policy period (number of days, hour, or weeks before the check-in date that a cancellation can be done).

FieldDescription
cutoffNot nullable.

Number of days, hours, or weeks before the check-in date to which this policy applies (non-zero integer).

Type: Int
temporalUnitNot nullable.

Time unit of the cutoff.

Type: CancellationWindowTemporalUnit
CancellationPolicyConfig
Object

Cancellation policy defined for the property.

FieldDescription
additionalCancellationFee

Fee charged to the traveler when the reservation is cancelled. This is supported for custom cancellation policies only.

Type: Money
defaultPoliciesNot nullable.

Policy types and tiers (cancellation window and penalty rules) for which they are applied.

Type: Array of non nullable CancellationPolicy
idNot nullable.

Policy ID. Be sure to store this ID when creating the policy in case it needs to be modified later.

Type: ID
nameNot nullable.

Policy name.

Type: String
overridePoliciesNot nullable.

Policy overrides, which define cancellation parameters for specific dates (also referred to as "seasonal cancellation policies").

Type: Array of non nullable CancellationPolicyOverride
property

Property details.

Type: Property
CancellationPolicyDateRange
Object

Date range to which the cancellation policy is applied. Dates are closed and inclusive.

FieldDescription
fromNot nullable.

Beginning date to which the policy is applied.

Type: Date
toNot nullable.

End date to which the policy is applied.

Type: Date
CancellationPolicyOverride
Object

Policy overrides (seasonal cancellation policies), which define policy parameters for specific date ranges.

FieldDescription
cancellationPolicyNot nullable.

Policy types and tiers (cancellation window and penalty rules) for which they are applied.

Type: CancellationPolicy
dateRangesNot nullable.

Data range to which the policy applies.

Type: Array of non nullable CancellationPolicyDateRange
CancellationPolicyTier
Object

Penalty or penalties applied based on cancellation window.

FieldDescription
cancellationWindowNot nullable.

Policy period (number of days, hour, or weeks before the check-in date that a cancellation can be done).

Type: CancellationPolicyCancellationWindow
penaltyRulesNot nullable.

Penalty type and amount that is applied to the total booking amount for the specified policy period.

Type: Array of non nullable CancellationPenaltyRule
CancellationPolicyType
Enum

The enforcement levels for the cancellation policy are as follows. Note that the traveler must cancel the reservation by 11:59 PM (property’s local time) of the cut-off day in order to receive the specified refund amount.

NameDescription
CUSTOM

Terms of the policy are defined by the custom policy.

FIRM

100% refund if reservation is cancelled at least 60 days before the arrival date, 50% refund if reservation is cancelled at least 30 days before the arrival date.

MODERATE

100% refund if reservation is cancelled at least 30 days before the arrival date, 50% refund if reservation is cancelled at least 14 days before the arrival date.

NO_REFUND

No refund.

RELAXED

100% refund if reservation is cancelled at least 14 days before the arrival date, 50% refund if reservation is cancelled at least 7 days before the arrival date.

STRICT

100% refund if reservation is cancelled at least 60 days before the arrival date.

CancellationWindowTemporalUnit
Enum

Time unit used for the cancellation window.

NameDescription
DAY
HOUR
WEEK
ChannelRestrictionsInput
InputObject

Channel restrictions that are applied to the rate plan being created.

FieldDescription
channelRestrictionCodesNot nullable.
Type: Array of non nullable String
CheckOutDateFilter
InputObject

Checkout date window for which to filter reservations. You can query for reservations up to 465 days in the past and up to 500 days in the future.

FieldDescription
fromNot nullable.

Date that defines the start of the checkout date window (format: YYYY-MM-DD).

Type: LocalDate
toNot nullable.

Date that defines the end of the checkout date window (format: YYYY-MM-DD).

Type: LocalDate
CheckpointFilterInput
InputObject

Parameters to filter checkpoints.

FieldDescription
result

Fulfillment status.

Type: Array of non nullable ResultFilter
Compliant
Object

Compliance status for mandatory requirements only (at the unit level) according to the local jurisdiction's regulatory requirements. If invalid information is provided for an optional regulatory requirement, or if regulatory information is set in a jurisdiction that does not require regulatory information, status: COMPLIANT is returned. For optional requirements, a warning is returned in the warningStatus field of the updateUnitRegistration mutation's payload.

FieldDescription
reasonNot nullable.

Reason why the unit is in or out of compliance. The label used for the registration number in this string comes from the numberTypeLabel field on the RegistrationNumberRequirement type.

Type: String
statusNot nullable.

Whether the unit is compliant or not.

Type: RegulatoryStatus
Coordinates
Object

Geographical location coordinates.

FieldDescription
latitudeNot nullable.

Latitudinal coordinates of property.

Type: Float
longitudeNot nullable.

Longitudinal coordinates of property.

Type: Float
CountryCode
CountryCode

Scalar representing a country code using the ISO 3166-1 alpha-3 standard.

CreateAgencyModelConfigInput
InputObject

Details about the Hotel Collect (agency) model configured on the rate plan.

FieldDescription
paymentScheduleApplicableNot nullable.

Whether a payment schedule (deposit) is required upon booking. This flag is only available for rate plans with the Hotel Collect or Expedia Traveler Preference business models.

Type: Boolean
supplierCodeNot nullable.

Supplier's rate plan code.

Type: String
CreateMerchantModelConfigInput
InputObject

Details about the Expedia Collect (merchant) model configured on the rate plan.

FieldDescription
supplierCodeNot nullable.

Supplier's rate plan code.

Type: String
taxInclusiveNot nullable.

Whether the rate includes taxes. For properties managing net rates, the default value is false. For properties managing sell rates, this is based on the property's configuration.

Type: Boolean
CreateRatePlanInput
InputObject

Details about the rate plan, including the unit, cancellation policy, and fee set to associate it with.

FieldDescription
agencyModelConfig

Hotel Collect configuration parameters. Specify these input parameters if payment is collected by the property.

Type: CreateAgencyModelConfigInput
baseRateGuestCount

Maximum occupants allowed for the base rate per day. Minimum value is 1, maximum value is 20. This is only applicable for per-day pricing properties, and is required in create requests.

Type: Int
cancellationPolicyConfigIdNot nullable.

ID of the cancellation policy that is associated with this rate plan.

Type: ID
clientMutationId

Partner's transaction ID that uniquely identifies the request, which can be used to associate requests and responses for troubleshooting purposes. This ID must be unique across requests and cannot be reused. However, if a request needs to be retried, such as because it failed or timed out, the ID provided in the original request should be used. The ID can be in any format as long as it uniquely identifies the request.

Type: ID
feeSetId

ID of the fee set that is associated with this rate plan.

Type: ID
merchantModelConfig

Expedia Collect configuration parameters. Specify these input parameters if Expedia collects payment for reservations.

Type: CreateMerchantModelConfigInput
nameNot nullable.

Rate plan name.

Type: String
pricingModelNot nullable.

Rate plan pricing model; must match the property's pricing model.

Type: PricingModel
propertyIdNot nullable.

ID of the property where the unit is located.

Type: ID
restrictions

Rate plan restrictions.

Type: CreateRatePlanRestrictionsInput
typeNot nullable.

Type of rate plan.

Type: RatePlanType
unitIdNot nullable.

Unit to associate the rate plan with.

Type: ID
valueAddsNot nullable.

Special features that are included with the rate, such as breakfast, internet, and parking.

Type: Array of non nullable String
CreateRatePlanPayload
Object

Payload after creating the rate plan.

FieldDescription
clientMutationId

Partner's transaction ID that identifies the request, which can be used to correlate with partner's transaction logs. This ID must be unique across requests and cannot be reused.

Type: String
ratePlan

Details about the rate plan that was created.

Type: RatePlan
CreateRatePlanRestrictionsInput
InputObject

Rate plan restrictions.

FieldDescription
advanceBookingDays

Minimum and maximum of days in advance of the booking that are required to make a reservation. Default range is 0-500 days.

Type: IntRangeInput
channels

Channels to which this rate plan is restricted.

Type: ChannelRestrictionsInput
lengthOfStay

Minimum and maximum number of days allowed for the length of stay. Default range is 1-28 days.

Type: IntRangeInput
membershipOnly

Whether the rate plan is restricted to members only.

Type: Boolean
mobileOnly

Whether this rate plan is applicable only to travelers booking on the mobile device.

Type: Boolean
regions

Regions to which the rate plan is restricted.

Type: RegionRestrictionsInput
reservationDates

Date range when the reservation can be made. If not restricted, start will be 1900-01-01 and end will be 2079-06-06.

Type: DateRangeInput
travelDates

Range of stay dates to which this rate plan applies. If not restricted, start will be 1900-01-01 and end will be 2079-06-06.

Type: DateRangeInput
Currency
Currency

Scalar representing an ISO4217 compliant currency.

CurrencyCode
CurrencyCode

Scalar that represents the three-letter currency code defined by the ISO 4217 standard.

CursorBasedPageInfo
Object

Information about the current page of results.

FieldDescription
endCursor

Value of the cursor of the last promotion in the current page.

Type: String
hasNextPageNot nullable.

Whether there are additional pages to retrieve.

Type: Boolean
CutoffDayType
Enum

Day when the property makes its inventory available after which same-day bookings can occur.

NameDescription
NEXT_DAY
SAME_DAY
Date
Date

Scalar that represents a date string compliant with the RFC 3339 profile of the ISO 8601 standard.

DateInput
InputObject

Date range used to filter reviews.

FieldDescription
fromNot nullable.

Beginning date in this format: YYYY-MM-DD.

Type: LocalDate
toNot nullable.

End date in this format: YYYY-MM-DD.

Type: LocalDate
DateRange
Object

Range of dates.

FieldDescription
fromNot nullable.

Beginning date in the range, in this format: YYYY-MM-DD.

Type: Date
toNot nullable.

End date in the range, in this format: YYYY-MM-DD.

Type: Date
DateRangeInput
InputObject

Range of dates.

FieldDescription
fromNot nullable.

Beginning date in the range, in this format: YYYY-MM-DD.

Type: Date
toNot nullable.

End date in the range, in this format: YYYY-MM-DD.

Type: Date
DateTime
DateTime

Scalar that represents a date-time string at UTC, such as 2007-12-03T10:15:30Z, compliant with the date-time format outlined in section 5.6 of the RFC 3339 profile of the ISO 8601 standard for representation of dates and times using the Gregorian calendar.

DateTimeRangeFilterInput
InputObject

Date and time range.

FieldDescription
fromNot nullable.

Beginning date of the date range.

Type: DateTime
operator

Whether the dates are inclusive or exclusive of the to/from dates.

Type: RangeOperator
toNot nullable.

Ending date of the date range.

Type: DateTime
DayOfWeekDiscount
Object

Day-of-week discounts enable partners to set discount percentages for specific days of the week. The day fields specify the discount for that day of the week for the travel dates (such as Mondays at 15%, Tuesdays at 10% discount).

FieldDescription
fridayNot nullable.
Type: Float
mondayNot nullable.
Type: Float
saturdayNot nullable.
Type: Float
sundayNot nullable.
Type: Float
thursdayNot nullable.
Type: Float
tuesdayNot nullable.
Type: Float
typeNot nullable.

Type of discount.

Type: DiscountType
unitNot nullable.

Unit of the discount. Currently, PERCENT is supported when creating or updating a discount. AMOUNT is supported for queries only.

Type: DiscountUnit
wednesdayNot nullable.
Type: Float
Decimal
Decimal

Scalar representing an arbitrary-precision and scale decimal number, serialized as a string.

Discount
Interface

Implemented by

FieldDescription
typeNot nullable.

Type of the discount.

Type: DiscountType
unitNot nullable.

Unit of the discount.

Type: DiscountUnit
DiscountPromotion
Object
FieldDescription
blackoutDates

Exception (blackout) dates for which the promotion should NOT apply. This field is only returned when querying for a single promotion (by specifying the promotion ID).

Type: Array of non nullable BlackoutDateRange
categoryNot nullable.

Category of the promotion. Currently, only DISCOUNT_PROMOTION is supported (such as Priced Promotions).

Type: PromotionCategory
codeNot nullable.

Promotion code that travelers will use to apply the promotion. This field is returned in our booking APIs if a reservation is created for a product that has an active promotion. It is returned in PromotionCode for the Booking Notification API and in promoName for Booking Retrieval API. Note that only these characters are supported: ​​a-z, A-Z, 0-9, ., ,, ', :, !, ?, $, %, (, ), /, -, and space.

Type: String
discount

Detail of the discount being applied on the promotion.

Type: Discount
eligibleRatePlansNot nullable.

Rate plans for which this promotion is applicable.

Type: Array of non nullable EligibleRatePlan
idNot nullable.

ID of the promotion stored in the Expedia platform.

Type: ID
isContractedPromotion

Whether the promotion is negotiated. (Negotiated promotions cannot be updated.)

Type: Boolean
nameNot nullable.

Name of the promotion.

Type: PromotionName
restrictions

List of restrictions that can be applied to these promotions.

Type: Restrictions
sellStatus

Whether the promotion is currently bookable based on the its reservation date/time range. This field is supported in queries only. All dates and times are relative to the property’s time zone. The promotion may still be unavailable due to other restrictions. At the time of querying, if the promotion's bookingLocalDateTimeFrom and bookingLocalDateTimeTo values are in the past but the travelDateFrom and travelDateTo values are in the future, the promotion is considered expired because the promotion can no longer be made available.

Type: PromotionSellStatus
statusNot nullable.

Status of the promotion.

Type: PromotionStatus
DiscountType
Enum

Discount type values.

NameDescription
DAY_OF_WEEK_DISCOUNT

Discount that is applicable for specific days of the week within the travel window.

MULTI_NIGHT_DISCOUNT

Discount that is applied to multi-night stays.

SINGLE_DISCOUNT

A single discount.

DiscountUnit
Enum
NameDescription
PERCENT

Percentage discount for the promotion.

AMOUNT

Amount-based discount for the promotion.

District
Object

District regulatory information.

FieldDescription
description

Description of the district regulation.

Type: String
idNot nullable.

District ID (such as Miami Beach).

Type: String
legalPropertyTypesNot nullable.

List of legal property types.

Type: Array of LegalPropertyType
localizedName

Localized district name that can be used for display.

Type: String
nativeLocale

Four-character locale code (language and country codes) of property's local district (such as fr_FR for a property in France).

Type: String
referenceUrls

URL to jurisdiction regulation information.

Type: Array of String
registrationRequiredNot nullable.

Whether registration is required by the jurisdiction. This is based on the geo code of the property’s address, not the property type (for example, registration may be required for a hotel but not a vacation rental in a specific area).

Type: Boolean
requirements

Jurisdiction regulations that the partner needs to meet to comply with onboarding to Expedia.

Type: Array of JurisdictionRequirement
EgBusinessModel
Enum

Business model used by the lodging partner.

NameDescription
AGENCY
MERCHANT
EligibleRatePlan
Object
FieldDescription
idNot nullable.

ID of the rate plan stored in the Expedia platform.

Type: ID
EmailAddress
EmailAddress

A field whose value conforms to the standard internet email address format as specified in HTML Spec.

Exemption
Object

Exemption to jurisdiction requirements.

FieldDescription
category

Exemption type.

Type: ExemptionCategory
description

Description of the exemption.

Type: String
ExemptionCategory
Enum

Exemption types.

NameDescription
MAX_NIGHT_CAP
ExpediaSupplierAmount
Object
FieldDescription
currencyCodeNot nullable.

Currency in which the amount is shown.

Type: String
ratesNot nullable.

Nightly rates for the reservation.

Type: Array of non nullable SupplierRate
rateTypeNot nullable.

Rate type: NET for Expedia Collect or SELL for Hotel Collect.

Type: RateType
totalNot nullable.

Total rates for the reservation.

Type: SupplierTotal
ExtraBedType
Object

Extra bed combination (type, size, quantity, and surcharge) that the unit provides.

FieldDescription
quantityNot nullable.

Number of extra beds.

Type: Int
sizeNot nullable.

Size of the bed.

Type: String
surcharge

Extra amount charged for the bed. Only extra beds of type 'CRIB' and 'ROLLAWAY_BED' will have a surcharge defined.

Type: Surcharge
typeNot nullable.

Type of bed.

Type: String
Fee
Object

Details about a fee.

FieldDescription
ageCategory

Age category to which the fee applies.

Type: FeeAgeCategory
categoryNot nullable.

Fee category.

Type: String
chargesNot nullable.

Amount, type, and duration of the fee.

Type: Array of non nullable FeeCharge
restrictions

Restrictions applied to the fee (dates or extra guests).

Type: FeeRestrictions
taxable

Whether the fee is taxable.

Type: Boolean
variesByLengthOfStay

Whether the fee changes based on length of stay.

Type: Boolean
FeeAgeCategory
Enum

Age category values.

NameDescription
ADULT
CHILD_A
CHILD_B
CHILD_C
CHILD_D
INFANT
FeeBusinessModel
Enum

Values for the property's business model.

NameDescription
AGENCY
MERCHANT
FeeCharge
Object

Amount, type, and duration of the fee.

FieldDescription
durationNot nullable.

Duration of time to which the fee is applied.

Type: FeeChargeDuration
flatAmount

Amount of the fee if applied as a flat amount.

Type: Money
percentage

Percentage of the rental amount if the fee is applied as a percentage.

Type: Decimal
typeNot nullable.

How the fee is applied (flat amount or percentage).

Type: FeeChargeType
FeeChargeDuration
Enum

Duration of time to which the fee is applied.

NameDescription
NIGHT
STAY
FeeChargeType
Enum

How the fee is applied (flat amount or percentage).

NameDescription
FLAT_AMOUNT
PERCENTAGE
FeeDateRange
Object

Date range when the fee is applied.

FieldDescription
fromNot nullable.

Start date of the date range.

Type: Date
to

End date of the date range.

Type: Date
FeeRestrictions
Object

Restrictions applied to the fee (dates or extra guests).

FieldDescription
dateRange

Date range restriction

Type: FeeDateRange
extraGuestRange

Number of guests (minimum and maximum) that are restricted.

Type: IntRange
FeeSet
Object

Details and fees that make up the fee set.

FieldDescription
businessModelNot nullable.

Business model used by the property.

Type: FeeBusinessModel
feesNot nullable.

One or more fees included in the fee set.

Type: Array of non nullable Fee
idNot nullable.

Fee set ID.

Type: ID
nameNot nullable.

Fee set name.

Type: String
FiltersInput
InputObject

Parameters used to filter results of the promotions query. Note that if you filter results by promotion ID, you cannot specify addition filters.

FieldDescription
bookingLocalDateTime

Reservation date and time being queries for. Format is YYYY-MM-DDThh:mm:ss, in the property’s local time zone.

Type: BookingLocalDateTimeInput
discountTypes

Type of the discount. Currently, only single discounts are supported (flat discount percentage, such as 15% off).

Type: Array of non nullable DiscountType
id

ID of the promotion stored in the Expedia platform.

Type: String
status

Status of the promotions.

Type: PromotionStatus
travelDate

Travel date window being queried for.

Type: TravelDateInput
Float
Float

The Float scalar type represents signed double-precision fractional values as specified by IEEE 754.

Guest
Object
FieldDescription
companyName

Name of the company that the guest works for.

Type: String
emailAddress

Guest's email address.

Type: EmailAddress
firstNameNot nullable.

Guest's first (given) name.

Type: String
lastNameNot nullable.

Guest's last name (surname).

Type: String
loyaltyTier

The traveler's Expedia Group VIP Access loyalty tier. These reservations often include value add promotions (VAPs), therefore it is important to associate this field and reservation:valueAddedPromotions in your systems so that end-users can properly identify loyal travelers and loyalty perks that the traveler is expecting. Values include MEMBER, VIP, PREMIUMVIP, and null. You must include this field to complete certification.

Type: String
phoneNumbers

The phone numbers of the guest.

Type: Array of non nullable GuestContactPhoneNumber
supplierLoyaltyPlanInfo

Details about the frequent traveler reward program. This field identifies if the traveler is a member of the supplier's loyalty program to ensure the supplier is able to greet the guest accordingly and award loyalty points as needed.

Type: SupplierLoyaltyPlanInfo
travelPurpose

Purpose of the guest's reservation.

Type: TravelPurpose
GuestContactPhoneNumber
Object

Guest phone number.

FieldDescription
areaCodeNot nullable.

Area code (three digits).

Type: String
countryCodeNot nullable.

Country code (two digits).

Type: String
numberNot nullable.

Phone number (seven digits, no hyphen).

Type: String
ID
ID

The ID scalar type represents a unique identifier, often used to refetch an object or as key for a cache. The ID type appears in a JSON response as a String; however, it is not intended to be human-readable. When expected as an input type, any string (such as "4") or integer (such as 4) input value will be accepted as an ID.

IdNode
Object

Known IDs in the source system.

FieldDescription
id

ID in the source system.

Type: ID
idSourceNot nullable.

Source of the ID.

Type: IdSource
IdNodeInput
InputObject

Reservation ID and its source.

FieldDescription
idNot nullable.

ID in the source system.

Type: ID
idSourceNot nullable.

Source of the ID.

Type: ReservationIdSource
IdSource
Enum

Source of a given ID.

NameDescription
EXPEDIA

Expedia is the source of the ID.

SUPPLIER

Connectivity provider or lodging partner is the source of the ID. This value is not supported for use in promotions.

VRBO

Unsupported.

Int
Int

The Int scalar type represents non-fractional signed whole numeric values. Int can represent values between -(2^31) and 2^31 - 1.

IntRange
Object

Range of integers.

FieldDescription
maxNot nullable.

Maximum integer value.

Type: Int
minNot nullable.

Minimum integer value.

Type: Int
IntRangeInput
InputObject

Range of integers.

FieldDescription
maxNot nullable.

Maximum integer value.

Type: Int
minNot nullable.

Minimum integer value.

Type: Int
InvalidScenario
Object

Reason and description of the scenario that makes the reservation ineligible for reconciliation.

FieldDescription
reasonNot nullable.

Description of why the reservation is ineligible for reconciliation.

Type: String
scenarioNot nullable.

Reason why the reservation cannot be reconciled. Values include the following:

  • GUEST_REQUESTED_CANCEL - Traveler cancelled the reservation
  • NO_SHOW - Traveler was a no-show
  • MODIFY_DATES_AMOUNTS - There was a difference in the booking price when the lodging partner charged the traveler (for example, because an extra night was added at the time of stay)
Type: String
InventoryConfig
Object

Configuration related to the property's inventory.

FieldDescription
businessModelsNot nullable.

Business model(s) used by the property.

Type: Array of non nullable EgBusinessModel
pricingModelNot nullable.

Pricing model used by the property.

Type: PropertyPricingModel
rateAcquisitionNot nullable.

Rate acquisition configuration for the property.

Type: RateAcquisition
JurisdictionRequirement
Object

Jurisdiction regulations that the partner needs to meet to comply with onboarding to Expedia.

FieldDescription
additionalDataRequirements

Additional required regulation data by jurisdiction, such as license holder name or property address.

Type: Array of AdditionalDataRequirement
exemptions

Exemptions of a requirement under certain conditions.

Type: Array of Exemption
isVacationRental

Whether this regulatory category is a vacation rental.

Type: Boolean
maxNightCap

Maximum number of nights allowed by the jurisdiction. null means no requirement.

Type: MaxNightCap
minStayNightsNot nullable.

Minimum number of stay nights for this category (default is 1).

Type: Int
qualifiedPropertyTypes

Regulation requirement that Expedia and Vrbo support.

Type: Array of LegalPropertyType
registrationNumberRequirements

List of registration number requirements.

Type: Array of non nullable RegistrationNumberRequirement
regulatoryCategory

Property regulatory category where the registration number requirements apply.

Type: RegulatoryCategory
regulatoryCategoryLabel

Localized string of the regulatory category.

Type: String
LastUpdatedDateTimeFilter
InputObject

Date and time window when a reservation was last updated.

FieldDescription
fromNot nullable.

Starting date and time when the reservation was last updated (format: YYYY-MM-DDTHH:mm:ssTZD, TZD is a time zone designator in the form +/-hh:mm).

Type: ZoneDateTime
toNot nullable.

Ending date and time when the reservation was last updated (format: YYYY-MM-DDTHH:mm:ssTZD, TZD is a time zone designator in the form +/-hh:mm).

Type: ZoneDateTime
LegalPropertyType
Object

Property type for the district. This type provides what’s possible for the district. Then, qualifiedPropertyTypes indicates the type and subtype at the unit level. If subtype is set for the property, you should use both type and subtype.

FieldDescription
subtype

Legal property subtype, applicable for residences, such as primary home or secondary home. (This field provides the value that is specified in the registration:details:regulatorySubType field of the updateUnitRegistration mutation.)

Type: String
type

Legal property type, such as hotel, bed and breakfast, residence, etc. (This field provides the value that is specified in the registration:details:regulatoryType field of the updateUnitRegistration mutation.)

Type: String
LivingRoom
Object

Details about a living room space.

FieldDescription
bedGroupsNot nullable.

Bed types offered in the living room.

Type: Array of non nullable BedGroup
idNot nullable.

Space ID of this living room.

Type: ID
orderNot nullable.

Where the living room appears in the list of living rooms (minimum value is 1).

Type: Int
text

Description of the living room.

Type: Array of non nullable Text
LocalDate
LocalDate

A type representing a date in ISO 8601 format: YYYY-MM-DD (such as 2007-12-03).

LocalDateTime
LocalDateTime

A type representing a date and time (such as 2007-12-03T10:15:30).

Locale
Locale

A type that represents a string that conforms to the BCP-47 (RFC 5646) standard. Example: en-GB.

LocalizedString
Object

Localized text and its locale code.

FieldDescription
localeNot nullable.

Locale code used to localize the text, which conforms to the BCP-47 (RFC 5646) standard, such as fr-FR.

Type: Locale
valueNot nullable.

Localized text.

Type: String
LocalTime
LocalTime

Scalar representing a time in this format: HH:mm:ss or HH:mm (such as 10:15:30 or 10:15).

MaxNightCap
Object

Maximum night cap parameters for the jurisdiction.

FieldDescription
annualLimit

Annual night cap.

Type: Int
isEnforced

Whether the cap is enforced (or just informational).

Type: Boolean
MerchantModelConfig
Object

Expedia Collect configuration parameters.

FieldDescription
merchantRatePlanIdNot nullable.

Rate plan ID.

Type: ID
supplierCodeNot nullable.

Supplier's ID for the rate plan.

Type: String
taxInclusiveNot nullable.

Whether the rate includes taxes. For properties managing net rates, the default value is false. For properties managing sell rates, this is based on the property's configuration.

Type: Boolean
MessageReviewStatus
Enum

Status values of a message as it goes through moderation.

NameDescription
IN_REVIEW
ACCEPTED
BLOCKED
MessageThread
Object

Message thread details, including IDs, creation time, messages, and reservation information.

FieldDescription
bookingInquiry

Booking inquiry associated with the message thread. null is returned for non-Vrbo properties.

Type: MessageThreadBookingInquiry
creationDateTimeUtc

Message creation date time in ISO format (yyyy-MM-dd'T'HH:mm:ss.SSSZ) and UTC timezone.

Type: DateTime
idNot nullable.

Message thread ID.

Type: ID
messagesNot nullable.

List of messages in the message thread. You can specify these arguments:

  • limit (type: Int), which enables you to limit the number of messages retrieved (up to 50).
  • cursor (type: String), which is the cursor value for this edge.
  • orderBy (type: MessageThreadMessagesOrderByInput), which provides the sort order of results. If not specified, messages are sorted in ascending order (from oldest to newest) based on the creation date.
Type: MessageThreadMessagesResponse
primaryTraveler

Primary guest's name.

Type: MessageThreadTraveler
propertyNot nullable.

Representation of a physical property, including its message threads and messages.

Type: Property
reservationSummary

Information about the reservation after it is made. This will be null until the reservation is made.

Type: MessageThreadReservationSummary
MessageThreadAttachment
Object

Attachment details.

FieldDescription
idNot nullable.

Attachment ID.

Type: ID
nameNot nullable.

Attachment file name.

Type: String
uploadDateTimeUtcNot nullable.

Date and time when the file was uploaded in ISO format (yyyy-MM-dd'T'HH:mm:ss.SSSZ) and UTC timezone.

Type: DateTime
urlNot nullable.

Attachment location.

Type: Url
MessageThreadBookingInquiry
Object

Booking inquiry information. These details are not available for non-Vrbo properties.

FieldDescription
adultCountNot nullable.

Number of adults included in the reservation.

Type: Int
checkInDate

Requested check-in date in the booking inquiry.

Type: LocalDate
checkOutDate

Requested checkout date in the booking inquiry.

Type: LocalDate
childCountNot nullable.

Number of children included in the reservation.

Type: Int
hasPetsNot nullable.

Whether pets are included in the reservation.

Type: Boolean
idNot nullable.

Booking inquiry ID. We recommend that you store this ID to reconcile the message thread with the inquiry ID provided in the booking request.

Type: ID
MessageThreadLocalizedString
Object

Localized message text.

FieldDescription
valueNot nullable.

Localized message text.

Type: String
MessageThreadMessage
Object

Message details.

FieldDescription
attachmentsNot nullable.

List of attachments associated with this message

Type: Array of non nullable MessageThreadAttachment
body

Localized message body.

Type: MessageThreadLocalizedString
creationDateTimeUtc

Date and time when the message was created in ISO format (yyyy-MM-dd'T'HH:mm:ss.SSSZ) and UTC timezone.

Type: DateTime
fromRole

Role of the participant who has inserted the message.

Type: MessageThreadParticipantRole
idNot nullable.

Message ID in our system.

Type: ID
messageThreadNot nullable.

Associated message thread for the message.

Type: MessageThread
reviewStatus

Status of a message that indicates its review status as it goes through moderation (to identify phishing messages).

Type: MessageReviewStatus
type

Message type. Refer to Message types for a list of values.

Type: String
MessageThreadMessagesOrderByInput
InputObject

Sort order of results. If not specified, messages are sorted in ascending order (from oldest to newest) based on the creation date.

FieldDescription
field

Value on which to base the sort.

Type: MessageThreadMessagesSortField
order

Order of sort.

Type: SortOrder
MessageThreadMessagesResponse
Object

Messages and metadata about messages in the message thread.

FieldDescription
cursor

Next page cursor in the list; empty if no more pages are available.

Type: String
elementsNot nullable.

List of messages.

Type: Array of non nullable MessageThreadMessage
totalCountNot nullable.

Total number of messages returned that meet the filter criteria.

Type: Int
MessageThreadMessagesSortField
Enum
NameDescription
CREATION_DATE_TIME_UTC
MessageThreadParticipantRole
Enum

Role of the participant who has inserted the message.

NameDescription
TRAVELER
SUPPLIER
MessageThreadReservationSummary
Object

Information about the reservation associated with the message. These details are not available until the reservation is made.

FieldDescription
adultCountNot nullable.

Number of adults included in the reservation.

Type: Int
alternativeIdsNot nullable.

Partner's (supplier) ID for the reservation.

Type: ReservationAlternativeIds
checkInDateNot nullable.

Reservation check-in date.

Type: LocalDate
checkOutDateNot nullable.

Reservation checkout date.

Type: LocalDate
childCountNot nullable.

Number of children included in the reservation.

Type: Int
idNot nullable.

For properties onboarded onto Expedia, this is the Expedia reservation ID. For properties onboarded onto Vrbo, this is the Vrbo internal reservation UUID.

Type: ID
petCountNot nullable.

Number of pets included in the reservation. This is supported for Vrbo properties only.

Type: Int
MessageThreadsResponse
Object

Message threads retrieved for a property.

FieldDescription
cursor

Next page cursor in the list; empty if no more pages are available.

Type: String
elementsNot nullable.

List of message threads.

Type: Array of non nullable MessageThread
totalCountNot nullable.

Total number of message threads returned that meet the filter criteria.

Type: Int
MessageThreadTraveler
Object

Primary guest's name.

FieldDescription
firstName

Guest's first (given) name.

Type: String
lastName

Guest's last name (surname).

Type: String
Money
Object

Monetary amount value and its currency code.

FieldDescription
amountNot nullable.

Monetary amount value. The scale of the amount varies according to the currency or any rate conversion that may have been applied.

Type: Decimal
currencyCodeNot nullable.

Currency code.

Type: CurrencyCode
MultiNightDiscount
Object

Multi-night discounts offer percentage-based discounts for applicable nights (such as 15% off a third night).

FieldDescription
applicableNightNot nullable.

Value of the applicable night to which the discount is applied. Permitted values are 2 to 28.

Type: Int
isRecurring

Whether the discount applied on the applicable night is recurring. For example, if applicableNight is set to 3 and isRecurring is set to true, the discount will be applied to the third, sixth, ninth nights (and so on).

Type: Boolean
memberOnlyAdditionalValue

Additional discount that is added to value for members only. For example, if value is 10, unit is PERCENT, and memberOnlyAdditionalValue is 5, members are offered 15 percent off.

Type: Float
typeNot nullable.

Type of discount.

Type: DiscountType
unitNot nullable.

Unit of the discount. Currently, PERCENT is supported when creating or updating a discount. AMOUNT is supported for queries only.

Type: DiscountUnit
valueNot nullable.

Value of the discount applied.

Type: Float
OneOfOperator
Enum

Values for operator input.

NameDescription
IN
NOT_IN
OneOfStringFilterInput
InputObject

Filter for results based on a string.

FieldDescription
operator

Whether to include or exclude the listed string.

Type: OneOfOperator
valuesNot nullable.

Strings used to filter results.

Type: Array of non nullable String
OwnerResponse
Object

Review response submitted by the partner.

FieldDescription
bodyNot nullable.

Localized response text.

Type: LocalizedString
createdDateTimeNot nullable.

Date and time (in UTC, format: YYYY-MM-DDThh:mm:ssTZD) when this response was created.

Type: String
lastUpdatedDateTimeNot nullable.

Date and time (in UTC, format: YYYY-MM-DDThh:mm:ssTZD) when this response was updated.

Type: String
statusNot nullable.

Status of the response. The following values may be returned: APPROVED, BEFORE_SUBMITTED_FOR_MODERATION, QUEUED_FOR_LANG_DETECT, REJECTED, BEFORE_SUBMITTED_TO_ES, SUBMITTED, and REMOVEDBYCLIENT.

Be aware that reviews may be pending for up to 14 days depending on lodging partner actions and review content.

Type: String
PageInfo
Object

Information about the current page of results.

FieldDescription
endCursor

Value of the cursor of the last result on the current page.

Type: String
hasNextPageNot nullable.

Whether additional pages can be retrieved.

Type: Boolean
Payment
Object

Guest payment details.

FieldDescription
instructionsNot nullable.

Text that is displayed to travelers if a payment type is associated with the reservation.

Type: String
PaymentCardDescriptor
Object

Information about the accepted credit card.

FieldDescription
codeNot nullable.

Code associated with the provider of this card: AFFIRM, VISA, MASTERCARD, etc.

Type: String
typeNot nullable.

Type of the card: ALTERNATIVE (for Affirm payments), CREDIT, or DEBIT (debit cards used as credit cards).

Type: String
PaymentInvoiceDescriptor
Object

Information about the invoice payment type.

FieldDescription
typeNot nullable.

Acceptable invoice payment method.

Type: String
Policies
Object

Policies defined for the property.

FieldDescription
bookingPolicy

Booking policies defined for the property.

Type: BookingPolicy
cancellationPolicyConfigs

Cancellation policies defined for the property.

Type: Array of non nullable CancellationPolicyConfig
PricingModel
Enum

Rate plan pricing models.

NameDescription
OCCUPANCY_BASED_PRICING
OCCUPANCY_BASED_PRICING_BY_DAY_OF_ARRIVAL
OCCUPANCY_BASED_PRICING_BY_LENGTH_OF_STAY
PER_DAY_PRICING
PER_DAY_PRICING_BY_DAY_OF_ARRIVAL
PER_DAY_PRICING_BY_LENGTH_OF_STAY
Promotion
Interface

Implemented by

FieldDescription
categoryNot nullable.

Category of the promotion. Currently, only DISCOUNT_PROMOTION is supported (such as Priced Promotions).

Type: PromotionCategory
idNot nullable.

ID of the promotion stored in the Expedia platform.

Type: ID
isContractedPromotion

Whether the promotion is negotiated. (Negotiated promotions cannot be updated.)

Type: Boolean
nameNot nullable.

Name of the promotion.

Type: PromotionName
sellStatus

Whether the promotion is currently bookable based on the its reservation date/time range. This field is supported in queries only. All dates and times are relative to the property’s time zone. The promotion may still be unavailable due to other restrictions. At the time of querying, if the promotion's bookingLocalDateTimeFrom and bookingLocalDateTimeTo values are in the past but the travelDateFrom and travelDateTo values are in the future, the promotion is considered expired because the promotion can no longer be made available.

Type: PromotionSellStatus
statusNot nullable.

Status of the promotion.

Type: PromotionStatus
PromotionCategory
Enum
NameDescription
DISCOUNT_PROMOTION

Priced (discount) promotion. That is, the traveler benefit here is monetary savings via promotions.

PromotionName
Enum
NameDescription
BASIC_PROMOTION

Flexible offer with restrictions defined by the connectivity or lodging partner. You can specify this value when creating or updating single and day-of-week discounts.

EARLY_BOOKING_PROMOTION

Discount offered to travelers who want to book early. You can specify this value when creating or updating single and day-of-week discounts only.

MULTI_NIGHT_PROMOTION

Multi-night discount that offers a percentage-based discount for applicable nights. You can specify this value when creating or updating multi-night discounts only.

SAME_DAY_PROMOTION

Discount offered to attract last-minute travelers by setting up a recurring deal when the travel date is the same as the booking date. You can specify this value when creating or updating single discounts only.

PromotionNode
Object
FieldDescription
cursorNot nullable.

Cursor value for this edge.

Type: String
nodeNot nullable.

Node that references the promotion data.

Type: Promotion
Promotions
Object
FieldDescription
edgesNot nullable.

Edges in the connection to traverse, each containing a cursor and node.

Type: Array of non nullable PromotionNode
pageInfoNot nullable.

Information about the current page of results.

Type: CursorBasedPageInfo
totalCountNot nullable.

Total number of promotions returned that meet the search criteria.

Type: Int
PromotionSellStatus
Enum

Values to indicate whether a promotion is currently bookable based on the its reservation date/time range.

NameDescription
EXPIRED

Promotion cannot be booked because today’s date is after the promotion's bookingLocalDateTimeTo.

CURRENT

Promotion can be booked because today’s date is between the promotion's bookingLocalDateTimeFrom and .bookingLocalDateTimeTo.

FUTURE

Promotion cannot be booked yet because today's date is before the promotion's bookingLocalDateTimeFrom. However, this promotion will become available to book in the future.

PromotionStatus
Enum
NameDescription
ACTIVE
INACTIVE
Property
Object

Representation of a physical property, including its units, reservations, and promotions.

FieldDescription
activeStatus

Status of the property on all platforms and property content. It indicates whether the property is live or not.

Type: ActiveStatus
addressNot nullable.

Physical street address of the property.

Type: Address
aggregatedReviews

Aggregated (average) ratings for the property. You can filter the results by brand name (website) using the filters argument (AggregatedReviewsFiltersInput input type).

Type: AggregatedReviewsResponse
currencyNot nullable.

ISO-4217 currency code of the rates being entered by the property.

Type: Currency
defaultLocaleNot nullable.

Default locale that is used as a fallback when no other locale is specified (IETF BCP 47 language tag, defaults to en-US).

Type: Locale
district

Regulatory requirements and parameters that apply to the property. You can specify the locale argument to retrieve the results in a specific language; specify the four-letter ISO code for language. Use a four-character code that indicates language and region, such as fr_FR for French in France.

Type: District
feeSets

Fee sets defined for the property. You can filter the results by one or more fee set IDs using the filters argument (PropertyFeeSetsFiltersInput input type).

Type: PropertyFeeSetsResponse
idNot nullable.

Expedia ID of the property.

Type: ID
ids

Known IDs for the property in the source system(s). IDs that are returned depend on where the property was onboarded:

  • If the property was onboarded onto Vrbo, three IDs are returned: the partner’s (external ID), Vrbo’s (Vrbo internal ID), and Expedia's (EID).
  • If the property was onboarded onto Expedia, only the Expedia ID is included in the response.
Type: Array of IdNode
inventoryConfigNot nullable.

Configuration related to the property's inventory.

Type: InventoryConfig
listings

Traveler-facing listing URLs of the property on the requested domains. Specify the domains argument (type: String!) and provide one or both of these values: expedia.com, vrbo.com. If you specify expedia.com, the API returns a listing URL if the property exists an Expedia site. If you specify vrbo.com, a listing URL is returned if the property exists on a Vrbo site.

Type: Array of PropertyListing
locationNot nullable.

Location of the property (geocoordinates).

Type: PropertyLocation
messages

List of messages in a message thread. You can specify these arguments:

  • limit (type: Int), which specifies the number of messages to retrieve (up to 10).
  • cursor (type: String), which is the cursor value for the page of results to retrieve.
  • filters (type: PropertyMessagesFiltersInput!), which specifies the creation date range to use to filter results.
Type: MessageThreadMessagesResponse
messageThreadsNot nullable.

List of message threads for a property. You can specify these arguments:

  • limit (type: Int), which specifies the number of message threads to retrieve (up to 10).
  • cursor (type: String), which is the cursor value for the page of results to retrieve.
  • filters (type: PropertyMessageThreadsFiltersInput!), which specifies the creation date range to use to filter results.
  • orderBy (type: ReviewsOrderBy), which provides the sort order of results. If not specified, message threads are sorted in ascending order (from oldest to newest) based on the creation date.
Type: MessageThreadsResponse
nameNot nullable.

Human-readable name of the property.

Type: String
names

List of all the names for the property.

Type: Array of non nullable LocalizedString
policiesNot nullable.

Booking and cancellation policies configured for the property.

Type: Policies
promotions

List of promotions that matches the specified arguments. You can specify these arguments:

  • filter (type: FiltersInput), which enables you to refine the promotions to retrieve. Note that if you filter results by promotion ID, you cannot specify addition filters.
  • pageSize (type: Int!), which is required and specifies the maximum number of promotions on each page (up to 25) returned by the response. For example, if there are 40 promotions on a property, you can retrieve two pages if this argument is set to 25 (page 1 includes 25 promotions, page 2 includes 15 promotions).
  • after (type: String), which is the cursor from the previous query response that marked the end of the previous page of results.
Type: Promotions
reservationsNot nullable.

List of the property's reservations that match the specified arguments:

  • filter (type: ReservationFilterInput), which enables you to refine the reservations to retrieve. If this argument is not specified, the query returns all reservations for the property.
  • pageSize (type: Int!), which is required and specifies the maximum number of reservations on each page (up to 25) returned by the response. For example, if there are 40 reservations on a property, you can retrieve two pages if this argument is set to 25 (page 1 includes 25 reservations, page 2 includes 15 reservations).
  • after (type: String), which is the cursor from the previous query response that marked the end of the previous page of results.
Type: ReservationsConnection
reviewsNot nullable.

Reviews provided by travelers for the property that match the specified arguments. You can specify these arguments:

  • filter (type: ReviewFilter), which provides additional arguments to filter the reviews that are returned by the query.
  • pageSize (type: Int!), which is required and specifies the maximum number of reviews on each page (up to 100) returned by the response. For example, if there are 15 reviews on a property, you can retrieve two pages if this argument is set to 10 (page 1 includes 10 reviews, page 2 includes 5 reviews).
  • after (type: String), which is the cursor from the previous query response that marked the end of the previous page of results.
  • orderBy (type: ReviewsOrderBy), which provides the sort order of results; only one field should be specified. If not specified, reviews are sorted by review creation dateTime.
Type: ReviewResponse
timeZoneNot nullable.

Time zone where the property is located.

Type: String
typeNot nullable.

Property type.

Type: PropertyType
units

Collection of unit configurations available for the property.

Type: Array of Unit
PropertyFeeSetsFiltersInput
InputObject

Input parameter for the feeSets query.

FieldDescription
feeSetIdsNot nullable.

One or more fee set IDs to filter results on.

Type: Array of non nullable ID
PropertyFeeSetsResponse
Object

Details about the fee sets defined for the property.

FieldDescription
elementsNot nullable.

Details about the fee set(s).

Type: Array of non nullable FeeSet
totalCountNot nullable.

Number of fee sets defined for the property.

Type: Int
PropertyListing
Object

Locale and URL of the listing on the specified domain(s).

FieldDescription
locale

Locale for the property listing on the requested domain.

Type: String
url

URL if the property is enabled on the requested domain.

Type: String
PropertyLocation
Object

Geographical location of a property.

FieldDescription
coordinates

Geographical location coordinates.

Type: Coordinates
PropertyMessagesFiltersInput
InputObject

Creation date range to use to filter results.

FieldDescription
creationDateTimeNot nullable.

Date range to use when filter results.

Type: DateTimeRangeFilterInput
PropertyMessageThreadsFiltersInput
InputObject

Creation date range to use to filter results.

FieldDescription
creationDateTimeNot nullable.

Date range to use when filter results.

Type: DateTimeRangeFilterInput
PropertyMessageThreadsOrderByInput
InputObject

Sort order of results. If not specified, message threads are sorted in ascending order (from oldest to newest) based on the creation date.

FieldDescription
field

Value on which to base the sort.

Type: PropertyMessageThreadsSortField
order

Order of sort.

Type: SortOrder
PropertyMessageThreadsSortField
Enum
NameDescription
CREATION_DATE_TIME_UTC
PropertyPricingModel
Enum

Pricing model used by the property.

NameDescription
OCCUPANCY_BASED
PER_DAY
PropertyType
Object

Property type.

FieldDescription
codeNot nullable.

Property type code. Use the metadata query for the list of supported codes.

Type: String
PropertyUnitArea
Object

Unit's size and unit of measure.

FieldDescription
unitNot nullable.

Unit of measure used to describe the unit's area.

Type: AreaUnit
valueNot nullable.

Size of the unit.

Type: Int
Purpose
Enum

Purpose of the requirement.

NameDescription
DATA_SHARING
RangeOperator
Enum

"Values that indicate whether the specified dates are inclusive or exclusive.

NameDescription
INCLUSIVE

Includes messages or message threads that occurred on the specified dates in the results.

EXCLUSIVE

Excludes messages or message threads that occurred on the specified dates in the results.

RateAcquisition
Object

Rate acquisition configuration for the property.

FieldDescription
pricingComponentsNot nullable.

Whether the rate includes fees and/or taxes. Only applicable for the SELL_LAR rate acquisition type.

Type: Array of non nullable RateAcquisitionPricingComponent
typeNot nullable.

How an entered rate is interpreted.

Type: RateAcquisitionType
RateAcquisitionPricingComponent
Enum

Whether the rate includes fees and/or taxes.

NameDescription
FEES
TAXES
RateAcquisitionType
Enum

Values for the type of rate to be used when managing availability and rates (how an entered rate is interpreted).

NameDescription
NET

Rate excludes Expedia Group's compensation.

SELL_LAR

Rate includes compensation.

RatePlan
Object

Details about the rate plan.

FieldDescription
agencyModelConfig

Hotel Collect configuration parameters.

Type: AgencyModelConfig
baseRateGuestCount

Number of guests allowed when applying the base rate.

Type: Int
cancellationPolicyConfig

Cancellation policy details for the policy that is associated with this rate plan.

Type: CancellationPolicyConfig
creationDateTimeNot nullable.

Date and time when the rate plan was created.

Type: DateTime
feeSet

Fee set associated with this rate plan.

Type: FeeSet
idNot nullable.

Rate plan ID.

Type: ID
lastUpdateDateTimeNot nullable.

Date and time when the rate plan was last updated.

Type: DateTime
merchantModelConfig

Expedia Collect configuration parameters.

Type: MerchantModelConfig
nameNot nullable.

Rate plan name.

Type: String
pricingModelNot nullable.

Pricing model used by the rate plan.

Type: PricingModel
propertyIdNot nullable.

ID of the property that the rate plan is associated with.

Type: ID
restrictionsNot nullable.

Rate plan restrictions.

Type: RatePlanRestrictions
statusNot nullable.

Status of the rate plan.

Type: RatePlanStatus
typeNot nullable.

Rate plan type.

Type: RatePlanType
unitIdNot nullable.

ID of the unit that the rate plan is associated with.

Type: ID
valueAddsNot nullable.

Value add promotions offered by the rate plan.

Type: Array of non nullable String
RatePlanRestrictions
Object

Rate plan restrictions.

FieldDescription
advanceBookingDays

Minimum and maximum of days in advance of the booking that are required to make a reservation. Default range is 0-500 days.

Type: IntRange
lengthOfStay

Minimum and maximum number of days allowed for the length of stay. Default range is 1-28 days.

Type: IntRange
mobileOnly

Whether this rate plan is applicable only to travelers booking on the mobile device.

Type: Boolean
reservationDates

Date range when the reservation can be made. If not restricted, start will be 1900-01-01 and end will be 2079-06-06.

Type: DateRange
travelDates

Range of stay dates to which this rate plan applies. If not restricted, start will be 1900-01-01 and end will be 2079-06-06.

Type: DateRange
RatePlanStatus
Enum

Rate plan status values.

NameDescription
ACTIVE
INACTIVE
RatePlanType
Enum

Rate plan type values.

NameDescription
B2B_DISTRIBUTION
BUSINESS
PACKAGE
PACKAGE_DISTRIBUTION
STANDALONE
RateThresholds
Object
FieldDescription
net

The rate threshold settings of RateAcquisitionType NET.

Type: RateThresholdSettings
sellLar

The rate threshold settings of RateAcquisitionType SELL_LAR.

Type: RateThresholdSettings
RateThresholdSettings
Object

Minimum and maximum rates allowed as well as the source of the rate.

FieldDescription
maxAmountNot nullable.

Maximum acceptable rate, expressed as a decimal number.

Type: Decimal
minAmountNot nullable.

Minimum acceptable rate, expressed as a decimal number.

Type: Decimal
sourceNot nullable.

How the minimum and maximum amounts were calculated.

Type: RateThresholdsSource
RateThresholdsSource
Enum

How the minimum and maximum amounts were calculated.

NameDescription
MANUAL_OVERRIDE
RECENT_BOOKINGS
RateTimeUnit
Enum

Time frame to which the rate is applied.

NameDescription
PER_DAY

Rate is applied per day.

PER_WEEK

Unsupported at this time.

PER_STAY

Unsupported at this time.

RateType
Enum
NameDescription
NET

Net amount (excludes compensation and taxes).

SELL

Gross amount (includes compensation and taxes).

Rating
Object

Star rating of the specified category as submitted by the traveler.

FieldDescription
categoryNot nullable.

Category to which the rating applies. For reviews collected on Expedia sites, these are the categories:

  • ecoFriendliness
  • roomComfort
  • roomCleanliness
  • service
  • overall
  • hotelCondition
  • roomAmenitiesScore
  • areaAroundHotel

For reviews collected on Vrbo, these are the categories:

  • overall
  • cleanliness
  • house_rules
  • communication
Type: String
valueNot nullable.

Value of the rating, from 1 (terrible) to 5 (excellent).

Note: Ratings on Expedia points of sale other than Expedia.com are displayed using a 10-point scale, which is calculated by doubling the rating provided through the API. For example, if a traveler submits a 2, 4 is displayed on Hotels.com. Ratings on non-hotel points of sale are displayed using a 5-point scale.

Type: String
ReconEligibility
Object

Reason(s) why the reservation can or cannot be reconciled.

FieldDescription
invalidScenarios

Reasons and descriptions why the reservation cannot be reconciled.

Type: Array of non nullable InvalidScenario
validScenarios

Reason why the reservation can be reconciled. Values include the following:

  • GUEST_REQUESTED_CANCEL - Traveler cancelled the reservation
  • NO_SHOW - Traveler was a no-show
  • MODIFY_DATES_AMOUNTS - There was a difference in the booking price when the lodging partner charged the traveler (for example, because an extra night was added at the time of stay)
Type: Array of non nullable String
RegionRestrictionsInput
InputObject

Regions to which the rate plan is restricted.

FieldDescription
regionIdsNot nullable.

Region IDs.

Type: Array of non nullable String
typeNot nullable.

Whether the specified regions are available for the rate plan.

Type: AvailabilityRestrictionType
Registration
Object

Government registration information for the unit or room type.

FieldDescription
applicableRegulations

Additional registration information required by certain districts.

Type: Array of non nullable ApplicableRegulations
completeNot nullable.

Checks the consistency of the information in our systems at the property level to determine whether the registration information is sufficient to fulfill the requirements of the property's district. We do not recommend including this field in the query because it does not provide the true value for some properties.

If false is returned for a unit, you can use the Product API to identify active units, though false may be returned for inactive units that have incorrect regulatory information.

Type: Boolean
detailNot nullable.

Detailed registration information for the unit or room type.

Type: RegistrationDetail
district

Geographical jurisdiction identifier. For non-configured districts, this is null.

Type: String
RegistrationDetail
Object

Registration information for the unit or room type.

FieldDescription
acknowledgementRecordsNot nullable.

Acknowledgement records for the bookable unit. These are displayed to the traveler to confirm that they understand the regulatory requirements.

Type: Array of non nullable AcknowledgementRecord
applicableRegulationsNot nullable.

Additional information about the bookable unit required by certain districts.

Type: Array of non nullable ApplicableRegulations
attachmentUrls

Links for registration documentation files (if required).

Type: Array of non nullable AttachmentUrl
compliant

Compliance status for mandatory requirements only (at the unit level) according to the local jurisdiction's regulatory requirements. If invalid information is provided for an optional regulatory requirement, or if regulatory information is set in a jurisdiction that does not require regulatory information, status: COMPLIANT is returned. For optional requirements, a warning is returned in the warningStatus field of the updateUnitRegistration mutation's payload.

Type: Compliant
displayRegistrationNumber

Registration number displayed to the traveler.

Type: String
exemptionCategories

List of exemptions for the property, such as maximum night cap.

Type: Array of non nullable ExemptionCategory
numberOfPhysicalRooms

Number of rooms in the bookable unit.

Type: Int
registrationRecordsNot nullable.

Registration records for the bookable unit filed with the governing jurisdiction.

Type: Array of non nullable RegistrationRecord
regulatoryCategoryNot nullable.

Property classification category as maintained by the governing jurisdiction.

Type: RegulatoryCategory
regulatoryCategoryLabelNot nullable.

Regulatory category in the specified locale.

Type: String
regulatorySubType

Property subtype, such as primary or secondary, or null if not applicable.

Type: String
regulatoryType

Property type, such as residence, condo, boat, etc.

Type: String
unitIdNot nullable.

Expedia ID of the unit or room type.

Note: We strongly recommend that you include this field in your implementation even though it is nullable. This field provides an audit trail for reporting purposes.

Type: ID
RegistrationNumberRequirement
Object

Registration requirement.

FieldDescription
allowPendingRegistrationsNot nullable.

Whether properties with pending registration applications are allowed to list.

Type: Boolean
format

Example(s) of the registration requirement's value.

Type: String
isExpirationDateRequiredNot nullable.

Whether an expiration date must be set for the registration requirement.

Type: Boolean
isOptionalNot nullable.

Whether the jurisdiction requires registration information. Be aware that if a jurisdiction requires a property owner to apply for a permit but there is no requirement for us to collect or display the permit, this field will be set to true (indicating that registration information is optional).

Type: Boolean
localName

Localized display name of the registration requirement as shown in the Vrbo dashboard or Expedia Partner Central (such as みんぱく for Japan Minpaku).

Type: String
numberType

Registration requirement type. (This field provides the value that must be specified in the registration:details:registrationRecords:registrationNumberType field of the updateUnitRegistration mutation.)

Type: RegistrationNumberType
numberTypeLabel

Label used to describe the registration requirement in the Vrbo dashboard and Expedia Partner Central.

Type: String
purpose

Purpose of this requirement, if other than common regulatory validations.

Type: Purpose
regex

Regular expression used to validate the syntax of the registration requirement's value.

Type: String
thirdPartyValidation

Information about external validation parameters, if required for the registration requirement.

Type: ThirdPartyValidation
url

URL of a page that provides information about the registration requirement.

Type: String
RegistrationNumberType
Enum

Types of registration numbers (licenses).

NameDescription
LICENSE_NUMBER
LICENSE_ID
PARTIAL_TAX_ID
REGISTRATION_NUMBER
BUSINESS_LICENSE_NUMBER
OPERATOR_LICENCE_ID
OPERATOR_LICENSE_ID
BUSINESS_TAX_ID
RESORT_TAX_ID
SHORT_TERM_RENTAL_LICENSE
PERMIT_NUMBER
PLANNING_NUMBER
HOTEL_LICENSE
IS_IN_ZONING_PLAN
IS_PROFESSIONAL_HOST
TOURIST_DEVELOPMENT_TAX_ACCOUNT_NUMBER
HOME_SHARING_NUMBER
HOME_SHARING_PERMIT_NUMBER
CERTIFICATE_OF_USE_NUMBER
GENERAL_EXCISE_TAX_ID
TRANSIENT_ACCOMMODATIONS_TAX_ID
REGISTRATION_CERTIFICATE_NUMBER
PROPERTY_REGISTRY_NUMBER
SPECIAL_OPERATION_SIGN
TRANSIENT_REGISTRATION_NUMBER
PROVINCIAL_TOURIST_IDENTIFICATION_CODE
PARCEL_NUMBER_TAX_MAP_KEY
BUSINESS_TAX_RECEIPT_NUMBER
OPERATOR_LICENSE_NUMBER
OPERATOR_PERMIT
OWNER_PERMIT
TAX_IDENTIFICATION_NUMBER
MA_REGISTRATION_CERTIFICATE_NUMBER
BOSTON_REGISTRATION_NUMBER
OWNER_NAME
CADASTRAL_REFERENCE
OWNER_IS_CITIZEN
OWNER_ID
ZIPCODE
HOUSE_NUMBER
IS_CONDITION
ENTITY_TYPE
IS_TRADED
IS_GOVERNMENT_ENTITY
IS_ADDRESS_IN_EU
IS_RESIDENCE_IN_EU
LEGAL_ADDRESS
ISSUED_TAX_ID
PERMANENT_ESTABLISHMENT_COUNTRY
BUSINESS_REGISTRATION_NUMBER
LAND_REGISTRATION_NUMBER
BIRTH_DATE
IS_VAT_REGISTERED
VAT_ID
DATE
CITIZEN_ID
FOREIGN_ID
NEIGHBORHOOD_NAME
NATIONAL_ADDRESS_NUMBER
FLOOR_SYSTEM_NUMBER
JOURNAL_NUMBER
IS_ZONING_LAW_APPLIED
APPLICATION_NUMBER
ISSUANCE_DATE
RegistrationRecord
Object

Registration record for the bookable unit that has been filed with the jurisdiction.

FieldDescription
expiry

Registration record expiration date in this format: yyyy-mm-dd

Type: String
registrationNumberNot nullable.

Registration record ID.

Type: String
registrationNumberType

Type of registration/license.

Type: RegistrationNumberType
registrationNumberTypeLabel

Localized registration number type.

Type: String
RegulatoryCategory
Enum

Category values for regulatory categories. Most of jurisdiction districts only allow for two categories, HOTEL and VACATION_RENTAL, though more values GRAPHQL_VALIDATION_FAILED are provided to satisfy local government requirements.

NameDescription
HOTEL
BED_AND_BREAKFAST
HOTEL_OR_BNB
PRIMARY_HOME
PRIMARY_HOME_WITH_EXCEPTION
SECONDARY_HOME
VACATION_RENTAL
LONG_TERM_ONLY
SHORT_TERM_RENTAL
MINPAKU
SIMPLE_LODGING
EVENT
SPECIAL
NO_LICENSE
HOTEL_RYOKAN
RYOKAN
PRIMARY_OR_SECONDARY
TRANSIENT_OCCUPANCY_RESIDENTIAL_STRUCTURE
MOTEL
HOME_SHARING_NUMBER
VACATION_RENTAL_OTHER
HOSTEL
CAMPING_SITES
RURAL_LODGING
APARTMENT_HOTEL
RegulatoryStatus
Enum

Values for regulatory status.

NameDescription
COMPLIANT

Unit meets all regulatory requirements.

COMPLIANT_ACTION_NEEDED

Unit meets requirements to remain listed but will need to provide additional information (or other action) in order to not be delisted.

NOT_COMPLIANT

Unit does not meet all regulatory requirements and cannot be shown.

NOT_COMPLIANT_ACTION_NEEDED

Unit is not compliant, but enforcement hasn't started yet. Action should be taken for the listing to be compliant after enforcement date.

NOT_ALLOWED

Platform does not allow units in this jurisdiction; no actions from partner can affect status.

NONE

Unit's status cannot be determined.

Reservation
Object

Reservation details.

FieldDescription
accessibilityText

Accessibility requests made by the guest for the reservation. We strongly recommend that you include this field in your implementation.

Type: Array of non nullable String
adultCountNot nullable.

Count for all adult guests associated with the reservation.

Type: Int
bedTypes

Bed type of the reservation.

Type: String
businessModelNot nullable.

Entity that collects payment for the reservation.

Type: BusinessModel
checkInDateNot nullable.

Check-in date (format: YYYY-MM-DD) of the reservation.

Type: LocalDate
checkOutDateNot nullable.

Checkout date (format: YYYY-MM-DD) of the reservation.

Type: LocalDate
childAges

Ages of children associated with the reservation.

Type: Array of Int
childCountNot nullable.

Count for all child guests associated with the reservation.

Type: Int
creationDateTimeNot nullable.

Timestamp of when the reservation was created (format: yyyy-mm-ddThh:mm:ssTZD, where TZD is a time zone designator in the form +/-hh:mm). Compare this value to that of lastUpdatedDateTime to determine if a reservation has been modified.

Type: String
idNot nullable.

Expedia's reservation ID.

Type: ID
isReconciled

Whether one or more reconciliation attempts have been made on the reservation.

Type: Boolean
lastUpdatedDateTimeNot nullable.

Date and time when the reservation was last updated. Compare this value to that of creationDateTime to determine if a reservation has been modified.

Type: String
messageThreadId

ID of message thread (conversation) associated with the reservation. This requires implementation and certification of the messaging capability. If no message threads exist for a reservation, null is returned.

Type: ID
multiRoomText

Text that is displayed to guests if there is a multi-room booking associated with the reservation.

Type: String
paymentNot nullable.

Guest payment details.

Type: Payment
primaryGuestNot nullable.

Guest who made the reservation.

Type: Guest
rateIdsNot nullable.

ID of the rate/rate plan and the source of the ID. In the response, when idSource is set to SUPPLIER, the id field returns the same value as returned by the existing booking APIs. However, for Hotel Collect properties, the A- prefix is no longer added to the source value and the A suffix is no longer appended to the rate ID as was done by the booking APIs.

Type: Array of non nullable IdNode
reconciliationEligibility

The reason(s) why the reservation can or cannot be reconciled.

Type: ReconEligibility
reconciliationType

Reconciliation type of the reservation, either MODIFY, CANCEL, NO_SHOW, or null.

Type: String
reservationIdsNot nullable.

IDs associated with the reservation and the source of the IDs.

Type: Array of non nullable IdNode
smokingTypeNot nullable.

Whether smoking is allowed for the reservation.

Type: String
sourceNot nullable.

Source of the reservation. Refer to Booking sources for the list of possible values (though \"A-\" is not included in Hotel Collect sources returned by this API).

Type: String
specialRequest

Text that is displayed to guests if there is a special request associated with the reservation.

Type: String
statusNot nullable.

Current status of the reservation.

Type: ReservationStatus
supplierAmount

Connectivity or lodging partner's amount for the reservation.

Type: SupplierAmount
tidsCode

Travel Industry Designator Service (TIDS) code that allows a reservation to be recognized by industry suppliers.

Type: Int
unitIdsNot nullable.

Known IDs for the unit/room in the source system(s). IDs that are returned depend on where the property was onboarded:

  • If the property was onboarded onto Vrbo, three IDs are returned: the partner’s (external ID), Vrbo’s (Vrbo internal ID), and Expedia's (EID).
  • If the property was onboarded onto Expedia, only the Expedia ID is included in the response.
Type: Array of non nullable IdNode
valueAddedPromotionsNot nullable.

Value add promotion(s) used to book the reservation, which are additional benefits that travelers receive based on loyalty tier status, chosen property, and room type or rate plan they book. If a value add promotion was not used, an empty array is returned. We strongly recommend that you include this field in your implementation to ensure traveler-promised perks can be properly fulfilled by suppliers.

Type: Array of non nullable ReservationValueAddedPromotion
ReservationAlternativeIds
Object

Partner's (supplier) IDs for the reservation.

FieldDescription
supplierIdNot nullable.

For properties onboarded onto Expedia, this is the partner’s confirmation ID for the booking.

For properties onboarded onto Vrbo, this is the partner’s supplier ID. This ID may be prefixed with “HA-” to indicate a platform reservation. Two scenarios account for this:

  • If the lodging partner was a former platform PM and has upcoming reservations that were made prior to their conversion to integrated lodging partner.
  • The lodging partner uses using a third-party calendar sync application, such as Hospitable, which may create platform bookings. To resolve this, the partner must disable the third-party application.
Type: ID
ReservationEdge
Object
FieldDescription
cursorNot nullable.

Cursor value for this edge.

Type: String
nodeNot nullable.

Node that references the reservation data.

Type: Reservation
ReservationFilterInput
InputObject

Parameters used to filter reservations. If more than one filter is specified, the intersection of the filters is returned.

FieldDescription
checkOutDate

Checkout date window for which to filter reservations. Example:

checkOutDate: { from: "2021-08-05", to: "2021-08-07" }
Type: CheckOutDateFilter
lastUpdatedDateTime

Date and time when the reservation was last updated. Compare this value to that of creationDateTime to determine if a reservation has been modified.Example:

 lastUpdatedDateTime: {
    "from": "2022-03-02T10:23:17Z",
    "to": "2022-06-08T12:00:00Z"
  }
Type: LastUpdatedDateTimeFilter
reservationIds

IDs of the reservations to retrieve. Example to retrieve two reservations based on their IDs:

reservationIds: [
  {
    "id": "123HotelCode",
    "idSource": "SUPPLIER"
  },
  {
    "id": "456HotelCode",
    "idSource": "SUPPLIER"
  }
]
Type: Array of non nullable IdNodeInput
ReservationIdSource
Enum

Source system of the reservation ID.

NameDescription
EXPEDIA
VRBO
SUPPLIER
ReservationsConnection
Object

Logical connection to reservations data.

FieldDescription
edgesNot nullable.

Edges in the connection to traverse, each containing a cursor and node.

Type: Array of ReservationEdge
pageInfo

Information about the current page of results.

Type: PageInfo
totalCount

Total number of reservations.

Type: Int
ReservationStatus
Enum

Status of the reservation.

NameDescription
BOOKED
CANCELLED
COMPLETE

For Vrbo reservations only.

CREATED

For Vrbo reservations only.

DECLINED

For Vrbo reservations only.

IN_PROGRESS

For Vrbo reservations only.

INVALID

For Vrbo reservations only.

RESERVED

For Vrbo reservations only.

ReservationValueAddedPromotion
Object

Value add promotion(s) used to book the reservation. If no value add promotion (VAP) was used, an empty array is returned.

FieldDescription
descriptionNot nullable.

Description of the promotion.

Type: String
idNot nullable.

ID of the promotion.

Type: String
ResolutionStatus
Enum

Resolution status values, which indicate the API's ability to determine if a checkpoint is fulfilled.

NameDescription
RESOLVED

Checkpoint was successfully evaluated.

UNRESOLVED_PROPERTY_NOT_PROVISIONED

API could not determine a fulfilled value because the property is missing from our internal system. Retry the operation; this is typically caused by a transient internal error. If the error persists, contact your Technical Relationship Manager.

UNRESOLVED_CHECKPOINT_SYSTEM_UNAVAILABLE

API could not determine a fulfilled value because of an internal problem. Retry the operation; this is typically caused by a transient internal error. If the error persists, contact your Technical Relationship Manager.

Restrictions
Object
FieldDescription
bookingLocalDateTimeFrom

Beginning of the date range (inclusive) when the reservation can be made in order for this promotion to be applicable. Format is YYYY-MM-DDThh:mm:ss, in the property’s local time zone.

Type: LocalDateTime
bookingLocalDateTimeTo

End of the date range (inclusive) when the reservation can be made in order for this promotion to be applicable. Format is YYYY-MM-DDThh:mm:ss, in the property’s local time zone.

Type: LocalDateTime
isMemberOnly

Whether a promotion is applicable only to members shopping on Expedia. The default value for this field is false.

Note that member-only badging is not applied to member-only deals that are less than 10%.

Type: Boolean
isMobileUserOnly

Whether this promotion is applicable only to travelers booking on the mobile device. This field is returned when querying for a single promotion only (by specifying the promotion ID).

Type: Boolean
maxAdvanceBookingDays

Maximum number of days in advance of the reservation date for the promotion to be applicable.

Type: Int
maxLengthOfStay

Maximum duration of stay for which the promotion can be applicable. Maximum value is 28.

Type: Int
minAdvanceBookingDays

Minimum number of days in advance of the reservation date for the promotion to be applicable. The default value for this field is 0.

Type: Int
minLengthOfStay

Minimum duration of stay for which the promotion can be applicable.

Type: Int
sameDayBookingStartTime

Start time for the same day for which the promotion is applicable (in the property’s local time zone). Applicable only for SAME_DAY_PROMOTION.

Type: LocalTime
travelDateFrom

Beginning travel date for which this promotion is applicable in YYYY-MM-DD format.

Type: LocalDate
travelDateTo

End travel date for which this promotion is applicable in YYYY-MM-DD format.

Type: LocalDate
ResultFilter
Enum

Fulfillment status values.

NameDescription
PASSED

Checkpoint is fulfilled (fulfilled equal to true).

FAILED

Checkpoint is not fulfilled (fulfilled equal to false). This means the content requirement has not been met. Verify that content is included in the Listings integration file for processing.

UNRESOLVED

API could not determine the checkpoint's fulfilled value (resolutionStatus equal to UNRESOLVED_*). Retry the operation; this is typically caused by a transient internal error. If the error persists, contact your Technical Relationship Manager.

Review
Object

Review content, including its source, localized text, and reservation information to which it pertains.

FieldDescription
bodyNot nullable.

Localized review text.

Type: LocalizedString
brandNameV2

Brand (site) where the review was collected.

Type: ReviewBrand
createdDateTimeNot nullable.

Date and time (in UTC, format: YYYY-MM-DDThh:mm:ssTZD) when this review was created.

Type: String
idNot nullable.

Review ID.

Type: ID
isEligibleForResponse

Whether the partner can respond to the review. Reasons why a review is ineligible include:

  • The review was imported and cannot be responded to
  • The window within which a partner can respond has expired
  • A response has been submitted and approved (moderated) and the partner is no longer allowed to submit a response
Type: Boolean
lastUpdatedDateTimeNot nullable.

Date and time (in UTC, format: YYYY-MM-DDThh:mm:ssTZD) when this review was last updated.

Type: String
media

Unsupported at this time. Media URLs and caption uploaded with the review, if any.

Type: ReviewMedia
propertyId

Property IDs.

Type: Array of IdNode
reservationType: ReviewReservation
response

Review response submitted by the partner (using the setReviewResponse mutation).

Type: OwnerResponse
source

Source of the review; values include PLATFORM and IMPORTED.

Type: String
starRatingsNot nullable.

Overall rating for this review, typically on a 1-5 point scale.

Type: Array of Rating
statusNot nullable.

Status of the review.

Type: String
title

Localized review title (headline).

Type: LocalizedString
ReviewAggregatedScore
Object

Aggregated score (rating) and the number of reviews used to compute the score.

FieldDescription
reviewsCountNot nullable.

Number of reviews that were averaged to create the aggregated rating.

Type: Int
scoreNot nullable.

Aggregated (average) rating.

Type: Float
ReviewBrand
Enum

Brand names (sites) where reviews are collected.

NameDescription
EXPEDIA
HOTELS
TRAVELOCITY
ORBITZ
CHEAP_TICKETS
WOTIF
EBOOKERS
MR_JET
LASTMINUTE
VRBO

Unsupported

HOTWIRE
OTHER

Unsupported

ReviewCategoryScore
Object

Category and aggregated rating.

FieldDescription
categoryNot nullable.

Category to which the rating applies. For reviews collected on Expedia sites, these are the categories:

  • ecoFriendliness
  • roomComfort
  • roomCleanliness
  • service
  • overall
  • hotelCondition
  • roomAmenitiesScore
  • areaAroundHotel

For reviews collected on Vrbo, these are the categories:

  • checkIn
  • overall
  • location
  • communication
  • onlineListing
  • cleanliness
Type: String
valueNot nullable.

Value of the aggregated (average) rating.

Type: ReviewAggregatedScore
ReviewFilter
InputObject

Additional arguments to filter the reviews that are returned by the query.

FieldDescription
brandNames

Expedia brand for which the review was created. Supported for non-Vrbo properties only.

Type: Array of non nullable ReviewBrand
createdDate

Date range when reviews were created.

Type: DateInput
hasOwnerResponse

Whether an owner or property manager response exists for the review.

Type: Boolean
reservation

Reservation details.

Type: ReviewReservationFilterInput
reviewId

Expedia or Vrbo ID of the review.

Type: String
source

Source of the review ID. To retrieve native reviews, specify PLATFORM. To retrieve imported reviews, specify IMPORTED.

Type: String
updatedDate

Date range when reviews were updated.

Type: DateInput
ReviewGuest
Object

Information about the traveler who left the review. If no name is provided for the review, Anonymous is listed as the review's name.

FieldDescription
firstNameNot nullable.

First name of the traveler.

Type: String
lastNameNot nullable.

Last name (surname) of the traveler.

Type: String
ReviewMedia
Object

Unsupported at this time. Media URLs and caption uploaded with the review, if any.

FieldDescription
caption

Image caption.

Type: LocalizedString
highResolutionUrl

URL of the full image.

Type: String
thumbnailUrl

URL of the image's thumbnail.

Type: String
ReviewReservation
Object

Reservation details associated with the review.

FieldDescription
checkInDate

Reservation check-in date.

Type: LocalDate
checkOutDate

Reservation checkout date.

Type: LocalDate
primaryGuest

Guest information.

Type: ReviewGuest
reservationIdsNot nullable.

IDs of the reservation.

Type: Array of non nullable IdNode
status

Status of the reservation.

Type: String
ReviewReservationFilterInput
InputObject

Reservation details that are used to filter results.

FieldDescription
reservationIds

Review IDs and their sources.

Type: Array of non nullable ReviewReservationIdNodeInput
ReviewReservationIdNodeInput
InputObject

Reservation ID and its source.

FieldDescription
idNot nullable.

Reservation ID.

Type: ID
idSourceNot nullable.

Source of the ID.

Type: IdSource
ReviewResponse
Object

Reviews retrieved by the query.

FieldDescription
cursor

Next page cursor for the next page of results (null if no more pages are available).

Type: String
reviewsNot nullable.

Review content, including each review's source, localized text, and reservation information to which it pertains.

Type: Array of Review
totalCountNot nullable.

Total number of reviews returned that meet the search criteria.

Type: Int
ReviewsOrderBy
InputObject

How reviews are sorted; only one field should be specified. If not specified, reviews are sorted by review creation dateTime.

FieldDescription
createdDateTime

Sort order based on review creation dateTime in ascending or descending order.

Type: SortOrder
lastUpdatedDateTime

Sort order based on review updated dateTime in ascending or descending order.

Type: SortOrder
ownerResponseCreatedDateTime

Sort order based on dateTime of when the owner response was created in ascending or descending order.

Type: SortOrder
ownerResponseLastUpdatedDateTime

Sort order based on dateTime when the owner response was updated in ascending or descending order.

Type: SortOrder
reservationCheckInDate

Sort order based on reservation check-in date in ascending or descending order.

Type: SortOrder
reservationCheckOutDate

Sort order based on reservation checkout date in ascending or descending order.

Type: SortOrder
SingleDiscount
Object

Discount that offers a percentage off a rate (such as 15% off).

FieldDescription
memberOnlyAdditionalValue

Value of member-only discount applied. For example, if the regular discount is 10% and memberOnlyAdditionalValue is set to 5, a member will receive a 15% discount and a non-member will receive a 10% discount.

Type: Float
typeNot nullable.

Type of discount.

Type: DiscountType
unitNot nullable.

Unit of the discount. Currently, PERCENT is supported when creating or updating a discount. AMOUNT is supported for queries only.

Type: DiscountUnit
valueNot nullable.

Value of the discount applied.

Type: Float
SortOrder
Enum

How to sort results.

NameDescription
ASC

Sort results in ascending order (oldest to newest).

DESC

Sort results in descending order (newest to oldest).

StatusCheckpoint
Object

Information about a property's or unit's content requirements (checkpoints).

FieldDescription
checkpointByName

Unsupported at this time.

Type: StatusCheckpoint
checkpoints

Content requirement (checkpoint) that determines overall status. This field provides an optional argument, checkpoints(filter: CheckpointFilterInput), which enables you to filter the returned checkpoints by result. Refer to the CheckpointFilterInput type for details.

Type: Array of non nullable StatusCheckpoint
foundCount

Number of checkpoint items associated with the property or unit, if quantifiable.

Type: Int
fulfilledNot nullable.

Whether the checkpoint conditions were satisfied. If false, the content requirement has not been met; verify that content is included in the Listings integration file for processing.

Type: Boolean
lastEvaluatedNot nullable.

UTC time when we last evaluated the checkpoint. This can help identify whether the data is stale if you see an unexpected status.

Type: String
maxCount

Maximum threshold allowed for the checkpoint to be satisfied, if applicable.

Type: Int
minCount

Minimum threshold required for the checkpoint to be satisfied, if applicable.

Type: Int
nameNot nullable.

Checkpoint name. For the list of checkpoints that may be returned and those that fulfill minimum content requirements, see Intro to property status.

Type: String
pathNot nullable.

Ordered list of parent checkpoint nodes in the status calculation tree. If you need to reconstruct the tree, discover added context about a checkpoint, then this information may be useful.

Type: Array of non nullable String
resolutionStatusNot nullable.

Status of the checkpoint retrieval.

Type: ResolutionStatus
String
String

The String scalar type represents textual data, represented as UTF-8 character sequences. The String type is most often used by GraphQL to represent free-form human-readable text.

SupplierAmount
Interface

Implemented by

FieldDescription
currencyCodeNot nullable.

Currency in which the amount is shown.

Type: String
rateTypeNot nullable.

Rate type.

Type: RateType
SupplierAmountCompensation
Object

Compensation information associated with the reservation for this date range.

FieldDescription
acceleratorPercent

Accelerator percentage, expressed as a fraction of 1 (for example, 0.25).

Type: Float
basePercent

Compensation base percentage, expressed as a fraction of 1 (for example, 0.25).

Type: Float
SupplierFeeType
Enum

Type of fee charged by the lodging partner.

NameDescription
BASE_RATE

Nightly rate with no additional taxes, fees, or surcharges.

EXTRA_GUEST_FEES

Fees that are included in the price that guests see when booking. They are paid in advance for Expedia Collect reservations or upon arrival for Hotel Collect reservations.

SERVICE_FEES

Fees that only apply to guests who make use of specific facilities or services, such as resort fees, parking fees, or fees for rollaway beds.

RECONCILED_AMOUNT

Updated rate, which must be the commissionable value for the stay date. Amounts for dates included in the original reservation cannot be modified to a value of three times more than the commissionable rate applicable to that date.

SupplierLoyaltyPlanInfo
Object

Details about the frequent traveler reward program. This field identifies if the traveler is a member of the supplier's loyalty program to ensure the supplier is able to greet the guest accordingly and award loyalty points as needed.

FieldDescription
membershipNumber

Traveler's membership number.

Type: String
planCode

Reward program code.

Type: String
SupplierRate
Object
FieldDescription
fromDateNot nullable.

Date when the rate becomes effective (format: YYYY-MM-DD).

Type: LocalDate
rateItemsNot nullable.

Itemized list of fees.

Type: Array of non nullable SupplierRateItem
rateTimeUnitNot nullable.

Time unit of the rate.

Type: RateTimeUnit
toDateNot nullable.

Date when the rate expires (format: YYYY-MM-DD).

Type: LocalDate
SupplierRateItem
Object
FieldDescription
amountNot nullable.

Amount of the fee.

Type: Float
feeTypeNot nullable.

Type of fee for this itemized rate.

Type: SupplierFeeType
SupplierTotal
Object
FieldDescription
amountAfterTaxNot nullable.

Total amount of the fee after tax is applied.

Type: Float
amountBeforeTaxNot nullable.

Total amount of the fee before tax is applied.

Type: Float
compensationNot nullable.

Compensation information associated with the reservation.

Type: SupplierAmountCompensation
Surcharge
Object

Extra amount to charge for an extra bed.

FieldDescription
amount

Amount of the surcharge. Must be defined if type is not 'Free'.

Type: Decimal
typeNot nullable.

Surcharge type.

Type: String
Text
Object

Key-value pairs that specify free text elements.

FieldDescription
keyNot nullable.

Name of text element.

Type: String
valuesNot nullable.

Localized value of text element.

Type: Array of non nullable LocalizedString
ThirdPartyValidation
Object

Third-party validation information.

FieldDescription
attributes

Attributes used to validate the registration number as provided by the third-party.

Type: Array of String
requiredNot nullable.

Whether third-party validation is required.

Type: Boolean
TravelDateInput
InputObject
FieldDescription
from

Start date of the travel window (format: YYYY-MM-DD).

Type: LocalDate
to

End date of the travel window (format: YYYY-MM-DD).

Type: LocalDate
TravelPurpose
Enum

Values for a guest's travel purpose, to identify business bookings.

NameDescription
NONE
KNOWN_BUSINESS_VISIT
SUSPECTED_BUSINESS_VISIT
KNOWN_PERSONAL_VISIT
SUSPECTED_PERSONAL_VISIT
Unit
Object

Unit details.

FieldDescription
ageCategoriesNot nullable.

Minimum age(s) for the specified age category.

Type: Array of non nullable UnitAgeCategory
amenities

Amenities available in the unit. You can filter by amenity name or whether it's available (active) by specifying the filters argument (type: AmenitiesFiltersInput).

Type: Array of non nullable Amenity
area

Unit's size and unit of measure.

Type: PropertyUnitArea
bedGroupsNot nullable.

Bed groups defined for the unit.

Type: Array of non nullable BedGroup
count

Cardinality of this unit configuration on the property.

Type: Int
extraBedsNot nullable.

Extra beds offered by the unit.

Type: Array of non nullable ExtraBedType
idNot nullable.

Expedia ID of the unit.

Type: ID
ids

Known IDs for the unit in the source system(s).

Type: Array of IdNode
maxOccupancyNot nullable.

Maximum occupancy of the unit in total and by age category.

Type: UnitOccupancy
nameConfigNot nullable.

Collection of elements and attributes related to the name of a unit.

Type: UnitNameConfig
propertyIdNot nullable.

Expedia ID of the property associated with this unit.

Type: ID
rateThresholdsNot nullable.

Minimum and maximum acceptable amounts that can be pushed for a unit night under any rate plan of the unit.

Type: RateThresholds
registration

Registration information for the unit or room type. You can specify the locale argument to retrieve the results in a specific language; specify the four-letter ISO code for language. Use a four-character code that indicates language and region, such as fr_FR for French in France.

Type: Registration
smokingPolicyNot nullable.

Smoking policy of this unit.

Type: UnitSmokingPolicy
spaces

Spaces available in the unit (as created by createUnitSpaces).

Type: UnitSpaces
statusNot nullable.

Unit status in Expedia's system.

Type: UnitStatus
UnitAgeCategory
Object

Minimum age for the specified age category.

FieldDescription
categoryNot nullable.

Category of age being defined.

Type: String
minAgeNot nullable.

Minimum age for a person belonging to the specified age category.

Type: Int
UnitNameAccessibility
Object

Attributes that determine if unit has accessibility.

FieldDescription
accessibilityTypeOverrideNot nullable.

Type of accessibility to be included in the name as specified; this will override includeAccessibility if present.

Type: String
includeAccessibilityNot nullable.

Whether to include 'Accessible' in the unit name. When accessibilityTypeOverride is provided, this field is set to true.

Type: Boolean
UnitNameAttributes
Object

Collection of attributes that can be used to build a unit name.

FieldDescription
accessibilityNot nullable.

Whether the unit has accessibility.

Type: UnitNameAccessibility
bedroomDetailsNot nullable.

Details of the bedroom, which is used to compose the name.

Type: String
customLabelNot nullable.

Custom label (up to 37 characters) used as a suffix to the unit name; always used in the name if provided. This text is not localized.

Type: String
featuredAmenityNot nullable.

Highlights a feature of the unit, which is used to compose the name.

Type: String
includeBedTypeNot nullable.

Whether to include bed type on the unit name. Not all bed combinations are fully displayed in the room name. Some combinations are displayed as “multiple beds” in the unit name.

Type: Boolean
includeSmokingPolicyNot nullable.

Whether to include unit smoking preferences in the unit name. When smokingPolicy is set to SMOKING_AND_NON_SMOKING and includeSmokingPolicy is set to true, the room name will specify SMOKING only.

Type: Boolean
locationNot nullable.

Highlights the location of the unit, which is used to compose the name.

Type: String
unitClassNot nullable.

Class of unit, which is used to compose the name (such as Basic, Standard, and so on).

Type: String
unitTypeNot nullable.

Type of unit, which is used to compose the name (such as Room, Apartment, Cabin, and so on).

Type: String
viewNot nullable.

Additional information about the view of the unit, which is used to compose the name.

Type: String
UnitNameConfig
Object

Collection of elements and attributes related to the name of a unit.

FieldDescription
attributesNot nullable.

Collection of attributes that can be used to build a unit name.

Type: UnitNameAttributes
valueNot nullable.

An auto-generated attribute name that is returned if attributes are provided.

Type: String
UnitOccupancy
Object

Maximum occupancy of the unit in total and by age category.

FieldDescription
adultsNot nullable.

Maximum number of adults that can reside in the unit; this will be at least 1 and less than or equal to the total.

Type: Int
childrenNot nullable.

Maximum number of children that can reside in the unit; this will be less than the total.

Type: Int
totalNot nullable.

Total count of people that can reside in the unit; this will be at least 1.

Type: Int
UnitSmokingPolicy
Enum

Smoking policy values.

NameDescription
NON_SMOKING
SMOKING
SMOKING_AND_NON_SMOKING
UnitSpaces
Object

Spaces available in the unit (as created by createUnitSpaces).

FieldDescription
bedrooms

Bedrooms available in the unit.

Type: Array of non nullable Bedroom
livingRooms

Living rooms available in the unit.

Type: Array of non nullable LivingRoom
UnitState
Enum

Unit status values.

NameDescription
ACTIVE
INACTIVE
UnitStatus
Object

Unit status in Expedia's system.

FieldDescription
stateNot nullable.

Unit status.

Type: UnitState
Url
Url

Scalar type whose value conforms to the standard URL format as specified in RFC3986 specification.

ZoneDateTime
ZoneDateTime

A type representing a date and time with a time zone in the format YYYY-MM-DDTHH:mm:ssTZD, where TZD is a time zone designator in the form +/-hh:mm).