Retrieve Reservations
UlysesCloud will request undelivered Reservation from ChannelManager using OTA_ReadRQ message. Channel Manager will respond with a OTA_ResRetrieveRS that contain the reservations.
OTA_ReadRQ
The OTA_ReadRQ message will be used to request undelivered reservation, modification or cancellations.
Example of Request
<OTA_ReadRQ EchoToken="73132ed2-a8a0-48e4-9710-7ff2239aee72" TimeStamp="2021-04-22T14:58:35.579+02:00" Version="1" xmlns="http://www.opentravel.org/OTA/2003/05">
<POS>
<Source>
<RequestorID Type="22" ID="ULYSESCLOUD"/>
</Source>
</POS>
<ReadRequests>
<HotelReadRequest HotelCode="UC123">
<SelectionCriteria SelectionType="Undelivered"/>
</HotelReadRequest>
</ReadRequests>
</OTA_ReadRQ>
Element | Number | Description |
---|---|---|
OTA_ReadRQ | 1 | Main element |
@Version | 1 | Current Version 1 |
@EchoToken | 1 | Globally unique identifier for the request, the value will be returned in the response EchoToken. |
@TimeStamp | 1 | Time of the transaction in xml schema dateTime format |
OTA_ReadRQ / POS / Source / RequestorID | 1 | This identifies the system which is sending the reservation |
@Type | 1 | Fixed at 22 (ESRP) |
@Id | 1 | The ID used will be agreed by the trading partners and remain the same throughout the messages |
OTA_ReadRQ / ReadRequests | 1 |
|
ReadRequests / HotelReadRequest | 1 |
|
@HotelCode | 1 | Hotel code as recognised by Channel Manager |
HotelReadRequest / SelectionCriteria | 1 | The time the reservation was updated on the PMS |
@SelectionType | 1 | Must be "Undelivered" |
OTA_ResRetrieveRS
This message is returned to the PMS in response to the OTA_ReadRQ message.
Example of Response
<OTA_ResRetrieveRS EchoToken="3301a089-7abf-4543-87df-bdb8f0ee37ca" TimeStamp="2021-04-20T14:23:26Z" Version="1" xmlns="http://www.opentravel.org/OTA/2003/05" xmlns:ns2="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" xmlns:ns3="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
<Success/>
<ReservationsList>
<HotelReservation ResStatus="Book" CreateDateTime="2021-04-20T14:22:33Z">
<POS>
<Source>
<RequestorID Type="22" ID="CHANNEL_MANAGER"/>
<BookingChannel Type="7" Primary="true">
<CompanyName Code="BDC">Booking.com</CompanyName>
</BookingChannel>
</Source>
</POS>
<UniqueID Type="14" ID="BDC-36909627"/>
<UniqueID Type="16" ID_Context="MESSAGE_UNIQUE_ID" ID="x1aphaap8exx0cbk"/>
<RoomStays>
<RoomStay>
<RoomTypes>
<RoomType RoomType="Single Room" RoomTypeCode="TWN">
<RoomDescription>
<Text>This air-conditioned room features a small kitchenette</Text>
</RoomDescription>
</RoomType>
</RoomTypes>
<RatePlans>
<RatePlan RatePlanCode="RO|1000|ST10" EffectiveDate="2021-04-23" ExpireDate="2021-04-26"/>
</RatePlans>
<RoomRates>
<RoomRate RoomTypeCode="TWN" NumberOfUnits="1" RatePlanCode="RO|1000|ST10">
<Rates>
<Rate RateTimeUnit="Day" UnitMultiplier="1" EffectiveDate="2021-04-23" ExpireDate="2021-04-24">
<Total AmountAfterTax="110.00" CurrencyCode="USD"/>
</Rate>
<Rate RateTimeUnit="Day" UnitMultiplier="1" EffectiveDate="2021-04-24" ExpireDate="2021-04-25">
<Total AmountAfterTax="80.00" CurrencyCode="USD"/>
</Rate>
<Rate RateTimeUnit="Day" UnitMultiplier="1" EffectiveDate="2021-04-25" ExpireDate="2021-04-26">
<Total AmountAfterTax="80.00" CurrencyCode="USD"/>
</Rate>
</Rates>
</RoomRate>
</RoomRates>
<GuestCounts>
<GuestCount AgeQualifyingCode="10" Count="1"/>
</GuestCounts>
<TimeSpan Start="2021-04-23" End="2021-04-26"/>
<Total AmountAfterTax="270.00" CurrencyCode="USD"/>
<BasicPropertyInfo HotelCode="UlysesCloud1063"/>
<ResGuestRPHs>
<ResGuestRPH RPH="1"/>
</ResGuestRPHs>
<Comments>
<Comment>
<Text>smoking preference Non-Smoking</Text>
</Comment>
</Comments>
</RoomStay>
</RoomStays>
<Services>
<Service ServiceRPH="1" ServiceInventoryCode="e_michstar" Inclusive="true" Quantity="2">
<Price>
<Total AmountBeforeTax="0.00" AmountAfterTax="566.00" CurrencyCode="EUR"/>
<RateDescription>
<Text>Service: 2xSan Sebastián, City of Michelin Stars. (e_michstar)</Text>
</RateDescription>
</Price>
<ServiceDetails>
<TimeSpan Start="2020-07-15" End="2020-07-16"/>
</ServiceDetails>
</Service>
</Services>
<ResGuests>
<ResGuest ResGuestRPH="1">
<Profiles>
<ProfileInfo>
<Profile ProfileType="1">
<Customer>
<PersonName>
<GivenName>Fiona</GivenName>
<Surname>Brown</Surname>
</PersonName>
<Telephone PhoneNumber="1111111111"/>
<Address>
<AddressLine>88 Cumberland St</AddressLine>
<CityName>Sydney</CityName>
<PostalCode>2000</PostalCode>
<CountryName>AU</CountryName>
</Address>
</Customer>
</Profile>
</ProfileInfo>
</Profiles>
</ResGuest>
<ResGuest ResGuestRPH="2" PrimaryIndicator="true">
<Profiles>
<ProfileInfo>
<Profile ProfileType="1">
<Customer>
<PersonName>
<GivenName>James</GivenName>
<Surname>McDonald</Surname>
</PersonName>
<Telephone PhoneNumber="1111111111"/>
<Address>
<AddressLine>88 Cumberland St</AddressLine>
<CityName>Sydney</CityName>
<PostalCode>2000</PostalCode>
<CountryName>AU</CountryName>
</Address>
</Customer>
</Profile>
</ProfileInfo>
</Profiles>
</ResGuest>
</ResGuests>
<ResGlobalInfo>
<DepositPayments>
<GuaranteePayment>
<AmountPercent TaxInclusive="true" Amount="1184.00" CurrencyCode="EUR"/>
</GuaranteePayment>
</DepositPayments>
<Guarantee>
<GuaranteesAccepted>
<GuaranteeAccepted>
<PaymentCard CardType="1" CardCode="MC" CardNumber="555555TQAQKT4444" ExpireDate="0820">
<CardHolderName>J McDonald</CardHolderName>
</PaymentCard>
</GuaranteeAccepted>
</GuaranteesAccepted>
</Guarantee>
<Total AmountAfterTax="625.00" CurrencyCode="USD"/>
<HotelReservationIDs>
<HotelReservationID ResID_Type="14" ResID_Value="36909627"/>
</HotelReservationIDs>
<Profiles>
<ProfileInfo>
<Profile ProfileType="1">
<Customer>
<PersonName>
<GivenName>James</GivenName>
<Surname>McDonald</Surname>
</PersonName>
<Telephone PhoneNumber="1111111111"/>
<Address>
<AddressLine>88 Cumberland St</AddressLine>
<CityName>Sydney</CityName>
<PostalCode>2000</PostalCode>
<CountryName>AU</CountryName>
</Address>
</Customer>
</Profile>
</ProfileInfo>
</Profiles>
</ResGlobalInfo>
</HotelReservation>
</ReservationsList>
</OTA_ResRetrieveRS>
OTA_ResRetrieveRS
Element | Number | Description |
---|---|---|
OTA_ResRetrieveRS | 1 | Main element |
@EchoToken | 1 | Return the EchoToken from the request message |
@Version | 1 | Current Version 1 |
@TimeStamp | 1 | Time of the transaction in xml schema dateTime format |
OTA_ResRetrieveRS / Success | 0 - 1 | Should only be present if the request processed successfully. The Errors node will not be present if the Success node is present |
OTA_ResRetrieveRS / Errors | 0 - 1 | Contains a list of errors if the request failed to process |
Errors / Error | 1 - n | Should be at least one node if there is an Errors Node |
@Type | 1 | Mandatory if Error present. |
@Code | 0 - 1 | Any code from the OTA code table for 'Error Codes (ERR)' can be used |
OTA_ResRetrieveRS / ReservationsList | 0 - 1 | ReservationList is only present if there are HotelReservation elements |
ReservationsList / HotelReservation | 1 - n | List of reservations |
@CreateDateTime | 1 | This is the date when the reservation was first made. Mandatory if ResStatus is "Book |
@LastModifyDateTime | 0 - 1 | This indicates the last date and time when the reservation was last modified. Mandatory if ResStatus is "Modify" or "Cancel" |
@ResStatus | 1 | Status is "Book", "Modify" or "Cancel" |
HotelReservation / UniqueID | 2 | The reservation reference in ChannelManager. The first UniqueID element will contain the unique identifier for the entire reservation. This identifier will identify the reservation through any subsequent modifications or cancellations. The second UniqueID element with ID_Context="MESSAGE_UNIQUE_ID" is the unique id for this message. This identifier should be used to confirm the message once processed |
@Type | 1 | Value '14' is the unique id for the reservation in ChannelManager. Value '16' is the unique id for the message transferring the reservation. |
@ID | 1 | Identifier of the reservation according to ChannelManager. Note, this is NOT the reservation id according to the upstream system. This is located in the HotelReservationID element. |
@ID_Context | 0 - 1 | Only present for the second UniqueID element and when present it will always be "MESSAGE_UNIQUE_ID" |
HotelReservation / POS | 1 | Point of sale |
POS / Source | 1 | Source of the reservation |
Source / RequestorID | 1 | This identifies the system which is sending the reservation. This element will only appear in the first Source element. |
@Type | 1 | Fixed at 22 (ESRP) |
@ID | 1 | Value is your ChannelManager Name |
Source / BookingChannel | 1 | Contains booking channel information |
@Primary | 1 | Indicates the primary booking source |
@Type | 1 | Always '7' for 'Internet'. |
BookingChannel / CompanyName | 1 | Name of the Booking Channel. |
@Code | 1 | Channel Manager code to identify the Booking Channel. |
HotelReservation / RoomStays / RoomStay | 0 - n | One instance of RoomStay per room booked. See RoomStay |
Reservation / ResGuests / ResGuest | 0 - n | One instance of ResGuest per reservation guests. This guest information is dependent on the sometimes limited information retrieved from the booking agents. ResGuests might not always be directly linkable to the RoomStays. Either all ResGuests are linked to RoomStays or none are. See ResGuest |
HotelReservation / Services / Service | 0 - n | A list of service fees and extra charges linked to the HotelReservation See Service |
HotelReservation / ResGlobalInfo | 1 | Contains general information about the Reservation See ResGlobalInfo |
RoomStay
Element | Number | Description |
---|---|---|
RoomStay / RoomTypes / RoomType | 0 - 1 | Container for room information. There will only ever be one RoomType per RoomStay |
@RoomType | 0 - 1 | The name of the RoomType as provided by source channel |
@RoomTypeCode | 0 - 1 | Room code, identifier for the room |
RoomType / RoomDescription / Text | 0 - 1 | A text description of the room |
RoomStay / RatePlans | 0 - 1 | Container for rate information |
RatePlans / RatePlan | 0 - n | Contains information for the Rate Plan used for the RoomStay |
@RatePlanCode | 0 - 1 | Rate code, identifier for the rate plan |
@RatePlanName | 0 - 1 | Name of the rate plan as provided the source channel |
@EffectiveDate | 1 | The effective date of the RatePlan |
@ExpireDate | 1 | The expire date for a RatePlan, this should be considered an exclusive date, the date for which the current rate plan information is no longer valid. |
RatePlan / RateDescription / Text | 0 - 1 | A text description of the rate |
RoomStay / RoomRates / RoomRate | 1 - n | Multiple RoomRates per RoomStay. Multiple rates are listed under each RoomRate. This can happen when there is a single room booked but more than one rate plan applies during the stay |
@RoomTypeCode | 1 | The code of the room booked |
@NumberOfUnits | 1 | Always 1. Each room will be listed in it's own RoomStay element |
@RatePlanCode | 1 | This is the rate booked for the room type code listed in the RoomTypeCode attribute. |
RoomRate / Rates | 0 - 1 | Container for the daily rate breakdown information |
Rates / Rate | 1 - n | The Rate element contains a timespan with daily rate information. The dates covered in the Rates will cover all the dates in the RoomStay/TimeSpan element |
@EffectiveDate | 1 | The starting date of the rate in the form yyyy-MM-dd. This date is inclusive. |
@ExpireDate | 1 | ExpireDate is the first day after the applicable period. Format yyyy-MM-dd. This date is exclusive. |
@RateTimeUnit | 1 | Always "Day" |
@UnitMultiplier | 1 | The total number of nights covered by the price |
Rate / Base | 0 - 1 | Specifies the base per-day rate for the room. This is the gross amount charged for the room, not including any discounts or extra charges |
@CurrencyCode | 0 - 1 | The ISO currency code for the total |
@AmountAfterTax | 0 - 1 | The total amount after tax |
@AmountBeforeTax | 0 - 1 | The total amount before tax |
Taxes | 0 - 1 | The total tax amount for the TotalType |
@Amount | 0 - 1 | The total tax amount |
Rate / Total | 0 - 1 | The total amount charged for the Rate. Will be equal to the Base amount with the extras and discounts applied. Note that the Total is gross, in other words the FULL amount charged for the per date rate as provided by the source channel. |
@CurrencyCode | 0 - 1 | The ISO currency code for the total |
@AmountAfterTax | 0 - 1 | The total amount after tax |
@AmountBeforeTax | 0 - 1 | The total amount before tax |
Taxes | 0 - 1 | The total tax amount for the TotalType |
@Amount | 0 - 1 | The total tax amount |
RoomRate / ServiceRPHs / ServiceRPH | 0 - n | Contains links to any service or extra charges for the rate |
@RPH | 1 - n | Links a Service/@ServiceRPHA to this RoomRate |
RoomStay / GuestCounts / GuestCount | 0 - n | The guest count specifies a part of the occupancy |
@AgeQualifyingCode | 1 | Specifies the guest type for this GuestCount - uses OTA Spec for identifiers, will be one of three values |
@Count | 1 | Number of guests |
RoomStay / TimeSpan | 1 | Contains the timespan which this RoomStay covers |
@Start | 1 | Check in date |
@End | 1 | Check out date |
RoomStay / Total | 0 - 1 | The total amount of the RoomStay. Will add up to the sum of Rate / Total*NumberOfUnits. If no Rate / Total is present, will be the sum of Rate / Base*NumberOfUnits plus any additional costs, such as fees/services etc. IE The total cost for the RoomStay. |
@CurrencyCode | 0 - 1 | The ISO currency code for the total |
@AmountAfterTax | 0 - 1 | The total amount after tax |
@AmountBeforeTax | 0 - 1 | The total amount before tax |
Taxes | 0 - 1 | The total tax amount for the TotalType |
@Amount | 0 - 1 | The total tax amount |
RoomStay / BasicPropertyInfo | 0 - 1 | Holds information about the Hotelier which this reservation is for. |
@HotelCode | 1 | The Channel Managerhotel identifier |
RoomStay / ServiceRPHs / ServiceRPH | 0 - n | Contains links to any service or extra charges for the room |
@RPH | 1 | Links a Service/@ServiceRPHA to this RoomStay |
RoomStay / ResGuestRPHs / ResGuestRPH | 0 - n | Used to link guests from the ResGuests list to the RoomStay |
@RPH | 1 | Links a ResGuest/@ResGuestRPH to this RoomStay |
RoomStay / Comments / Comment / Text | 0 - 1 | RoomStay comments |
ResGuest
Element | Number | Description |
---|---|---|
@ResGuestRPH | 0 - 1 | This value links the ResGuest to RoomStay(s) where possible. You can find the links in RoomStay / ResGuestRPHs. |
@ArrivalTime | 0..1 | The arrival time of the guest in the form HH:mm:ss. |
@PrimaryIndicator | 0..1 | When true indicates this is the primary guest |
ResGuest / Profiles | 1 | Contains the guest profile information See Profiles |
ResGuest / Comments / Comment | 0 - 1 | Container for extra information about the guest |
@Name | 0 - 1 | Identifier for the comment |
Comment / Text | 1 | Text for the guest extra information |
Service
Element | Number | Description |
---|---|---|
@ServiceInventoryCode | 1 | The identifier code for the service as given by the source booking channel will be provided here. |
@ServiceRPH | 0 - 1 | This links a Service to a RoomStay or a RoomRate. The absence of a ServiceRPH indicates that this is a HotelReservation level charge |
@Inclusive | 1 | Always 'true' |
@Quantity | 0 - 1 | The number of units included in the charge. |
@ID | 0 - 1 | The reference id provided for a extra/service by the source booking channel |
@ID_Context | 0 - 1 | If ID present, will always be 'CHANNEL' |
Service / Price | 1 | Container for the price |
Price / Base | 0 - 1 | The amount per unit for this extra charge as provided by the hotel. |
@CurrencyCode | 0 - 1 | The ISO currency code for the unit amount |
@AmountAfterTax | 0 - 1 | The unit amount after tax |
@AmountBeforeTax | 0 - 1 | The unit amount before tax |
Price / Total | 0 - 1 | The total amount for the extra charge for all units |
@CurrencyCode | 0 - 1 | The ISO currency code for the unit amount |
@AmountAfterTax | 0 - 1 | The unit amount after tax |
@AmountBeforeTax | 0 - 1 | The unit amount before tax |
Price / RateDescription / Text | 0 - 1 | A text description of the service/extra |
Service / ServiceDetails | 0 - 1 |
|
ServiceDetails / TimeSpan | 0 - 1 | Start date for which the extra charge applies |
@Start | 0 - 1 | Start date for which the extra charge applies |
@End | 0 - 1 | End date for which the extra charge applies. This is an inclusive date, the last date for which the charge applies |
ResGlobalInfo
Element | Number | Description |
---|---|---|
HotelReservationIDs / HotelReservationID | 1 | Reference number/string or PNR as supplied by the Booking agent will be supplied here |
@ResID_Type | 1 | Always ‘14’ |
@ResID_Value | 1 | Reference number/string supplied by the Booking agent |
Total | 0 - 1 | The total amount for the Reservation. Will add up to the sum of the RoomStay totals PLUS any additional fees sent by the BookingAgent. |
@CurrencyCode | 0 - 1 | The ISO currency code for the total |
@AmountAfterTax | 0 - 1 | The total amount after tax |
@AmountBeforeTax | 0 - 1 | The total amount before tax |
Profiles | 0 - 1 | This is a listing of Profiles associated with the reservation that are not Guests. This includes Customers, Travel Agents and Travel Arrangers. The Customer is the contact person for the Reservation. If the customer is also a guest, they will also be included in the ResGuest profile. See Profile |
DepositPayments | 0 - 1 | Contains the deposit information |
DepositPayments / GuaranteePayment / AmountPercent | 1 |
|
@Amount | 0 - 1 | The deposit as a currency amount. At least @Amount or @Percent will be populated. |
@CurrencyCode | 0 - 1 | This is the ISO currency code of the deposit. Mandatory if @Amount exists. |
@Percent | 0 - 1 | This is the percentage of the Total charge for the deposit (rounded to 3 decimal places). If the the Total.amountAfterTax is provided, it will be a percentage of this value. If only the amountBeforeTax is provided it will be the percentage of this value. At least @Amount or @Percent will be populated. |
@TaxInclusive | 0 - 1 | Indicates if tax is included in @Amount |
Guarantee | 0 - 1 | Guarantee information |
Guarantee / GuaranteesAccepted / GuaranteeAccepted / PaymentCard | 0 - 1 | Contains payment card information |
@CardCode | 0..1 | The 2 character code of the credit card issuer. Please see the OTA Payment Card Provider Codes table for reference |
@CardType | 0 - 1 | The type of payment card, refer to the OTA Card Type code table for reference. Common usages are: 1: Credit |
@CardNumber | 0 - 1 | The number embossed on the payment card |
@ExpireDate | 0 - 1 | This is the expiry date of the payment card used in the format MMyy |
PaymentCard / CardHolderName | 0 - 1 | This is the name of the card holder. |
Profile
Element | Number | Description |
---|---|---|
Profiles / ProfileInfo | 1 - n | Profile information |
ProfileInfo / UniqueID | 0 - n | Contains profile ids provided by the source channel. There can 0 to many identifiers passed through here |
@Type | 1 | This will always be "16" to represent 'Reference' from the OTA code table Unique Id Type (UIT) |
@ID | 1 | The reference identifier for the profile as provided by the source channel |
@ID_Context | 1 | This can be one of 2 values: CHANNEL: To specify that this is a channel reference id |
ProfileInfo / Profile | 1 | Contains the profile information |
@ProfileType | 1 | The type of profile See OTA Profile Type (PRT) code table. Some common usages are below 1: Customer |
Profile / Customer | 1 |
|
Customer / PersonName | 0 - 1 | Profile name details. Always present for type Customer |
PersonName / NamePrefix | 0 - 1 | Name prefix |
PersonName / GivenName | 0 - 1 | The name of the profile. Always present for type Customer |
PersonName / MiddleName | 0 - 1 | The middle name of the profile |
PersonName / Surname | 0 - 1 | The last name of the profile. Always present for type Customer |
Customer / Telephone | 0 - 1 | Contact telephone number for the profile if available |
@PhoneNumber | 0 - 1 | The actual number, will be there if the Telephone element is there |
@PhoneUseType | 0 - 1 | The type of phone use for example daytime, nighttime, work. If this field is blank this is the primary phone, otherwise PhoneUseType="4" denotes a secondary or nighttime phone |
@PhoneTechType | 0 - 1 | The type of phone technology, if not provided it should be assumed as a landline 5: Mobile |
Customer / Email | 0 - 1 | The email address of the profile if available |
Customer / Address | 0 - 1 | Address information for the profile if available |
Address / AddressLine | 0 - n | One or more address lines for the profile |
Address / CityName | 0 - 1 | Customer city of residence if available |
Address / PostalCode | 0 - 1 | Post code for profile if available |
Address / StateProv | 0 - 1 | State or province name |
Address / CountryName | 0 - 1 | Country name |
Address / CompanyName | 0 - 1 | Company name |
Customer / CustLoyalty | 0 - 1 | A list of Memberships. Memberships provides a list of reward programs. |
@MembershipID | 0 - 1 | The account identification number for this particular member in this particular program. |
@ProgramID | 0 - 1 | The defined membership program name or ID applicable to program. This will be in the form as provided by the source booking channel. |
@ExpiryDate | 0 - 1 | The expiry date of the program membership issued to card holder. Date format is yyyy-MM-dd |