Master-Interlook:HotelService — различия между версиями

Материал из Megatec
Перейти к: навигация, поиск
[досмотренная версия][досмотренная версия]
м (Методы поиска)
(SearchBookings (Получение списка забронированных заявок))
 
(не показано 14 промежуточных версий этого же участника)
Строка 12: Строка 12:
 
<BR>
 
<BR>
  
 +
==Подключение к базе данных ПК «Мастер-Interlook»==
 +
В файле <code>web.config</code>, расположенном в папке '''Interlook.HotelServiceService''' пропишите необходимые параметры подключения (<span style="color:red">красным цветом</span> выделены значения, которые необходимо ввести).
 +
Строка подключения к базе данных ПК «Мастер-Interlook»:<br />
 +
<code><add key = "connectionString" value = "Data Source=<span style="color:red">ip-адрес сервера базе данных ПК «Мастер-Interlook»</span>;Initial Catalog=<span style="color:red">название базы данных ПК «Мастер-Interlook»</span>;User ID=<span style="color:red">логин пользователя ПК «Мастер-Interlook»</span>;Password=<span style="color:red">пароль пользователя ПК «Мастер-Interlook»</span>"/></code>
 +
==Настройки в файле WEB.CONFIG==
 +
Настройки задаются в секции <code><appSettings></code> файла <code>web.config</code> основного приложения Interlook.HotelServiceService.
 +
{| border="1" cellpadding="8" style="background-color:#F9F9F9; border:#AAAAAA; border-collapse:collapse"
 +
 +
|- style="background-color:#F2F2F2"
 +
 +
! width="2%" | №
 +
! width="28%" | Описание
 +
! width="35%" | Значение
 +
! width="35%" | Настройка
 +
 +
|- style="vertical-align:text-top"
 +
 +
| 1
 +
| Процедура перезапуска кэша
 +
| '''cachingTime'''
 +
"cachingTime" value="-1" - инициализация кэша максимально производительная: каждый отель загружается в своем потоке (возможны сбои).</br>
 +
"cachingTime" value="-2"/> - весь кэш загружается в 2 потока.
 +
|<syntaxhighlight lang="xml" enclose="div">
 +
<add key="cachingTime" value="-1"/>
 +
</syntaxhighlight>
 +
 +
|- style="vertical-align:text-top"
 +
 +
| 2
 +
| Включение логирования о использовании памяти сервера
 +
| '''LogCacheMemory'''</br>
 +
Настройка служит для включения или отключения логирования в таблицу базы данных о использовании кешем сервиса памяти сервера.</br>
 +
0 - выключена, 1 - включена </br>
 +
|<syntaxhighlight lang="xml" enclose="div">
 +
<add key="LogCacheMemory" value="0"/>
 +
</syntaxhighlight>
 +
 +
|- style="vertical-align:text-top"
 +
 +
|}
 
=Методы HotelService=
 
=Методы HotelService=
  
Строка 105: Строка 145:
 
* '''inwork''' – возвращает информацию по заявкам взятым отелем в работу. <br />
 
* '''inwork''' – возвращает информацию по заявкам взятым отелем в работу. <br />
 
Заявка получает статус InWork в следующих случаях:<br />
 
Заявка получает статус InWork в следующих случаях:<br />
- если через [[Master-Interlook:HotelService#|HotelService]] в методе [[Master-Interlook:HotelService#ManageBooking|ManageBooking]] по заявке передан параметр <hotelWorkStatus>true</hotelWorkStatus><br />
+
- если через [[Master-Interlook:HotelService#|HotelService]] в методе [[Master-Interlook:HotelService#ManageBooking (Передача изменений по услуге проживания в Interlook)|ManageBooking]] по заявке передан параметр <hotelWorkStatus>true</hotelWorkStatus><br />
 
- если по заявке распечатано или отправлено какое-либо из уведомлений по кнопке Actions в окне Interlook.<br />
 
- если по заявке распечатано или отправлено какое-либо из уведомлений по кнопке Actions в окне Interlook.<br />
 
* '''showConfirmed''' - отображает путевки со статусом Confirmed (false или отсутствие настройки означает, что путевки со статусом Confirmed не отображаются)
 
* '''showConfirmed''' - отображает путевки со статусом Confirmed (false или отсутствие настройки означает, что путевки со статусом Confirmed не отображаются)
Строка 156: Строка 196:
 
******* '''CostOfferDuration''' – продолжительность проживания до данному CostOffer
 
******* '''CostOfferDuration''' – продолжительность проживания до данному CostOffer
 
***** '''Penalty''' – информация о штрафах по аннулированной заявке  
 
***** '''Penalty''' – информация о штрафах по аннулированной заявке  
 +
***** '''FlightInfo''' – секция информации об авиаперелете
 +
****** '''Tourist''' – Фамилия и имя туриста
 +
****** '''Charters''' – секция авиаперелета
 +
******* '''CharterInfo''' – секция информации об авиаперелете
 +
******** '''Type''' – тип авиаперелета (Arrival или Departure)
 +
******** '''Date''' – дата заезда/выезда из отеля
 +
******** '''Details''' – наименование авиаперелета (номер рейса - время прилета/вылета)
 
*** '''MessageInfo''' – массив данных сообщений
 
*** '''MessageInfo''' – массив данных сообщений
 
**** '''Id''' – идентификатор сообщения
 
**** '''Id''' – идентификатор сообщения
Строка 173: Строка 220:
 
       <tem:SearchBookings>
 
       <tem:SearchBookings>
 
         <!--Optional:-->
 
         <!--Optional:-->
         <tem:guid>69ad76b6-3551-403d-934e-18d8358a60e2</tem:guid>
+
         <tem:guid>fd57bdcb-35e0-41b1-9743-eba763211e49</tem:guid>
 
         <!--Optional:-->
 
         <!--Optional:-->
 
         <tem:hotelID>
 
         <tem:hotelID>
 
             <!--Zero or more repetitions:-->
 
             <!--Zero or more repetitions:-->
             <tem:int>2942</tem:int>
+
             <tem:int>2930</tem:int>
 
         </tem:hotelID>
 
         </tem:hotelID>
 
         <tem:dateInfo>1</tem:dateInfo>
 
         <tem:dateInfo>1</tem:dateInfo>
         <tem:dateFrom>2022-01-02</tem:dateFrom>
+
         <tem:dateFrom>2022-08-19</tem:dateFrom>
         <tem:dateTo>2022-04-01</tem:dateTo>
+
         <tem:dateTo>2022-08-30</tem:dateTo>
        <tem:checkInFrom>2022-02-02</tem:checkInFrom>
+
         <tem:New>1</tem:New>
        <tem:checkInTo>2022-05-28</tem:checkInTo>
+
         <tem:change>1</tem:change>
         <tem:New>true</tem:New>
+
         <tem:cancel>1</tem:cancel>
         <tem:change>true</tem:change>
+
         <tem:inwork>1</tem:inwork>
         <tem:cancel>true</tem:cancel>
+
    </tem:SearchBookings>
         <tem:inwork>true</tem:inwork>
 
        <tem:showConfirmed>true</tem:showConfirmed>
 
      </tem:SearchBookings>
 
 
   </soapenv:Body>
 
   </soapenv:Body>
 
</soapenv:Envelope>
 
</soapenv:Envelope>
Строка 200: Строка 244:
 
       <SearchBookingsResponse xmlns="http://tempuri.org/">
 
       <SearchBookingsResponse xmlns="http://tempuri.org/">
 
         <SearchBookingsResult>
 
         <SearchBookingsResult>
    <Booking>MGR20228A01</Booking>
+
      <BookingInfo>
               <BookingID>37062</BookingID>
+
              <Booking>MT140101AAL</Booking>
 +
               <BookingID>37608</BookingID>
 
               <Action>Changed</Action>
 
               <Action>Changed</Action>
               <CreationDate>2022-02-14T11:40:03.61</CreationDate>
+
               <CreationDate>2022-08-25T14:37:12.25</CreationDate>
 
               <ChangeDate xsi:nil="true"/>
 
               <ChangeDate xsi:nil="true"/>
 
               <CancelDate xsi:nil="true"/>
 
               <CancelDate xsi:nil="true"/>
Строка 212: Строка 257:
 
               <HotelServices>
 
               <HotelServices>
 
                   <HotelServiceInfo>
 
                   <HotelServiceInfo>
                     <HotelServiceId>167845</HotelServiceId>
+
                     <HotelServiceId>171495</HotelServiceId>
                     <HotelServiceName>HTL::Kiev/Green/Double Room/2AD/Inner View/BB</HotelServiceName>
+
                     <HotelServiceName>HTL::Kiev/Red/Double Room/2AD/Jakuzzi/BB</HotelServiceName>
 
                     <Hotel>
 
                     <Hotel>
                         <HotelId>2942</HotelId>
+
                         <HotelId>2930</HotelId>
                         <HotelName>Green</HotelName>
+
                         <HotelName>Red</HotelName>
 
                     </Hotel>
 
                     </Hotel>
 
                     <Pansion>
 
                     <Pansion>
Строка 231: Строка 276:
 
                     </RoomAccomodation>
 
                     </RoomAccomodation>
 
                     <RoomCategory>
 
                     <RoomCategory>
                         <RoomCategoryId>19</RoomCategoryId>
+
                         <RoomCategoryId>20</RoomCategoryId>
                         <RoomCategoryName>Inner View</RoomCategoryName>
+
                         <RoomCategoryName>Jakuzzi</RoomCategoryName>
 
                     </RoomCategory>
 
                     </RoomCategory>
 
                     <Status>
 
                     <Status>
 
                         <StatusId>1</StatusId>
 
                         <StatusId>1</StatusId>
                         <StatusName>confirmed</StatusName>
+
                         <StatusName>Wait</StatusName>
 
                     </Status>
 
                     </Status>
                     <CheckIn>2022-02-28T00:00:00</CheckIn>
+
                     <CheckIn>2022-08-20T00:00:00</CheckIn>
                     <CheckOut>2022-04-04T00:00:00</CheckOut>
+
                     <CheckOut>2022-08-27T00:00:00</CheckOut>
 
                     <Tourists>
 
                     <Tourists>
 
                         <TouristInfo>
 
                         <TouristInfo>
                           <Name>Вровро Враовро</Name>
+
                           <Name>Vladimirov Alex</Name>
                           <BirthDate xsi:nil="true"/>
+
                           <BirthDate>1979-08-10T00:00:00</BirthDate>
 
                           <Sex>MR</Sex>
 
                           <Sex>MR</Sex>
                           <HotelServiceId>167845</HotelServiceId>
+
                           <HotelServiceId>171495</HotelServiceId>
 
                         </TouristInfo>
 
                         </TouristInfo>
 
                         <TouristInfo>
 
                         <TouristInfo>
                           <Name>Аврпро Варовро</Name>
+
                           <Name>Vladimirovicha Alexa</Name>
                           <BirthDate xsi:nil="true"/>
+
                           <BirthDate>1972-08-11T00:00:00</BirthDate>
 
                           <Sex>MR</Sex>
 
                           <Sex>MR</Sex>
                           <HotelServiceId>167845</HotelServiceId>
+
                           <HotelServiceId>171495</HotelServiceId>
 
                         </TouristInfo>
 
                         </TouristInfo>
 
                     </Tourists>
 
                     </Tourists>
 
                     <CostOffers>
 
                     <CostOffers>
 
                         <CostOfferInfo>
 
                         <CostOfferInfo>
                           <CostOfferName>kolesnyk/kolesnyk</CostOfferName>
+
                           <CostOfferName>kolesnyk2/kolesnyk2</CostOfferName>
                           <CostOfferDateBegin>2022-02-28T00:00:00</CostOfferDateBegin>
+
                           <CostOfferDateBegin>2022-08-20T00:00:00</CostOfferDateBegin>
                           <CostOfferDateEnd>2022-03-01T00:00:00</CostOfferDateEnd>
+
                           <CostOfferDateEnd>2022-08-27T00:00:00</CostOfferDateEnd>
                           <CostOfferDuration>1</CostOfferDuration>
+
                           <CostOfferDuration>7</CostOfferDuration>
                        </CostOfferInfo>
 
                        <CostOfferInfo>
 
                          <CostOfferName>Green - 14-12/Green - 14-12</CostOfferName>
 
                          <CostOfferDateBegin>2022-03-02T00:00:00</CostOfferDateBegin>
 
                          <CostOfferDateEnd>2022-03-12T00:00:00</CostOfferDateEnd>
 
                          <CostOfferDuration>10</CostOfferDuration>
 
                        </CostOfferInfo>
 
                        <CostOfferInfo>
 
                          <CostOfferName>kolesnyk/kolesnyk</CostOfferName>
 
                          <CostOfferDateBegin>2022-03-13T00:00:00</CostOfferDateBegin>
 
                          <CostOfferDateEnd>2022-03-14T00:00:00</CostOfferDateEnd>
 
                          <CostOfferDuration>1</CostOfferDuration>
 
                        </CostOfferInfo>
 
                        <CostOfferInfo>
 
                          <CostOfferName>Green - 14-12/Green - 14-12</CostOfferName>
 
                          <CostOfferDateBegin>2022-03-15T00:00:00</CostOfferDateBegin>
 
                          <CostOfferDateEnd>2022-03-18T00:00:00</CostOfferDateEnd>
 
                          <CostOfferDuration>3</CostOfferDuration>
 
                        </CostOfferInfo>
 
                        <CostOfferInfo>
 
                          <CostOfferName>kolesnyk/kolesnyk</CostOfferName>
 
                          <CostOfferDateBegin>2022-03-19T00:00:00</CostOfferDateBegin>
 
                          <CostOfferDateEnd>2022-04-04T00:00:00</CostOfferDateEnd>
 
                          <CostOfferDuration>20</CostOfferDuration>
 
 
                         </CostOfferInfo>
 
                         </CostOfferInfo>
 
                     </CostOffers>
 
                     </CostOffers>
Строка 289: Строка 310:
 
                   </HotelServiceInfo>
 
                   </HotelServiceInfo>
 
               </HotelServices>
 
               </HotelServices>
              <Messages>
+
              <Flights>
                   <MessageInfo>
+
                   <FlightInfo>
                     <Id>780510</Id>
+
                     <Tourist>Vladimirov Alex</Tourist>
                     <IsOutgoing>false</IsOutgoing>
+
                     <Charters>
                    <DateCreate>2022-03-15T18:33:07.953</DateCreate>
+
                        <CharterInfo>
                     <IsRead>false</IsRead>
+
                          <Type>Arrival</Type>
                     <Text>HTL::Kiev/Green/Double Room/2AD/Inner View/BB:
+
                          <Date>2022-08-20T00:00:00</Date>
                     ftigjhfjhjhkjhjhk</Text>
+
                          <Details>A123-A124 (A123 - 16:00)</Details>
                   </MessageInfo>
+
                        </CharterInfo>
 +
                        <CharterInfo>
 +
                          <Type>Departure</Type>
 +
                          <Date>2022-08-27T00:00:00</Date>
 +
                          <Details>A123-A124 (A124 - 15:00)</Details>
 +
                        </CharterInfo>
 +
                     </Charters>
 +
                  </FlightInfo>
 +
                  <FlightInfo>
 +
                     <Tourist>Vladimirovicha Alexa</Tourist>
 +
                    <Charters>
 +
                        <CharterInfo>
 +
                          <Type>Arrival</Type>
 +
                          <Date>2022-08-20T00:00:00</Date>
 +
                          <Details>A123-A124 (A123 - 16:00)</Details>
 +
                        </CharterInfo>
 +
                        <CharterInfo>
 +
                          <Type>Departure</Type>
 +
                          <Date>2022-08-27T00:00:00</Date>
 +
                          <Details>A123-A124 (A124 - 15:00)</Details>
 +
                        </CharterInfo>
 +
                     </Charters>
 +
                   </FlightInfo>
 +
              </Flights>
 
               <Messages/>
 
               <Messages/>
 
             </BookingInfo>
 
             </BookingInfo>
        </SearchBookingsResult>
+
        </SearchBookingsResult>
 
       </SearchBookingsResponse>
 
       </SearchBookingsResponse>
 
   </soap:Body>
 
   </soap:Body>
Строка 380: Строка 424:
 
******* '''CostOfferDuration''' – продолжительность проживания до данному CostOffer
 
******* '''CostOfferDuration''' – продолжительность проживания до данному CostOffer
 
***** '''Penalty''' – информация о штрафах по аннулированной заявке  
 
***** '''Penalty''' – информация о штрафах по аннулированной заявке  
 +
***** '''FlightInfo''' – секция информации об авиаперелете
 +
****** '''Tourist''' – Фамилия и имя туриста
 +
****** '''Charters''' – секция авиаперелета
 +
******* '''CharterInfo''' – секция информации об авиаперелете
 +
******** '''Type''' – тип авиаперелета (Arrival или Departure)
 +
******** '''Date''' – дата заезда/выезда из отеля
 +
******** '''Details''' – наименование авиаперелета (номер рейса - время прилета/вылета)
 
*** '''MessageInfo''' – массив данных сообщений
 
*** '''MessageInfo''' – массив данных сообщений
 
**** '''Id''' – идентификатор сообщения
 
**** '''Id''' – идентификатор сообщения
Строка 396: Строка 447:
 
   <soapenv:Body>
 
   <soapenv:Body>
 
       <tem:SearchBookingsJSON>
 
       <tem:SearchBookingsJSON>
        <!--Optional:-->
+
      <!--Optional:-->
         <tem:guid>bbadd56d-5f81-421e-ab8c-0c7380074447</tem:guid>
+
         <tem:guid>fd57bdcb-35e0-41b1-9743-eba763211e49</tem:guid>
 
         <!--Optional:-->
 
         <!--Optional:-->
 
         <tem:hotelID>
 
         <tem:hotelID>
 
             <!--Zero or more repetitions:-->
 
             <!--Zero or more repetitions:-->
             <tem:int>2942</tem:int>
+
             <tem:int>2930</tem:int>
 
         </tem:hotelID>
 
         </tem:hotelID>
 
         <tem:dateInfo>1</tem:dateInfo>
 
         <tem:dateInfo>1</tem:dateInfo>
         <tem:dateFrom>2022-01-02</tem:dateFrom>
+
         <tem:dateFrom>2022-08-20</tem:dateFrom>
         <tem:dateTo>2022-04-01</tem:dateTo>
+
         <tem:dateTo>2022-08-28</tem:dateTo>
        <tem:checkInFrom>2022-02-02</tem:checkInFrom>
+
         <tem:New>1</tem:New>
        <tem:checkInTo>2022-05-28</tem:checkInTo>
+
         <tem:change>1</tem:change>
         <tem:New>true</tem:New>
+
         <tem:cancel>1</tem:cancel>
         <tem:change>true</tem:change>
+
         <tem:inwork>1</tem:inwork>
         <tem:cancel>true</tem:cancel>
 
         <tem:inwork>true</tem:inwork>
 
        <tem:showConfirmed>true</tem:showConfirmed>
 
 
       </tem:SearchBookingsJSON>
 
       </tem:SearchBookingsJSON>
 
   </soapenv:Body>
 
   </soapenv:Body>
Строка 420: Строка 468:
 
Возвращаемый результат метода SearchBookingsJSON
 
Возвращаемый результат метода SearchBookingsJSON
 
<syntaxhighlight lang="java" enclose="div">
 
<syntaxhighlight lang="java" enclose="div">
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/
+
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
+
xmlns:xsd="http://www.w3.org/2001/XMLSchema">
 
   <soap:Body>
 
   <soap:Body>
 
       <SearchBookingsJSONResponse xmlns="http://tempuri.org/">
 
       <SearchBookingsJSONResponse xmlns="http://tempuri.org/">
         <SearchBookingsJSONResult>[{"Booking":"MGR20301A01","BookingID":37061,"Action":"Changed",
+
         <SearchBookingsJSONResult>[{"Booking":"MT140101AAH","BookingID":37601,"Action":"New","CreationDate":
"CreationDate":"2022-02-14T11:12:51.767","ChangeDate":null,"CancelDate":null,"CustomerMarket":
+
"2022-08-23T11:36:30.907","ChangeDate":null,"CancelDate":null,"CustomerMarket":{"CustomerMarketId":2,
{"CustomerMarketId":2,"CustomerMarketName":"Russian Market"},"HotelServices":[{"CheckIn":"2022-03-01T00:00:00",
+
"CustomerMarketName":"Russian Market"},"HotelServices":[{"CheckIn":"2022-08-20T00:00:00","CheckOut"
"CheckOut":"2022-03-10T00:00:00","Tourists":[{"Name":"Dfhfgh Fdghfghg","BirthDate":null,"Sex":"MR",
+
"2022-08-27T00:00:00","Tourists":[{"Name":"Vladimirov Alex","BirthDate":"1979-08-10T00:00:00","Sex":
"HotelServiceId":167841},{"Name":"Xdghfh Fghfghdfgh","BirthDate":null,"Sex":"MR","HotelServiceId":167841}],
+
"MR","HotelServiceId":171448},{"Name":"Vladimirovicha Alexa","BirthDate":"1972-08-11T00:00:00","Sex":
"CostOffers":[{"CostOfferName":"Green - 14-12/Green - 14-12","CostOfferDateBegin":"2022-03-01T00:00:00",
+
"MR","HotelServiceId":171448}],"CostOffers":[{"CostOfferName":"kolesnyk2/kolesnyk2","CostOfferDateBegin"
"CostOfferDateEnd":"2022-03-10T00:00:00","CostOfferDuration":9}],"Penalty":"","Notes":null,"HotelServiceId"
+
:"2022-08-20T00:00:00","CostOfferDateEnd":"2022-08-27T00:00:00","CostOfferDuration":7}],"Penalty":"",
:167841,"HotelServiceName":"HTL::Kiev/Green/Double Room/2AD/Jakuzzi/BB","Hotel":{"HotelId":2942,
+
"Notes":null,"HotelServiceId":171448,"HotelServiceName":"HTL::Kiev/Red/Double Room/2AD/Jakuzzi/BB",
"HotelName":"Green"},"Pansion":{"PansionId":3,"PansionName":"Bed and Breakfast"},"RoomType":
+
"Hotel":{"HotelId":2930,"HotelName":"Red"},"Pansion":{"PansionId":3,"PansionName":"Bed and Breakfast"}
{"RoomTypeId":3,"RoomTypeName":"Double Room"},"RoomAccomodation":{"AccommodationId":5558,
+
,"RoomType":{"RoomTypeId":3,"RoomTypeName":"Double Room"},"RoomAccomodation":{"AccommodationId":5558,
"AccommodationName":"2AD"},"RoomCategory":{"RoomCategoryId":20,"RoomCategoryName":"Jakuzzi"},
+
"AccommodationName":"2AD"},"RoomCategory":{"RoomCategoryId":20,"RoomCategoryName":"Jakuzzi"},"Status"
"Status":{"StatusId":1,"StatusName":"Wait"}}],"Messages":[{"Id":780700,"IsOutgoing":false,
+
:{"StatusId":1,"StatusName":"Wait"}}],"Flights":[],"Messages":[]},{"Booking":"MT140101AAJ","BookingID"
"DateCreate":"2022-04-04T10:39:39.26","SenderName":null,"IsRead":false,"Text":"HTL::Kiev/Green/Double
+
:37602,"Action":"New","CreationDate":"2022-08-23T11:37:05.227","ChangeDate":null,"CancelDate":null,
Room/2AD/Jakuzzi/BB:\r\nHotel confirmation number is changed\nBooking not processed"},{
+
"CustomerMarket":{"CustomerMarketId":2,"CustomerMarketName":"Russian Market"},"HotelServices":
"Id":780701,"IsOutgoing":false,"DateCreate":"2022-04-04T10:40:56.287","SenderName":null,"IsRead":false,
+
[{"CheckIn":"2022-08-20T00:00:00","CheckOut":"2022-08-27T00:00:00","Tourists":[{"Name":"Vladimirov Alex",
"Text":"HTL::Kiev/Green/Double Room/2AD/Jakuzzi/BB:\r\nBooking is being process"}]},{
+
"BirthDate":"1979-08-10T00:00:00","Sex":"MR","HotelServiceId":171454},{"Name":"Vladimirovicha Alexa"
"Booking":"MGR20228A01","BookingID":37062,"Action":"Changed","CreationDate":"2022-02-14T11:40:03.61"
+
,"BirthDate":"1972-08-11T00:00:00","Sex":"MR","HotelServiceId":171454}],"CostOffers":[{"CostOfferName"
,"ChangeDate":null,"CancelDate":null,"CustomerMarket":{"CustomerMarketId":2,"CustomerMarketName"
+
:"kolesnyk2/kolesnyk2","CostOfferDateBegin":"2022-08-20T00:00:00","CostOfferDateEnd":"2022-08-27T00:00
:"Russian Market"},"HotelServices":[{"CheckIn":"2022-02-28T00:00:00","CheckOut":
+
:00","CostOfferDuration":7}],"Penalty":"","Notes":null,"HotelServiceId":171454,"HotelServiceName":
"2022-04-04T00:00:00","Tourists":[{"Name":"Вровро Враовро","BirthDate":null,"Sex":"MR",
+
"HTL::Kiev/Red/Double Room/2AD/Jakuzzi/BB","Hotel":{"HotelId":2930,"HotelName":"Red"},"Pansion":
"HotelServiceId":167845},{"Name":"Аврпро Варовро","BirthDate":null,"Sex":"MR","HotelServiceId"
+
{"PansionId":3,"PansionName":"Bed and Breakfast"},"RoomType":{"RoomTypeId":3,"RoomTypeName":"Double Room"}
:167845}],"CostOffers":[{"CostOfferName":"kolesnyk/kolesnyk","CostOfferDateBegin":
+
,"RoomAccomodation":{"AccommodationId":5558,"AccommodationName":"2AD"},"RoomCategory":{"RoomCategoryId":
"2022-02-28T00:00:00","CostOfferDateEnd":"2022-03-01T00:00:00","CostOfferDuration":1},
+
20,"RoomCategoryName":"Jakuzzi"},"Status":{"StatusId":1,"StatusName":"Wait"}}],"Flights":[],"Messages":
{"CostOfferName":"Green - 14-12/Green - 14-12","CostOfferDateBegin":"2022-03-02T00:00:00",
+
[]},{"Booking":"MT140101AAK","BookingID":37607,"Action":"Changed","CreationDate":"2022-08-25T14:35:38.033",
"CostOfferDateEnd":"2022-03-12T00:00:00","CostOfferDuration":10},{"CostOfferName":
 
"kolesnyk/kolesnyk","CostOfferDateBegin":"2022-03-13T00:00:00","CostOfferDateEnd":
 
"2022-03-14T00:00:00","CostOfferDuration":1},{"CostOfferName":"Green - 14-12/Green - 14-12",
 
"CostOfferDateBegin":"2022-03-15T00:00:00","CostOfferDateEnd":"2022-03-18T00:00:00",
 
"CostOfferDuration":3},{"CostOfferName":"kolesnyk/kolesnyk","CostOfferDateBegin":
 
"2022-03-19T00:00:00","CostOfferDateEnd":"2022-04-04T00:00:00","CostOfferDuration":20}],
 
"Penalty":"","Notes":null,"HotelServiceId":167845,"HotelServiceName":
 
"HTL::Kiev/Green/Double Room/2AD/Inner View/BB","Hotel":{"HotelId":2942,"HotelName":"Green"},
 
"Pansion":{"PansionId":3,"PansionName":"Bed and Breakfast"},"RoomType":
 
{"RoomTypeId":3,"RoomTypeName":"Double Room"},"RoomAccomodation":
 
{"AccommodationId":5558,"AccommodationName":"2AD"},"RoomCategory":
 
{"RoomCategoryId":19,"RoomCategoryName":"Inner View"},"Status":
 
{"StatusId":1,"StatusName":"Wait"}}],"Messages":[]},{"Booking":
 
"MT120224A01","BookingID":37210,"Action":"Changed","CreationDate":
 
"2022-02-24T11:20:28.673","ChangeDate":null,"CancelDate":null,"CustomerMarket":
 
{"CustomerMarketId":2,"CustomerMarketName":"Russian Market"},"HotelServices":
 
[{"CheckIn":"2022-02-24T00:00:00","CheckOut":"2022-02-27T00:00:00","Tourists":
 
[{"Name":"Mr Mr","BirthDate":null,"Sex":"MR","HotelServiceId":168484},{"Name":
 
"Mrs Mrs","BirthDate":null,"Sex":"MR","HotelServiceId":168484}],"CostOffers":
 
[{"CostOfferName":"kolesnyk/kolesnyk","CostOfferDateBegin":"2022-02-24T00:00:00",
 
"CostOfferDateEnd":"2022-02-27T00:00:00","CostOfferDuration":3}],
 
"Penalty":"","Notes":null,"HotelServiceId":168484,"HotelServiceName":
 
"HTL::Kiev/Green/Double Room/2AD/Inner View/BB","Hotel":{"HotelId"
 
:2942,"HotelName":"Green"},"Pansion":{"PansionId":3,"PansionName":
 
"Bed and Breakfast"},"RoomType":{"RoomTypeId":3,"RoomTypeName":"Double Room"},
 
"RoomAccomodation":{"AccommodationId":5558,"AccommodationName":"2AD"},"RoomCategory":
 
{"RoomCategoryId":19,"RoomCategoryName":"Inner View"},"Status":{"StatusId":1,
 
"StatusName":"Wait"}}],"Messages":[]},{"Booking":"MT120304A01","BookingID":
 
37234,"Action":"Changed","CreationDate":"2022-03-01T18:20:17.683","ChangeDate"
 
:null,"CancelDate":null,"CustomerMarket":{"CustomerMarketId":2,"CustomerMarketName"
 
:"Russian Market"},"HotelServices":[{"CheckIn":"2022-03-04T00:00:00",
 
"CheckOut":"2022-04-04T00:00:00","Tourists":[{"Name":"Jiouiop Hopiopiop",
 
"BirthDate":null,"Sex":"MR","HotelServiceId":168594},{"Name":"Uioyuioio
 
Yuiouyouio","BirthDate":null,"Sex":"MR","HotelServiceId":168594}],"CostOffers":
 
[{"CostOfferName":"kolesnyk/kolesnyk","CostOfferDateBegin":"2022-03-04T00:00:00",
 
"CostOfferDateEnd":"2022-03-08T00:00:00","CostOfferDuration":4},{"CostOfferName":
 
"Green - 14-12/Green - 14-12","CostOfferDateBegin":"2022-03-09T00:00:00",
 
"CostOfferDateEnd":"2022-03-12T00:00:00","CostOfferDuration":3},{"CostOfferName":
 
"kolesnyk/kolesnyk","CostOfferDateBegin":"2022-03-13T00:00:00","CostOfferDateEnd":
 
"2022-03-14T00:00:00","CostOfferDuration":1},{"CostOfferName":"Green - 14-12/Green
 
- 14-12","CostOfferDateBegin":"2022-03-15T00:00:00","CostOfferDateEnd":"2022-04-04T00:00:00"
 
,"CostOfferDuration":23}],"Penalty":"","Notes":null,"HotelServiceId":168594,
 
"HotelServiceName":"HTL::Kiev/Green/Double Room/2AD/Inner View/BB","Hotel":{"HotelId":
 
2942,"HotelName":"Green"},"Pansion":{"PansionId":3,"PansionName":"Bed and Breakfast"},
 
"RoomType":{"RoomTypeId":3,"RoomTypeName":"Double Room"},"RoomAccomodation":
 
{"AccommodationId":5558,"AccommodationName":"2AD"},"RoomCategory":{"RoomCategoryId":19,
 
"RoomCategoryName":"Inner View"},"Status":{"StatusId":2,"StatusName":"Confirmed"}}],
 
"Messages":[{"Id":780510,"IsOutgoing":false,"DateCreate":"2022-03-15T18:33:07.953",
 
"SenderName":null,"IsRead":false,"Text":"HTL::Kiev/Green/Double Room/2AD/Inner View/BB:
 
\r\nftigjhfjhjhkjhjhk"},{"Id":780511,"IsOutgoing":false,"DateCreate":"2022-03-15T18:33:
 
08.153","SenderName":null,"IsRead":false,"Text":"HTL::Kiev/Green/Double Room/2AD/Inner
 
View/BB:\r\nService status is changed\nBooking is being process"},{"Id":780512,"IsOutgoing"
 
:true,"DateCreate":"2022-03-15T18:36:54.267","SenderName":"Work Name work","IsRead":
 
false,"Text":"fgjhghjghhhhhhhhhhhhhhhhhjkkkkkkkkkkkk"},{"Id":780513,"IsOutgoing":true,
 
"DateCreate":"2022-03-15T18:39:27.29","SenderName":"Work Name work","IsRead":false,
 
"Text":"jhkhjkjjjjjjjjjjjjjjjjjjjjjjjjhhhhhhhhhhhhhhhhhjjjj"}]},{"Booking":"MT120331A03"
 
,"BookingID":37292,"Action":"Changed","CreationDate":"2022-03-31T18:16:28.457",
 
 
"ChangeDate":null,"CancelDate":null,"CustomerMarket":{"CustomerMarketId":2,"CustomerMarketName"
 
"ChangeDate":null,"CancelDate":null,"CustomerMarket":{"CustomerMarketId":2,"CustomerMarketName"
:"Russian Market"},"HotelServices":[{"CheckIn":"2022-03-31T00:00:00","CheckOut":
+
:"Russian Market"},"HotelServices":[{"CheckIn":"2022-08-20T00:00:00","CheckOut":"2022-08-27T00:00:00"
"2022-04-14T00:00:00","Tourists":[{"Name":"Иванов Иван","BirthDate":null,"Sex":"MR",
+
,"Tourists":[{"Name":"Vladimirov Alex","BirthDate":"1979-08-10T00:00:00","Sex":"MR","HotelServiceId"
"HotelServiceId":169028},{"Name":"Иван Иван","BirthDate":null,"Sex":"MR","HotelServiceId":169028}]
+
:171489},{"Name":"Vladimirovicha Alexa","BirthDate":"1972-08-11T00:00:00","Sex":"MR","HotelServiceId"
,"CostOffers":[{"CostOfferName":"Green - 14-12/Green - 14-12","CostOfferDateBegin":
+
:171489}],"CostOffers":[{"CostOfferName":"kolesnyk2/kolesnyk2","CostOfferDateBegin":"2022-08-20T00:00:00"
"2022-03-31T00:00:00","CostOfferDateEnd":"2022-04-14T00:00:00","CostOfferDuration":14}],"Penalty":
+
,"CostOfferDateEnd":"2022-08-27T00:00:00","CostOfferDuration":7}],"Penalty":"","Notes":null,
"","Notes":null,"HotelServiceId":169028,"HotelServiceName":"HTL::Kiev/Green/Double Room/2AD/Jakuzzi
+
"HotelServiceId":171489,"HotelServiceName":"HTL::Kiev/Red/Double Room/2AD/Jakuzzi/BB","Hotel"
/BB","Hotel":{"HotelId":2942,"HotelName":"Green"},"Pansion":{"PansionId":3,"PansionName":"Bed and  
+
:{"HotelId":2930,"HotelName":"Red"},"Pansion":{"PansionId":3,"PansionName":"Bed and Breakfast"}
Breakfast"},"RoomType":{"RoomTypeId":3,"RoomTypeName":"Double Room"},"RoomAccomodation":{"AccommodationId":
+
,"RoomType":{"RoomTypeId":3,"RoomTypeName":"Double Room"},"RoomAccomodation":{"AccommodationId"
5558,"AccommodationName":"2AD"},"RoomCategory":{"RoomCategoryId":20,"RoomCategoryName":"Jakuzzi"},
+
:5558,"AccommodationName":"2AD"},"RoomCategory":{"RoomCategoryId":20,"RoomCategoryName":"Jakuzzi"}
"Status":{"StatusId":1,"StatusName":"Wait"}}],"Messages":[]}]</SearchBookingsJSONResult>
+
,"Status":{"StatusId":1,"StatusName":"Wait"}}],"Flights":[{"Tourist":"Vladimirov Alex","Charters"
 +
:[{"Type":"Arrival","Date":"2022-08-20T00:00:00","Details":"A123-A124 (A123 - 16:00)"},{"Type"
 +
:"Departure","Date":"2022-08-27T00:00:00","Details":"A123-A124 (A124 - 15:00)"}]},{"Tourist":
 +
"Vladimirovicha Alexa","Charters":[{"Type":"Arrival","Date":"2022-08-20T00:00:00","Details":
 +
"A123-A124 (A123 - 16:00)"},{"Type":"Departure","Date":"2022-08-27T00:00:00","Details":
 +
"A123-A124 (A124 - 15:00)"}]}],"Messages":[]}]</SearchBookingsJSONResult>
 
       </SearchBookingsJSONResponse>
 
       </SearchBookingsJSONResponse>
 +
  </soap:Body>
 +
</soap:Envelope>
 +
</syntaxhighlight>
 +
</TD></TR></TABLE>
 +
</div></div><br />
 +
 +
===GetMarkets (Получение списка рынков)===
 +
Метод предназначен для отображения всех существующих рынков. <br />
 +
Принимаемые параметры запроса ( * – обязательный):<br />
 +
Отсутствуют.<br />
 +
Возвращаемый результат:
 +
* '''GetMarketsResult''' – массив данных рынков
 +
** '''Name''' – наименование рынка
 +
** '''Id''' – идентификатор рынка
 +
 +
<div class="toccolours mw-collapsible mw-collapsed" style="width:900px">Пример
 +
<div class="mw-collapsible-content">
 +
<TABLE STYLE="border: 0.1em dashed #2F6FAB; margin: 8px; padding: 8px" WIDTH="99%"><TR><TD>
 +
Вызов метода GetMarkets
 +
<syntaxhighlight lang="java" enclose="div">
 +
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
 +
  <soapenv:Header/>
 +
  <soapenv:Body>
 +
      <tem:GetMarkets/>
 +
  </soapenv:Body>
 +
</soapenv:Envelope>
 +
</syntaxhighlight>
 +
 +
Возвращаемый результат метода GetMarkets
 +
<syntaxhighlight lang="java" enclose="div">
 +
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
 +
  <soap:Body>
 +
      <GetMarketsResponse xmlns="http://tempuri.org/">
 +
        <GetMarketsResult>
 +
            <MarketInfo Name="!test" Id="61"/>
 +
            <MarketInfo Name="&lt;All>" Id="0"/>
 +
            <MarketInfo Name="1111" Id="33"/>
 +
            <MarketInfo Name="1112" Id="34"/>
 +
            <MarketInfo Name="12" Id="32"/>
 +
            <MarketInfo Name="12" Id="40"/>
 +
            <MarketInfo Name="1t1" Id="44"/>
 +
            <MarketInfo Name="1t2" Id="45"/>
 +
            <MarketInfo Name="1t3" Id="46"/>
 +
            <MarketInfo Name="1t4" Id="47"/>
 +
            <MarketInfo Name="1t5" Id="48"/>
 +
            <MarketInfo Name="1t6" Id="49"/>
 +
            <MarketInfo Name="21" Id="36"/>
 +
            <MarketInfo Name="234" Id="37"/>
 +
            <MarketInfo Name="313" Id="38"/>
 +
            <MarketInfo Name="34" Id="35"/>
 +
            <MarketInfo Name="34" Id="41"/>
 +
            <MarketInfo Name="4" Id="51"/>
 +
            <MarketInfo Name="434" Id="39"/>
 +
            <MarketInfo Name="45" Id="42"/>
 +
            <MarketInfo Name="456" Id="43"/>
 +
            <MarketInfo Name="Balkan Market" Id="5"/>
 +
            <MarketInfo Name="France Market" Id="8"/>
 +
            <MarketInfo Name="Greek Market" Id="3"/>
 +
            <MarketInfo Name="Italy Market" Id="9"/>
 +
            <MarketInfo Name="market12^*#$)_22_ 09" Id="22"/>
 +
            <MarketInfo Name="market1FAD" Id="11"/>
 +
            <MarketInfo Name="market2083" Id="13"/>
 +
            <MarketInfo Name="market25C5" Id="16"/>
 +
            <MarketInfo Name="market8085" Id="14"/>
 +
            <MarketInfo Name="market9873" Id="10"/>
 +
            <MarketInfo Name="marketA5F9" Id="18"/>
 +
            <MarketInfo Name="marketD84E" Id="15"/>
 +
            <MarketInfo Name="marketF3A6" Id="19"/>
 +
            <MarketInfo Name="marketF415" Id="21"/>
 +
            <MarketInfo Name="marketFCFE" Id="20"/>
 +
            <MarketInfo Name="marketFFDC" Id="12"/>
 +
            <MarketInfo Name="mk" Id="31"/>
 +
            <MarketInfo Name="mk_market" Id="30"/>
 +
            <MarketInfo Name="Old" Id="6"/>
 +
            <MarketInfo Name="qwer" Id="50"/>
 +
            <MarketInfo Name="Russian Market" Id="2"/>
 +
            <MarketInfo Name="test new" Id="56"/>
 +
            <MarketInfo Name="test1211" Id="53"/>
 +
            <MarketInfo Name="Мой личный рынок" Id="25"/>
 +
            <MarketInfo Name="ук" Id="55"/>
 +
        </GetMarketsResult>
 +
      </GetMarketsResponse>
 
   </soap:Body>
 
   </soap:Body>
 
</soap:Envelope>
 
</soap:Envelope>
Строка 617: Строка 695:
 
         </ManageBookingResult>
 
         </ManageBookingResult>
 
       </ManageBookingResponse>
 
       </ManageBookingResponse>
 +
  </soap:Body>
 +
</soap:Envelope>
 +
</syntaxhighlight>
 +
</TD></TR></TABLE>
 +
</div></div><br />
 +
 +
==Методы создания цен==
 +
 +
===CreateCostOffer (Создание ценового предложения)===
 +
Метод предназначен для занесения цен на объекты размещения. <br />
 +
Принимаемые параметры запроса ( * – обязательный):<br />
 +
* '''Guid *''' – идентификатор аутентификации (возвращается при запросе к методу [[Master-Interlook:HotelService#Connect (получение аутентификационного токена)|Connect]])<br />
 +
* '''costOffer''' – массив данных CostOffer
 +
** '''HotelId *''' – ключ отеля
 +
** '''RateId *''' – ключ валюты
 +
** '''CostOfferTypeId''' – ключ типа CostOffer (Ordinary или SPO. Если не указан, то отправляется Ordinary. Если в запросе имеется и заполнена секция Rules, то CostOffer автоматически определяется с типом SPO)
 +
** '''MarketIds''' – ключ рынка (если не указан, то отправляется 0 - все. Возвращается при запросе к методу [[Master-Interlook:HotelService#GetMarkets (получение списка рынков)|GetMarkets]])<br />
 +
** '''SaleDateBegin''' – дата с которой возможно бронирование (если не указана, то берется в соответствии с текущей)
 +
** '''SaleDateEnd''' – дата до которой возможно бронирование
 +
** '''NameFromProvider''' – наименование для провайдера (если не указан, то записывается пустое)
 +
** '''PeriodBeforeCheckIn''' – период до заезда (если не указан, то отправляется 0)
 +
** '''Comment''' – комментарий
 +
** '''MinDays''' – минимальная продолжительность (если не задано, то устанавливается 1)
 +
** '''MaxDays''' – максимальная продолжительность (если не задано, то устанавливается 365)
 +
* '''prices''' – массив данных цен
 +
** '''PriceRequest''' – массив данных цены
 +
*** '''DateFrom *''' – дата начала (если не указана, то берется текущая)
 +
*** '''DateTo *''' – дата окончания (если не указана, то берется из списка цен максимальная дата выезда)
 +
*** '''DateCheckinFrom''' – дата заезда от (если не указан, то минимальная)
 +
*** '''DateCheckinTo''' – дата заезда по (если не указан, то максимальная)
 +
*** '''DateCheckoutFrom''' – дата выезда от (если не указан, то минимальная)
 +
*** '''DateCheckoutTo''' – дата выезда по (если не указан, то максимальная)
 +
*** '''WeekDays''' – день недели (если не указано, то проставляются все)
 +
*** '''AccomodationId *''' – ключ типа размещения
 +
*** '''RoomTypeId *''' – ключ типа комнаты
 +
*** '''RoomCategoryId *''' – ключ категории комнаты
 +
*** '''PansionId *''' – ключ типа питания
 +
*** '''Price *''' – цена
 +
*** '''TarifId''' – (если не указан, то устанавливается 0 - ordinary. Берется из таблицы Tariffs Базы Данных)
 +
* '''rules''' – массив данных правил изменения цены
 +
** '''XYRuleRequst''' – массив данных правил изменения цены
 +
*** '''ExcludeBy''' – какие именно ночи должны быть бесплатными (принимает значения Last - последняя, Min - дешевая, Max - дорогая)
 +
*** '''Sign''' – значение количества рассчитываемых ночей (принимает значения "=" или "-")
 +
*** '''XFrom''' – от какой продолжительности проживания действует акция
 +
*** '''XTo''' – до какой продолжительности проживания действует акция
 +
*** '''Y''' – количество бесплатных ночей или значение продолжительности проживания
 +
Возвращаемый результат:
 +
* '''CreateCostOfferResponse''' – массив данных CostOffer
 +
** '''Id''' –  идентификатор CostOffer
 +
** '''Name''' – наименование CostOffer
 +
** '''CostOfferType''' – тип CostOffer
 +
** '''Rate''' – валюта
 +
** '''CreateDate''' – дата создания CostOffer
 +
** '''Markets''' – наименование рынка
 +
** '''XYRuleResponse''' – массив данных правил изменения цены
 +
*** '''ExcludeBy''' – какие именно ночи должны быть бесплатными (принимает значения Last - последняя, Min - дешевая, Max - дорогая)
 +
*** '''Sign''' – значение количества рассчитываемых ночей (принимает значения "=" или "-")
 +
*** '''XFrom''' – от какой продолжительности проживания действует акция
 +
*** '''XTo''' – до какой продолжительности проживания действует акция
 +
*** '''Y''' – количество бесплатных ночей или значение продолжительности проживания
 +
** '''CostInfoResponse''' – массив данных цены
 +
*** '''Id''' –  идентификатор цены
 +
*** '''Code''' –  идентификатор отеля
 +
*** '''CheckInDateBegin''' – дата заезда «с»
 +
*** '''CheckInDateEnd''' – дата заезда «до»
 +
*** '''CheckOutDateBegin''' – дата выезда «с»
 +
*** '''CheckOutDateEnd''' – дата выезда «до»
 +
*** '''DateBegin''' – дата действия цены «с»
 +
*** '''DateEnd''' – дата действия цены «до»
 +
*** '''Price''' – значение цены
 +
*** '''RoomTypeId''' – ключ типа номера
 +
*** '''PansionId''' – ключ питания
 +
*** '''RoomCategoryId''' – ключ категории номера
 +
*** '''AccommodationId''' – ключ типа размещения
 +
*** '''TariffId''' – ключ тарифа (В таблице цен соответствует параметру CS_CVId)
 +
*** '''Type''' – тип цены (Per Room - за комнату, Per Person - за человека)
 +
В случае некорректного запроса в ответе приходит описание ошибки и номер строки, в которой указаны некорректные данные.<br />
 +
<div class="toccolours mw-collapsible mw-collapsed" style="width:900px">Пример
 +
<div class="mw-collapsible-content">
 +
<TABLE STYLE="border: 0.1em dashed #2F6FAB; margin: 8px; padding: 8px" WIDTH="99%"><TR><TD>
 +
Вызов метода CreateCostOffer
 +
<syntaxhighlight lang="java" enclose="div">
 +
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
 +
  <soapenv:Header/>
 +
  <soapenv:Body>
 +
      <tem:CreateCostOffer>
 +
        <!--Optional:-->
 +
        <tem:guid>342d6612-f6d4-4149-a365-275a7701c306</tem:guid>
 +
        <!--Optional:-->
 +
        <tem:costOffer>
 +
            <tem:HotelId>2930</tem:HotelId>
 +
            <tem:RateId>1</tem:RateId>
 +
            <tem:CostOfferTypeId>Ordinary</tem:CostOfferTypeId>
 +
            <!--Optional:-->
 +
            <tem:MarketIds>
 +
              <!--Zero or more repetitions:-->
 +
              <tem:int>2</tem:int>
 +
            </tem:MarketIds>
 +
            <tem:SaleDateBegin>2022-10-01</tem:SaleDateBegin>
 +
            <tem:SaleDateEnd>2045-10-01</tem:SaleDateEnd>
 +
            <!--Optional:-->
 +
            <tem:NameFromProvider>New Name</tem:NameFromProvider>
 +
            <tem:PeriodBeforeCheckIn>1</tem:PeriodBeforeCheckIn>
 +
            <!--Optional:-->
 +
            <tem:Comment>NewComment</tem:Comment>
 +
            <tem:MinDays>1</tem:MinDays>
 +
            <tem:MaxDays>7</tem:MaxDays>
 +
        </tem:costOffer>
 +
        <!--Optional:-->
 +
        <tem:prices>
 +
            <!--Zero or more repetitions:-->
 +
            <tem:PriceRequest>
 +
              <tem:DateFrom>2022-10-01</tem:DateFrom>
 +
              <tem:DateTo>2028-10-01</tem:DateTo>
 +
              <tem:DateCheckinFrom>2022-10-01</tem:DateCheckinFrom>
 +
              <tem:DateCheckinTo>2025-10-01</tem:DateCheckinTo>
 +
              <tem:DateCheckoutFrom>2028-10-01</tem:DateCheckoutFrom>
 +
              <tem:DateCheckoutTo>2028-10-01</tem:DateCheckoutTo>
 +
              <!--Optional:-->
 +
              <tem:WeekDays>1234567</tem:WeekDays>
 +
              <tem:AccomodationId>5558</tem:AccomodationId>
 +
              <tem:RoomTypeId>3</tem:RoomTypeId>
 +
              <tem:RoomCategoryId>20</tem:RoomCategoryId>
 +
              <tem:PansionId>3</tem:PansionId>
 +
              <tem:Price>932</tem:Price>
 +
              <tem:TarifId>0</tem:TarifId>
 +
            </tem:PriceRequest>
 +
        </tem:prices>
 +
        <!--Optional:-->
 +
        <tem:rules>
 +
            <!--Zero or more repetitions:-->
 +
            <tem:XYRuleRequst>
 +
              <tem:ExcludeBy>Last</tem:ExcludeBy>
 +
              <!--Optional:-->
 +
              <tem:Sign>=</tem:Sign>
 +
              <tem:XFrom>1</tem:XFrom>
 +
              <tem:XTo>5</tem:XTo>
 +
              <tem:Y>1</tem:Y>
 +
            </tem:XYRuleRequst>
 +
        </tem:rules>
 +
      </tem:CreateCostOffer>
 +
  </soapenv:Body>
 +
</soapenv:Envelope>
 +
</syntaxhighlight>
 +
 +
Возвращаемый результат метода CreateCostOffer
 +
<syntaxhighlight lang="java" enclose="div">
 +
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
 +
  <soap:Body>
 +
      <CreateCostOfferResponse xmlns="http://tempuri.org/">
 +
        <CreateCostOfferResult Message="Ok">
 +
            <Data>
 +
              <CreateCostOfferResponse>
 +
                  <Id>2549</Id>
 +
                  <Name>2022.10.01 - 2028.10_Russian Market_1-7_&lt;All>_Mouzenidis Travel 1_Red_53</Name>
 +
                  <CostOfferType>SPO</CostOfferType>
 +
                  <Rate>EU</Rate>
 +
                  <CreateDate>2022-11-14T13:14:07.047</CreateDate>
 +
                  <Markets>Russian Market</Markets>
 +
                  <XYRules>
 +
                    <XYRuleResponse>
 +
                        <ExcludeBy>Last</ExcludeBy>
 +
                        <Sign>-</Sign>
 +
                        <XFrom>1</XFrom>
 +
                        <XTo>5</XTo>
 +
                        <Y>1</Y>
 +
                    </XYRuleResponse>
 +
                  </XYRules>
 +
                  <CostsInfo>
 +
                    <CostInfoResponse>
 +
                        <Id>807703</Id>
 +
                        <Code>2930</Code>
 +
                        <CheckInDateBegin>2028-10-01T00:00:00</CheckInDateBegin>
 +
                        <CheckInDateEnd>2028-10-01T00:00:00</CheckInDateEnd>
 +
                        <CheckOutDateBegin>2028-10-01T00:00:00</CheckOutDateBegin>
 +
                        <CheckOutDateEnd>2028-10-01T00:00:00</CheckOutDateEnd>
 +
                        <DateBegin>2022-10-01T00:00:00</DateBegin>
 +
                        <DateEnd>2028-10-01T00:00:00</DateEnd>
 +
                        <Price>956.1700</Price>
 +
                        <RoomTypeId>3</RoomTypeId>
 +
                        <PansionId>3</PansionId>
 +
                        <RoomCategoryId>20</RoomCategoryId>
 +
                        <AccomodationId>5558</AccomodationId>
 +
                        <TariffId>0</TariffId>
 +
                        <Type>PerPax</Type>
 +
                    </CostInfoResponse>
 +
                  </CostsInfo>
 +
              </CreateCostOfferResponse>
 +
            </Data>
 +
        </CreateCostOfferResult>
 +
      </CreateCostOfferResponse>
 
   </soap:Body>
 
   </soap:Body>
 
</soap:Envelope>
 
</soap:Envelope>

Текущая версия на 16:24, 24 января 2023

Версия статьи от 24-01-2023.

Доступно начиная с релиза 11.20


Введение

Сервис InterlookHotelService предназначен для работы с отелями. Работает с методами REST API. Для вызова методов REST API можно использовать SoapUi.

Предупреждение


Для доступа к сервису у онлайн пользователя должен быть установлен признак Hotel/Service в настройке Person connection и в настройках Role активирован параметр Show hotel reservations by date.


Подключение к базе данных ПК «Мастер-Interlook»

В файле web.config, расположенном в папке Interlook.HotelServiceService пропишите необходимые параметры подключения (красным цветом выделены значения, которые необходимо ввести). Строка подключения к базе данных ПК «Мастер-Interlook»:
<add key = "connectionString" value = "Data Source=ip-адрес сервера базе данных ПК «Мастер-Interlook»;Initial Catalog=название базы данных ПК «Мастер-Interlook»;User ID=логин пользователя ПК «Мастер-Interlook»;Password=пароль пользователя ПК «Мастер-Interlook»"/>

Настройки в файле WEB.CONFIG

Настройки задаются в секции <appSettings> файла web.config основного приложения Interlook.HotelServiceService.

Описание Значение Настройка
1 Процедура перезапуска кэша cachingTime

"cachingTime" value="-1" - инициализация кэша максимально производительная: каждый отель загружается в своем потоке (возможны сбои).
"cachingTime" value="-2"/> - весь кэш загружается в 2 потока.

<add key="cachingTime" value="-1"/>
2 Включение логирования о использовании памяти сервера LogCacheMemory

Настройка служит для включения или отключения логирования в таблицу базы данных о использовании кешем сервиса памяти сервера.
0 - выключена, 1 - включена

<add key="LogCacheMemory" value="0"/>

Методы HotelService

Методы аутентификации

Connect (Получение аутентификационного токена)

Принимаемые параметры запроса ( * – обязательный):

  • Login * – логин online пользователя
  • Password * – пароль online пользователя

Возвращаемый результат:

  • ConnectResult – идентификатор аутентификации (если аутентификация прошла успешно. то получаем идентификатор, в противном случае результат -1)
Пример

Вызов метода Connect

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
   <soapenv:Header/>
   <soapenv:Body>
      <tem:Connect>
         <!--Optional:-->
         <tem:login>mk1</tem:login>
         <!--Optional:-->
         <tem:password>123</tem:password>
      </tem:Connect>
   </soapenv:Body>
</soapenv:Envelope>

Возвращаемый результат метода Connect

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
   <soap:Body>
      <ConnectResponse xmlns="http://tempuri.org/">
         <ConnectResult>123c02db-3d47-4db5-861b-758be524a5fe</ConnectResult>
      </ConnectResponse>
   </soap:Body>
</soap:Envelope>


CheckConnect (Проверка активности подключения под конкретным идентификатором)

Метод проверяет наличие активного подключения под конкретным идентификатором аутентификации.
Принимаемые параметры запроса ( * – обязательный):

  • Guid * – идентификатор аутентификации (возвращается при запросе к методу Connect)

Возвращаемый результат:

  • CheckConnectResult – идентификатор аутентификации (true – если подключение активно, false – если подключения нет)
Пример

Вызов метода CheckConnect

<soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope" xmlns:tem="http://tempuri.org/">
   <soap:Header/>
   <soap:Body>
      <tem:CheckConnect>
         <!--Optional:-->
         <tem:guid>123c02db-3d47-4db5-861b-758be524a5fe</tem:guid>
      </tem:CheckConnect>
   </soap:Body>
</soap:Envelope>

Возвращаемый результат метода CheckConnect

<soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
   <soap:Body>
      <CheckConnectResponse xmlns="http://tempuri.org/">
         <CheckConnectResult>true</CheckConnectResult>
      </CheckConnectResponse>
   </soap:Body>
</soap:Envelope>


Методы поиска

SearchBookings (Получение списка забронированных заявок)

Метод предназначен для поиска забронированных заявок. Отбираются те заявки, у которых партнер предоставления услуги совпадает с партнером для логина, под которым осуществляется поиск.
Принимаемые параметры запроса ( * – обязательный):

  • Guid * – идентификатор аутентификации (возвращается при запросе к методу Connect)
  • hotelID – массив данных с ключами отелей. Можно передавать как один так и несколько ключей отелей. Если не передаём данный параметр, то в ответ получаем все заказы, подходящие под выбранные даты.
  • dateInfo * – по какой дате осуществлять поиск (1 - дата создания заявки, 2 - дата заезда в отель, 3 - дата выезда из отеля)
  • dateFrom * – дата начала
  • dateTo * – дата окончания
  • checkInFrom – дата заезда от
  • checkInTo – дата заезда по
  • New – возвращает новые бронирования с датой, попадающей в указанное выше условие
  • change – возвращает измененные бронирования с изменениями, внесенными в выбранный период
  • cancel – возвращает информацию об отмененных бронированиях за выбранный период
  • inwork – возвращает информацию по заявкам взятым отелем в работу.

Заявка получает статус InWork в следующих случаях:
- если через HotelService в методе ManageBooking по заявке передан параметр <hotelWorkStatus>true</hotelWorkStatus>
- если по заявке распечатано или отправлено какое-либо из уведомлений по кнопке Actions в окне Interlook.

  • showConfirmed - отображает путевки со статусом Confirmed (false или отсутствие настройки означает, что путевки со статусом Confirmed не отображаются)

Возвращаемый результат:

    • BookingInfo – массив данных брони
      • Booking – номер брони в системе Interlook
      • BookingID – ключ заявки из базы данных
      • Action – новая, отмененная или измененная заявка
      • CreationDate – дата создания услуги в заявке
      • ChangeDate – не используется
      • CancelDate – не используется
      • CustomerMarket – данные туроператора, оформившего заявку
        • CustomerMarketId – ключ туроператора, оформившего заявку
        • CustomerMarketName – имя туроператора, оформившего заявку
      • HotelServices – массив данных по сервисам отелей
        • HotelServiceInfo – информация по сервису отеля
          • HotelServiceId – ключ сервиса отеля
          • HotelServiceName – имя сервиса отеля
          • Hotel – массив данных по отелям
            • HotelId – ключ отеля
            • HotelName – имя отеля
          • Pansion – тип питания
            • PansionId – ключ питания
            • PansionName – имя питания
          • RoomType – тип номера
            • RoomTypeId – ключ типа номера
            • RoomTypeName – имя типа номера
          • RoomAccomodation – тип размещения
            • AccommodationId – ключ типа размещения
            • AccommodationName – имя типа размещения
          • RoomCategory – категория номер
            • RoomCategoryId – ключ категории номера
            • RoomCategoryName – имя категории номера
          • Status – статус по услуге проживания
            • StatusId – ключ статуса по услуге проживания
            • StatusName – имя статуса по услуге проживания
          • CheckIn – дата заезда в отель
          • CheckOut – дата выезда из отеля
          • Tourists – массив данных туристов
            • TouristInfo – массив данных по туристу
              • Name – имя туриста
              • BirthDate – дата рождения туриста
              • Sex – пол туриста
              • HotelServiceId – ключ услуги проживания с которой связан турист
          • CostOffers – массив данных по CostOffers, по которым рассчитана цена услуги
            • CostOfferInfo – массив данных по конкретному CostOffer
              • CostOfferName – название CostOffer (Если заявка не аннулирована, то выводим название CostOffer по цене netto. Если заявка аннулирована со штрафами, то выводим название CostOffer по цене брутто. Если заявка аннулирована без штрафов, то выводим текст "Canceled without penalty")
              • CostOfferDateBegin – дата начала действия CostOffer
              • CostOfferDateEnd – дата окончания действия CostOffer
              • CostOfferDuration – продолжительность проживания до данному CostOffer
          • Penalty – информация о штрафах по аннулированной заявке
          • FlightInfo – секция информации об авиаперелете
            • Tourist – Фамилия и имя туриста
            • Charters – секция авиаперелета
              • CharterInfo – секция информации об авиаперелете
                • Type – тип авиаперелета (Arrival или Departure)
                • Date – дата заезда/выезда из отеля
                • Details – наименование авиаперелета (номер рейса - время прилета/вылета)
      • MessageInfo – массив данных сообщений
        • Id – идентификатор сообщения
        • IsOutgoing – исходящее (true - исходящее, false - входящее)
        • DateCreate – дата создания сообщения
        • IsRead – прочитано (true - прочитано, false - не прочитано )
        • Text – текст сообщения
Пример

Вызов метода SearchBookings

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
   <soapenv:Header/>
   <soapenv:Body>
      <tem:SearchBookings>
         <!--Optional:-->
         <tem:guid>fd57bdcb-35e0-41b1-9743-eba763211e49</tem:guid>
         <!--Optional:-->
         <tem:hotelID>
            <!--Zero or more repetitions:-->
            <tem:int>2930</tem:int>
         </tem:hotelID>
         <tem:dateInfo>1</tem:dateInfo>
         <tem:dateFrom>2022-08-19</tem:dateFrom>
         <tem:dateTo>2022-08-30</tem:dateTo>
         <tem:New>1</tem:New>
         <tem:change>1</tem:change>
         <tem:cancel>1</tem:cancel>
         <tem:inwork>1</tem:inwork>
    </tem:SearchBookings>
   </soapenv:Body>
</soapenv:Envelope>

Возвращаемый результат метода SearchBookings

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
   <soap:Body>
      <SearchBookingsResponse xmlns="http://tempuri.org/">
         <SearchBookingsResult>
       <BookingInfo>
               <Booking>MT140101AAL</Booking>
               <BookingID>37608</BookingID>
               <Action>Changed</Action>
               <CreationDate>2022-08-25T14:37:12.25</CreationDate>
               <ChangeDate xsi:nil="true"/>
               <CancelDate xsi:nil="true"/>
               <CustomerMarket>
                  <CustomerMarketId>2</CustomerMarketId>
                  <CustomerMarketName>Russian Market</CustomerMarketName>
               </CustomerMarket>
               <HotelServices>
                  <HotelServiceInfo>
                     <HotelServiceId>171495</HotelServiceId>
                     <HotelServiceName>HTL::Kiev/Red/Double Room/2AD/Jakuzzi/BB</HotelServiceName>
                     <Hotel>
                        <HotelId>2930</HotelId>
                        <HotelName>Red</HotelName>
                     </Hotel>
                     <Pansion>
                        <PansionId>3</PansionId>
                        <PansionName>Bed and Breakfast</PansionName>
                     </Pansion>
                     <RoomType>
                        <RoomTypeId>3</RoomTypeId>
                        <RoomTypeName>Double Room</RoomTypeName>
                     </RoomType>
                     <RoomAccomodation>
                        <AccommodationId>5558</AccommodationId>
                        <AccommodationName>2AD</AccommodationName>
                     </RoomAccomodation>
                     <RoomCategory>
                        <RoomCategoryId>20</RoomCategoryId>
                        <RoomCategoryName>Jakuzzi</RoomCategoryName>
                     </RoomCategory>
                     <Status>
                        <StatusId>1</StatusId>
                        <StatusName>Wait</StatusName>
                     </Status>
                     <CheckIn>2022-08-20T00:00:00</CheckIn>
                     <CheckOut>2022-08-27T00:00:00</CheckOut>
                     <Tourists>
                        <TouristInfo>
                           <Name>Vladimirov Alex</Name>
                           <BirthDate>1979-08-10T00:00:00</BirthDate>
                           <Sex>MR</Sex>
                           <HotelServiceId>171495</HotelServiceId>
                        </TouristInfo>
                        <TouristInfo>
                           <Name>Vladimirovicha Alexa</Name>
                           <BirthDate>1972-08-11T00:00:00</BirthDate>
                           <Sex>MR</Sex>
                           <HotelServiceId>171495</HotelServiceId>
                        </TouristInfo>
                     </Tourists>
                     <CostOffers>
                        <CostOfferInfo>
                           <CostOfferName>kolesnyk2/kolesnyk2</CostOfferName>
                           <CostOfferDateBegin>2022-08-20T00:00:00</CostOfferDateBegin>
                           <CostOfferDateEnd>2022-08-27T00:00:00</CostOfferDateEnd>
                           <CostOfferDuration>7</CostOfferDuration>
                        </CostOfferInfo>
                     </CostOffers>
                     <Penalty/>
                  </HotelServiceInfo>
               </HotelServices>
               <Flights>
                  <FlightInfo>
                     <Tourist>Vladimirov Alex</Tourist>
                     <Charters>
                        <CharterInfo>
                           <Type>Arrival</Type>
                           <Date>2022-08-20T00:00:00</Date>
                           <Details>A123-A124 (A123 - 16:00)</Details>
                        </CharterInfo>
                        <CharterInfo>
                           <Type>Departure</Type>
                           <Date>2022-08-27T00:00:00</Date>
                           <Details>A123-A124 (A124 - 15:00)</Details>
                        </CharterInfo>
                     </Charters>
                  </FlightInfo>
                  <FlightInfo>
                     <Tourist>Vladimirovicha Alexa</Tourist>
                     <Charters>
                        <CharterInfo>
                           <Type>Arrival</Type>
                           <Date>2022-08-20T00:00:00</Date>
                           <Details>A123-A124 (A123 - 16:00)</Details>
                        </CharterInfo>
                        <CharterInfo>
                           <Type>Departure</Type>
                           <Date>2022-08-27T00:00:00</Date>
                           <Details>A123-A124 (A124 - 15:00)</Details>
                        </CharterInfo>
                     </Charters>
                  </FlightInfo>
               </Flights>
               <Messages/>
            </BookingInfo>
        </SearchBookingsResult>
      </SearchBookingsResponse>
   </soap:Body>
</soap:Envelope>


SearchBookingsJSON (Получение списка забронированных заявок в формате JSON)

Метод предназначен для поиска забронированных заявок. Отбираются те заявки, у которых партнер предоставления услуги совпадает с партнером для логина, под которым осуществляется поиск.
Принимаемые параметры запроса ( * – обязательный):

  • Guid * – идентификатор аутентификации (возвращается при запросе к методу Connect)
  • hotelID – массив данных с ключами отелей. Можно передавать как один так и несколько ключей отелей. Если не передаём данный параметр, то в ответ получаем все заказы, подходящие под выбранные даты.
  • dateInfo * – по какой дате осуществлять поиск (1 - дата создания заявки, 2 - дата заезда в отель, 3 - дата выезда из отеля)
  • dateFrom * – дата начала
  • dateTo * – дата окончания
  • checkInFrom – дата заезда от
  • checkInTo – дата заезда по
  • New – возвращает новые бронирования с датой, попадающей в указанное выше условие
  • change – возвращает измененные бронирования с изменениями, внесенными в выбранный период
  • cancel – возвращает информацию об отмененных бронированиях за выбранный период
  • inwork – возвращает информацию по заявкам взятым отелем в работу

Заявка получает статус InWork в следующих случаях:
- если через HotelService в методе ManageBooking по заявке передан параметр <hotelWorkStatus>true</hotelWorkStatus>
- если по заявке распечатано или отправлено какое-либо из уведомлений по кнопке Actions в окне Interlook.

  • showConfirmed - отображает путевки со статусом Confirmed (false или отсутствие настройки означает, что путевки со статусом Confirmed не отображаются)

Возвращаемый результат:

  • Booking – номер брони в системе Interlook
  • BookingID – ключ заявки из базы данных
  • Action – новая, отмененная или измененная заявка
  • CreationDate – дата создания услуги в заявке
  • ChangeDate – не используется
  • CancelDate – не используется
  • CustomerMarket – данные туроператора, оформившего заявку
    • CustomerMarketId – ключ туроператора, оформившего заявку
    • CustomerMarketName – имя туроператора, оформившего заявку
  • HotelServices – массив данных по сервисам отелей
    • CheckIn – дата заезда в отель
    • CheckOut – дата выезда из отеля
    • Tourists – массив данных туристов
        • Name – имя туриста
        • BirthDate – дата рождения туриста
        • Sex – пол туриста
        • HotelServiceId – ключ услуги проживания с которой связан турист
    • Notes – не указывается
      • HotelServiceId – ключ сервиса отеля
      • HotelServiceName – имя сервиса отеля
      • Hotel – массив данных по отелям
        • HotelId – ключ отеля
        • HotelName – имя отеля
      • Pansion – тип питания
        • PansionId – ключ питания
        • PansionName – имя питания
      • RoomType – тип номера
        • RoomTypeId – ключ типа номера
        • RoomTypeName – имя типа номера
      • RoomAccomodation – тип размещения
        • AccommodationId – ключ типа размещения
        • AccommodationName – имя типа размещения
      • RoomCategory – категория номер
        • RoomCategoryId – ключ категории номера
        • RoomCategoryName – имя категории номера
      • Status – статус по услуге проживания
        • StatusId – ключ статуса по услуге проживания
        • StatusName – имя статуса по услуге проживания
          • CheckIn – дата заезда в отель
          • CheckOut – дата выезда из отеля
          • Tourists – массив данных туристов
            • TouristInfo – массив данных по туристу
              • Name – имя туриста
              • BirthDate – дата рождения туриста
              • Sex – пол туриста
              • HotelServiceId – ключ услуги проживания с которой связан турист
          • CostOffers – массив данных по CostOffers, по которым рассчитана цена услуги
            • CostOfferInfo – массив данных по конкретному CostOffer
              • CostOfferName – название CostOffer (Если заявка не аннулирована, то выводим название CostOffer по цене netto. Если заявка аннулирована со штрафами, то выводим название CostOffer по цене брутто. Если заявка аннулирована без штрафов, то выводим текст "Canceled without penalty")
              • CostOfferDateBegin – дата начала действия CostOffer
              • CostOfferDateEnd – дата окончания действия CostOffer
              • CostOfferDuration – продолжительность проживания до данному CostOffer
          • Penalty – информация о штрафах по аннулированной заявке
          • FlightInfo – секция информации об авиаперелете
            • Tourist – Фамилия и имя туриста
            • Charters – секция авиаперелета
              • CharterInfo – секция информации об авиаперелете
                • Type – тип авиаперелета (Arrival или Departure)
                • Date – дата заезда/выезда из отеля
                • Details – наименование авиаперелета (номер рейса - время прилета/вылета)
      • MessageInfo – массив данных сообщений
        • Id – идентификатор сообщения
        • IsOutgoing – исходящее (true - исходящее, false - входящее)
        • DateCreate – дата создания сообщения
        • IsRead – прочитано (true - прочитано, false - не прочитано )
        • Text – текст сообщения
Пример

Вызов метода SearchBookingsJSON

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
   <soapenv:Header/>
   <soapenv:Body>
      <tem:SearchBookingsJSON>
       <!--Optional:-->
         <tem:guid>fd57bdcb-35e0-41b1-9743-eba763211e49</tem:guid>
         <!--Optional:-->
         <tem:hotelID>
            <!--Zero or more repetitions:-->
            <tem:int>2930</tem:int>
         </tem:hotelID>
         <tem:dateInfo>1</tem:dateInfo>
         <tem:dateFrom>2022-08-20</tem:dateFrom>
         <tem:dateTo>2022-08-28</tem:dateTo>
         <tem:New>1</tem:New>
         <tem:change>1</tem:change>
         <tem:cancel>1</tem:cancel>
         <tem:inwork>1</tem:inwork>
      </tem:SearchBookingsJSON>
   </soapenv:Body>
</soapenv:Envelope>

Возвращаемый результат метода SearchBookingsJSON

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xmlns:xsd="http://www.w3.org/2001/XMLSchema">
   <soap:Body>
      <SearchBookingsJSONResponse xmlns="http://tempuri.org/">
         <SearchBookingsJSONResult>[{"Booking":"MT140101AAH","BookingID":37601,"Action":"New","CreationDate":
"2022-08-23T11:36:30.907","ChangeDate":null,"CancelDate":null,"CustomerMarket":{"CustomerMarketId":2,
"CustomerMarketName":"Russian Market"},"HotelServices":[{"CheckIn":"2022-08-20T00:00:00","CheckOut"
"2022-08-27T00:00:00","Tourists":[{"Name":"Vladimirov Alex","BirthDate":"1979-08-10T00:00:00","Sex":
"MR","HotelServiceId":171448},{"Name":"Vladimirovicha Alexa","BirthDate":"1972-08-11T00:00:00","Sex":
"MR","HotelServiceId":171448}],"CostOffers":[{"CostOfferName":"kolesnyk2/kolesnyk2","CostOfferDateBegin"
:"2022-08-20T00:00:00","CostOfferDateEnd":"2022-08-27T00:00:00","CostOfferDuration":7}],"Penalty":"",
"Notes":null,"HotelServiceId":171448,"HotelServiceName":"HTL::Kiev/Red/Double Room/2AD/Jakuzzi/BB",
"Hotel":{"HotelId":2930,"HotelName":"Red"},"Pansion":{"PansionId":3,"PansionName":"Bed and Breakfast"}
,"RoomType":{"RoomTypeId":3,"RoomTypeName":"Double Room"},"RoomAccomodation":{"AccommodationId":5558,
"AccommodationName":"2AD"},"RoomCategory":{"RoomCategoryId":20,"RoomCategoryName":"Jakuzzi"},"Status"
:{"StatusId":1,"StatusName":"Wait"}}],"Flights":[],"Messages":[]},{"Booking":"MT140101AAJ","BookingID"
:37602,"Action":"New","CreationDate":"2022-08-23T11:37:05.227","ChangeDate":null,"CancelDate":null,
"CustomerMarket":{"CustomerMarketId":2,"CustomerMarketName":"Russian Market"},"HotelServices":
[{"CheckIn":"2022-08-20T00:00:00","CheckOut":"2022-08-27T00:00:00","Tourists":[{"Name":"Vladimirov Alex",
"BirthDate":"1979-08-10T00:00:00","Sex":"MR","HotelServiceId":171454},{"Name":"Vladimirovicha Alexa"
,"BirthDate":"1972-08-11T00:00:00","Sex":"MR","HotelServiceId":171454}],"CostOffers":[{"CostOfferName"
:"kolesnyk2/kolesnyk2","CostOfferDateBegin":"2022-08-20T00:00:00","CostOfferDateEnd":"2022-08-27T00:00
:00","CostOfferDuration":7}],"Penalty":"","Notes":null,"HotelServiceId":171454,"HotelServiceName":
"HTL::Kiev/Red/Double Room/2AD/Jakuzzi/BB","Hotel":{"HotelId":2930,"HotelName":"Red"},"Pansion":
{"PansionId":3,"PansionName":"Bed and Breakfast"},"RoomType":{"RoomTypeId":3,"RoomTypeName":"Double Room"}
,"RoomAccomodation":{"AccommodationId":5558,"AccommodationName":"2AD"},"RoomCategory":{"RoomCategoryId":
20,"RoomCategoryName":"Jakuzzi"},"Status":{"StatusId":1,"StatusName":"Wait"}}],"Flights":[],"Messages":
[]},{"Booking":"MT140101AAK","BookingID":37607,"Action":"Changed","CreationDate":"2022-08-25T14:35:38.033",
"ChangeDate":null,"CancelDate":null,"CustomerMarket":{"CustomerMarketId":2,"CustomerMarketName"
:"Russian Market"},"HotelServices":[{"CheckIn":"2022-08-20T00:00:00","CheckOut":"2022-08-27T00:00:00"
,"Tourists":[{"Name":"Vladimirov Alex","BirthDate":"1979-08-10T00:00:00","Sex":"MR","HotelServiceId"
:171489},{"Name":"Vladimirovicha Alexa","BirthDate":"1972-08-11T00:00:00","Sex":"MR","HotelServiceId"
:171489}],"CostOffers":[{"CostOfferName":"kolesnyk2/kolesnyk2","CostOfferDateBegin":"2022-08-20T00:00:00"
,"CostOfferDateEnd":"2022-08-27T00:00:00","CostOfferDuration":7}],"Penalty":"","Notes":null,
"HotelServiceId":171489,"HotelServiceName":"HTL::Kiev/Red/Double Room/2AD/Jakuzzi/BB","Hotel"
:{"HotelId":2930,"HotelName":"Red"},"Pansion":{"PansionId":3,"PansionName":"Bed and Breakfast"}
,"RoomType":{"RoomTypeId":3,"RoomTypeName":"Double Room"},"RoomAccomodation":{"AccommodationId"
:5558,"AccommodationName":"2AD"},"RoomCategory":{"RoomCategoryId":20,"RoomCategoryName":"Jakuzzi"}
,"Status":{"StatusId":1,"StatusName":"Wait"}}],"Flights":[{"Tourist":"Vladimirov Alex","Charters"
:[{"Type":"Arrival","Date":"2022-08-20T00:00:00","Details":"A123-A124 (A123 - 16:00)"},{"Type"
:"Departure","Date":"2022-08-27T00:00:00","Details":"A123-A124 (A124 - 15:00)"}]},{"Tourist":
"Vladimirovicha Alexa","Charters":[{"Type":"Arrival","Date":"2022-08-20T00:00:00","Details":
"A123-A124 (A123 - 16:00)"},{"Type":"Departure","Date":"2022-08-27T00:00:00","Details":
"A123-A124 (A124 - 15:00)"}]}],"Messages":[]}]</SearchBookingsJSONResult>
      </SearchBookingsJSONResponse>
   </soap:Body>
</soap:Envelope>


GetMarkets (Получение списка рынков)

Метод предназначен для отображения всех существующих рынков.
Принимаемые параметры запроса ( * – обязательный):
Отсутствуют.
Возвращаемый результат:

  • GetMarketsResult – массив данных рынков
    • Name – наименование рынка
    • Id – идентификатор рынка
Пример

Вызов метода GetMarkets

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
   <soapenv:Header/>
   <soapenv:Body>
      <tem:GetMarkets/>
   </soapenv:Body>
</soapenv:Envelope>

Возвращаемый результат метода GetMarkets

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
   <soap:Body>
      <GetMarketsResponse xmlns="http://tempuri.org/">
         <GetMarketsResult>
            <MarketInfo Name="!test" Id="61"/>
            <MarketInfo Name="&lt;All>" Id="0"/>
            <MarketInfo Name="1111" Id="33"/>
            <MarketInfo Name="1112" Id="34"/>
            <MarketInfo Name="12" Id="32"/>
            <MarketInfo Name="12" Id="40"/>
            <MarketInfo Name="1t1" Id="44"/>
            <MarketInfo Name="1t2" Id="45"/>
            <MarketInfo Name="1t3" Id="46"/>
            <MarketInfo Name="1t4" Id="47"/>
            <MarketInfo Name="1t5" Id="48"/>
            <MarketInfo Name="1t6" Id="49"/>
            <MarketInfo Name="21" Id="36"/>
            <MarketInfo Name="234" Id="37"/>
            <MarketInfo Name="313" Id="38"/>
            <MarketInfo Name="34" Id="35"/>
            <MarketInfo Name="34" Id="41"/>
            <MarketInfo Name="4" Id="51"/>
            <MarketInfo Name="434" Id="39"/>
            <MarketInfo Name="45" Id="42"/>
            <MarketInfo Name="456" Id="43"/>
            <MarketInfo Name="Balkan Market" Id="5"/>
            <MarketInfo Name="France Market" Id="8"/>
            <MarketInfo Name="Greek Market" Id="3"/>
            <MarketInfo Name="Italy Market" Id="9"/>
            <MarketInfo Name="market12^*#$)_22_ 09" Id="22"/>
            <MarketInfo Name="market1FAD" Id="11"/>
            <MarketInfo Name="market2083" Id="13"/>
            <MarketInfo Name="market25C5" Id="16"/>
            <MarketInfo Name="market8085" Id="14"/>
            <MarketInfo Name="market9873" Id="10"/>
            <MarketInfo Name="marketA5F9" Id="18"/>
            <MarketInfo Name="marketD84E" Id="15"/>
            <MarketInfo Name="marketF3A6" Id="19"/>
            <MarketInfo Name="marketF415" Id="21"/>
            <MarketInfo Name="marketFCFE" Id="20"/>
            <MarketInfo Name="marketFFDC" Id="12"/>
            <MarketInfo Name="mk" Id="31"/>
            <MarketInfo Name="mk_market" Id="30"/>
            <MarketInfo Name="Old" Id="6"/>
            <MarketInfo Name="qwer" Id="50"/>
            <MarketInfo Name="Russian Market" Id="2"/>
            <MarketInfo Name="test new" Id="56"/>
            <MarketInfo Name="test1211" Id="53"/>
            <MarketInfo Name="Мой личный рынок" Id="25"/>
            <MarketInfo Name="ук" Id="55"/>
         </GetMarketsResult>
      </GetMarketsResponse>
   </soap:Body>
</soap:Envelope>


Методы передачи изменений по услугам

ManageBooking (Передача изменений по услуге проживания в Interlook)

Принимаемые параметры запроса ( * – обязательный):

  • guid * – идентификатор аутентификации (возвращается при запросе к методу Connect)
  • hotelServiceId * – ключ услуги проживания (возвращается при запросе к методу SearchBookings)
  • status – фильтр для отбора услуг с определенным статусом (1 - Wait, 2 - Confirmed, 3 - notConfirmed)
  • message – сообщение для пользователя Interlook
  • hotelWorkStatus – отметка отеля по заявке (true - отель взял заявку в работу, false - отель заявку в работу не взял). При отправке этого параметра формируется запись в историю по заявке и сообщение от провайдера.


История

Сообщение
Возвращаемый результат:

  • ManageBookingResult – массив данных
  • HotelServiceId – ключ сервиса отеля
  • HotelServiceName – имя сервиса отеля
    • Hotel – массив данных по отелям
      • HotelId – ключ отеля
      • HotelName – имя отеля
    • Pansion – тип питания
      • PansionId – ключ питания
      • PansionName – имя питания
    • RoomType – тип номера
      • RoomTypeId – ключ типа номера
      • RoomTypeName – имя типа номера
    • RoomAccomodation – тип размещения
      • AccommodationId – ключ типа размещения
      • AccommodationName – имя типа размещения
    • RoomCategory – категория номер
      • RoomCategoryId – ключ категории номера
      • RoomCategoryName – имя категории номера
    • Status – статус по услуге проживания
      • StatusId – ключ статуса по услуге проживания
      • StatusName – имя статуса по услуге проживания


Пример

Вызов метода ManageBooking

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
   <soapenv:Header/>
   <soapenv:Body>
      <tem:ManageBooking>
         <!--Optional:-->
         <tem:guid>69ad76b6-3551-403d-934e-18d8358a60e2</tem:guid>
         <tem:hotelServiceId>163806</tem:hotelServiceId>
         <tem:status>1</tem:status>
         <!--Optional:-->
         <tem:message>яварааааааааарвя</tem:message>
         <tem:hotelWorkStatus>false</tem:hotelWorkStatus>
      </tem:ManageBooking>
   </soapenv:Body>
</soapenv:Envelope>

Возвращаемый результат метода ManageBooking

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
   <soap:Body>
      <ManageBookingResponse xmlns="http://tempuri.org/">
         <ManageBookingResult Message="Ok">
            <Data>
               <ManageBookingResult>
                  <HotelServiceId>163806</HotelServiceId>
                  <HotelServiceName>HTL::Kiev/Hilton/Double Room/2AD/Jakuzzi/BB</HotelServiceName>
                  <Hotel>
                     <HotelId>2935</HotelId>
                     <HotelName>Hilton</HotelName>
                  </Hotel>
                  <Pansion>
                     <PansionId>3</PansionId>
                     <PansionName>Bed and Breakfast</PansionName>
                  </Pansion>
                  <RoomType>
                     <RoomTypeId>3</RoomTypeId>
                     <RoomTypeName>Double Room</RoomTypeName>
                  </RoomType>
                  <RoomAccomodation>
                     <AccommodationId>5558</AccommodationId>
                     <AccommodationName>2AD</AccommodationName>
                  </RoomAccomodation>
                  <RoomCategory>
                     <RoomCategoryId>20</RoomCategoryId>
                     <RoomCategoryName>Jakuzzi</RoomCategoryName>
                  </RoomCategory>
                  <Status>
                     <StatusId>1</StatusId>
                     <StatusName>Wait</StatusName>
                  </Status>
               </ManageBookingResult>
            </Data>
         </ManageBookingResult>
      </ManageBookingResponse>
   </soap:Body>
</soap:Envelope>


Методы создания цен

CreateCostOffer (Создание ценового предложения)

Метод предназначен для занесения цен на объекты размещения.
Принимаемые параметры запроса ( * – обязательный):

  • Guid * – идентификатор аутентификации (возвращается при запросе к методу Connect)
  • costOffer – массив данных CostOffer
    • HotelId * – ключ отеля
    • RateId * – ключ валюты
    • CostOfferTypeId – ключ типа CostOffer (Ordinary или SPO. Если не указан, то отправляется Ordinary. Если в запросе имеется и заполнена секция Rules, то CostOffer автоматически определяется с типом SPO)
    • MarketIds – ключ рынка (если не указан, то отправляется 0 - все. Возвращается при запросе к методу GetMarkets)
    • SaleDateBegin – дата с которой возможно бронирование (если не указана, то берется в соответствии с текущей)
    • SaleDateEnd – дата до которой возможно бронирование
    • NameFromProvider – наименование для провайдера (если не указан, то записывается пустое)
    • PeriodBeforeCheckIn – период до заезда (если не указан, то отправляется 0)
    • Comment – комментарий
    • MinDays – минимальная продолжительность (если не задано, то устанавливается 1)
    • MaxDays – максимальная продолжительность (если не задано, то устанавливается 365)
  • prices – массив данных цен
    • PriceRequest – массив данных цены
      • DateFrom * – дата начала (если не указана, то берется текущая)
      • DateTo * – дата окончания (если не указана, то берется из списка цен максимальная дата выезда)
      • DateCheckinFrom – дата заезда от (если не указан, то минимальная)
      • DateCheckinTo – дата заезда по (если не указан, то максимальная)
      • DateCheckoutFrom – дата выезда от (если не указан, то минимальная)
      • DateCheckoutTo – дата выезда по (если не указан, то максимальная)
      • WeekDays – день недели (если не указано, то проставляются все)
      • AccomodationId * – ключ типа размещения
      • RoomTypeId * – ключ типа комнаты
      • RoomCategoryId * – ключ категории комнаты
      • PansionId * – ключ типа питания
      • Price * – цена
      • TarifId – (если не указан, то устанавливается 0 - ordinary. Берется из таблицы Tariffs Базы Данных)
  • rules – массив данных правил изменения цены
    • XYRuleRequst – массив данных правил изменения цены
      • ExcludeBy – какие именно ночи должны быть бесплатными (принимает значения Last - последняя, Min - дешевая, Max - дорогая)
      • Sign – значение количества рассчитываемых ночей (принимает значения "=" или "-")
      • XFrom – от какой продолжительности проживания действует акция
      • XTo – до какой продолжительности проживания действует акция
      • Y – количество бесплатных ночей или значение продолжительности проживания

Возвращаемый результат:

  • CreateCostOfferResponse – массив данных CostOffer
    • Id – идентификатор CostOffer
    • Name – наименование CostOffer
    • CostOfferType – тип CostOffer
    • Rate – валюта
    • CreateDate – дата создания CostOffer
    • Markets – наименование рынка
    • XYRuleResponse – массив данных правил изменения цены
      • ExcludeBy – какие именно ночи должны быть бесплатными (принимает значения Last - последняя, Min - дешевая, Max - дорогая)
      • Sign – значение количества рассчитываемых ночей (принимает значения "=" или "-")
      • XFrom – от какой продолжительности проживания действует акция
      • XTo – до какой продолжительности проживания действует акция
      • Y – количество бесплатных ночей или значение продолжительности проживания
    • CostInfoResponse – массив данных цены
      • Id – идентификатор цены
      • Code – идентификатор отеля
      • CheckInDateBegin – дата заезда «с»
      • CheckInDateEnd – дата заезда «до»
      • CheckOutDateBegin – дата выезда «с»
      • CheckOutDateEnd – дата выезда «до»
      • DateBegin – дата действия цены «с»
      • DateEnd – дата действия цены «до»
      • Price – значение цены
      • RoomTypeId – ключ типа номера
      • PansionId – ключ питания
      • RoomCategoryId – ключ категории номера
      • AccommodationId – ключ типа размещения
      • TariffId – ключ тарифа (В таблице цен соответствует параметру CS_CVId)
      • Type – тип цены (Per Room - за комнату, Per Person - за человека)

В случае некорректного запроса в ответе приходит описание ошибки и номер строки, в которой указаны некорректные данные.

Пример

Вызов метода CreateCostOffer

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:tem="http://tempuri.org/">
   <soapenv:Header/>
   <soapenv:Body>
      <tem:CreateCostOffer>
         <!--Optional:-->
         <tem:guid>342d6612-f6d4-4149-a365-275a7701c306</tem:guid>
         <!--Optional:-->
         <tem:costOffer>
            <tem:HotelId>2930</tem:HotelId>
            <tem:RateId>1</tem:RateId>
            <tem:CostOfferTypeId>Ordinary</tem:CostOfferTypeId>
            <!--Optional:-->
            <tem:MarketIds>
               <!--Zero or more repetitions:-->
               <tem:int>2</tem:int>
            </tem:MarketIds>
            <tem:SaleDateBegin>2022-10-01</tem:SaleDateBegin>
            <tem:SaleDateEnd>2045-10-01</tem:SaleDateEnd>
            <!--Optional:-->
            <tem:NameFromProvider>New Name</tem:NameFromProvider>
            <tem:PeriodBeforeCheckIn>1</tem:PeriodBeforeCheckIn>
            <!--Optional:-->
            <tem:Comment>NewComment</tem:Comment>
            <tem:MinDays>1</tem:MinDays>
            <tem:MaxDays>7</tem:MaxDays>
         </tem:costOffer>
         <!--Optional:-->
         <tem:prices>
            <!--Zero or more repetitions:-->
            <tem:PriceRequest>
               <tem:DateFrom>2022-10-01</tem:DateFrom>
               <tem:DateTo>2028-10-01</tem:DateTo>
               <tem:DateCheckinFrom>2022-10-01</tem:DateCheckinFrom>
               <tem:DateCheckinTo>2025-10-01</tem:DateCheckinTo>
               <tem:DateCheckoutFrom>2028-10-01</tem:DateCheckoutFrom>
               <tem:DateCheckoutTo>2028-10-01</tem:DateCheckoutTo>
               <!--Optional:-->
               <tem:WeekDays>1234567</tem:WeekDays>
               <tem:AccomodationId>5558</tem:AccomodationId>
               <tem:RoomTypeId>3</tem:RoomTypeId>
               <tem:RoomCategoryId>20</tem:RoomCategoryId>
               <tem:PansionId>3</tem:PansionId>
               <tem:Price>932</tem:Price>
               <tem:TarifId>0</tem:TarifId>
            </tem:PriceRequest>
         </tem:prices>
         <!--Optional:-->
         <tem:rules>
            <!--Zero or more repetitions:-->
            <tem:XYRuleRequst>
               <tem:ExcludeBy>Last</tem:ExcludeBy>
               <!--Optional:-->
               <tem:Sign>=</tem:Sign>
               <tem:XFrom>1</tem:XFrom>
               <tem:XTo>5</tem:XTo>
               <tem:Y>1</tem:Y>
            </tem:XYRuleRequst>
         </tem:rules>
      </tem:CreateCostOffer>
   </soapenv:Body>
</soapenv:Envelope>

Возвращаемый результат метода CreateCostOffer

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
   <soap:Body>
      <CreateCostOfferResponse xmlns="http://tempuri.org/">
         <CreateCostOfferResult Message="Ok">
            <Data>
               <CreateCostOfferResponse>
                  <Id>2549</Id>
                  <Name>2022.10.01 - 2028.10_Russian Market_1-7_&lt;All>_Mouzenidis Travel 1_Red_53</Name>
                  <CostOfferType>SPO</CostOfferType>
                  <Rate>EU</Rate>
                  <CreateDate>2022-11-14T13:14:07.047</CreateDate>
                  <Markets>Russian Market</Markets>
                  <XYRules>
                     <XYRuleResponse>
                        <ExcludeBy>Last</ExcludeBy>
                        <Sign>-</Sign>
                        <XFrom>1</XFrom>
                        <XTo>5</XTo>
                        <Y>1</Y>
                     </XYRuleResponse>
                  </XYRules>
                  <CostsInfo>
                     <CostInfoResponse>
                        <Id>807703</Id>
                        <Code>2930</Code>
                        <CheckInDateBegin>2028-10-01T00:00:00</CheckInDateBegin>
                        <CheckInDateEnd>2028-10-01T00:00:00</CheckInDateEnd>
                        <CheckOutDateBegin>2028-10-01T00:00:00</CheckOutDateBegin>
                        <CheckOutDateEnd>2028-10-01T00:00:00</CheckOutDateEnd>
                        <DateBegin>2022-10-01T00:00:00</DateBegin>
                        <DateEnd>2028-10-01T00:00:00</DateEnd>
                        <Price>956.1700</Price>
                        <RoomTypeId>3</RoomTypeId>
                        <PansionId>3</PansionId>
                        <RoomCategoryId>20</RoomCategoryId>
                        <AccomodationId>5558</AccomodationId>
                        <TariffId>0</TariffId>
                        <Type>PerPax</Type>
                     </CostInfoResponse>
                  </CostsInfo>
               </CreateCostOfferResponse>
            </Data>
         </CreateCostOfferResult>
      </CreateCostOfferResponse>
   </soap:Body>
</soap:Envelope>