Master-Interlook:HotelService
Версия статьи от 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" - инициализация кэша максимально производительная: каждый отель загружается в своем потоке (возможны сбои). |
<add key="cachingTime" value="-1"/>
|
2 | Включение логирования о использовании памяти сервера | LogCacheMemory Настройка служит для включения или отключения логирования в таблицу базы данных о использовании кешем сервиса памяти сервера. |
<add key="LogCacheMemory" value="0"/>
|
Методы HotelService
Методы аутентификации
Connect (Получение аутентификационного токена)
Принимаемые параметры запроса ( * – обязательный):
- Login * – логин online пользователя
- Password * – пароль online пользователя
Возвращаемый результат:
- ConnectResult – идентификатор аутентификации (если аутентификация прошла успешно. то получаем идентификатор, в противном случае результат -1)
CheckConnect (Проверка активности подключения под конкретным идентификатором)
Метод проверяет наличие активного подключения под конкретным идентификатором аутентификации.
Принимаемые параметры запроса ( * – обязательный):
- Guid * – идентификатор аутентификации (возвращается при запросе к методу Connect)
Возвращаемый результат:
- CheckConnectResult – идентификатор аутентификации (true – если подключение активно, false – если подключения нет)
Методы поиска
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 – ключ услуги проживания с которой связан турист
- TouristInfo – массив данных по туристу
- CostOffers – массив данных по CostOffers, по которым рассчитана цена услуги
- CostOfferInfo – массив данных по конкретному CostOffer
- CostOfferName – название CostOffer (Если заявка не аннулирована, то выводим название CostOffer по цене netto. Если заявка аннулирована со штрафами, то выводим название CostOffer по цене брутто. Если заявка аннулирована без штрафов, то выводим текст "Canceled without penalty")
- CostOfferDateBegin – дата начала действия CostOffer
- CostOfferDateEnd – дата окончания действия CostOffer
- CostOfferDuration – продолжительность проживания до данному CostOffer
- CostOfferInfo – массив данных по конкретному CostOffer
- Penalty – информация о штрафах по аннулированной заявке
- FlightInfo – секция информации об авиаперелете
- Tourist – Фамилия и имя туриста
- Charters – секция авиаперелета
- CharterInfo – секция информации об авиаперелете
- Type – тип авиаперелета (Arrival или Departure)
- Date – дата заезда/выезда из отеля
- Details – наименование авиаперелета (номер рейса - время прилета/вылета)
- CharterInfo – секция информации об авиаперелете
- HotelServiceInfo – информация по сервису отеля
- MessageInfo – массив данных сообщений
- Id – идентификатор сообщения
- IsOutgoing – исходящее (true - исходящее, false - входящее)
- DateCreate – дата создания сообщения
- IsRead – прочитано (true - прочитано, false - не прочитано )
- Text – текст сообщения
- BookingInfo – массив данных брони
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 – ключ услуги проживания с которой связан турист
- TouristInfo – массив данных по туристу
- CostOffers – массив данных по CostOffers, по которым рассчитана цена услуги
- CostOfferInfo – массив данных по конкретному CostOffer
- CostOfferName – название CostOffer (Если заявка не аннулирована, то выводим название CostOffer по цене netto. Если заявка аннулирована со штрафами, то выводим название CostOffer по цене брутто. Если заявка аннулирована без штрафов, то выводим текст "Canceled without penalty")
- CostOfferDateBegin – дата начала действия CostOffer
- CostOfferDateEnd – дата окончания действия CostOffer
- CostOfferDuration – продолжительность проживания до данному CostOffer
- CostOfferInfo – массив данных по конкретному CostOffer
- Penalty – информация о штрафах по аннулированной заявке
- FlightInfo – секция информации об авиаперелете
- Tourist – Фамилия и имя туриста
- Charters – секция авиаперелета
- CharterInfo – секция информации об авиаперелете
- Type – тип авиаперелета (Arrival или Departure)
- Date – дата заезда/выезда из отеля
- Details – наименование авиаперелета (номер рейса - время прилета/вылета)
- CharterInfo – секция информации об авиаперелете
- MessageInfo – массив данных сообщений
- Id – идентификатор сообщения
- IsOutgoing – исходящее (true - исходящее, false - входящее)
- DateCreate – дата создания сообщения
- IsRead – прочитано (true - прочитано, false - не прочитано )
- Text – текст сообщения
GetMarkets (Получение списка рынков)
Метод предназначен для отображения всех существующих рынков.
Принимаемые параметры запроса ( * – обязательный):
Отсутствуют.
Возвращаемый результат:
- GetMarketsResult – массив данных рынков
- Name – наименование рынка
- Id – идентификатор рынка
Методы передачи изменений по услугам
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 – имя статуса по услуге проживания
- Hotel – массив данных по отелям
Методы создания цен
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 Базы Данных)
- PriceRequest – массив данных цены
- rules – массив данных правил изменения цены
- XYRuleRequst – массив данных правил изменения цены
- ExcludeBy – какие именно ночи должны быть бесплатными (принимает значения Last - последняя, Min - дешевая, Max - дорогая)
- Sign – значение количества рассчитываемых ночей (принимает значения "=" или "-")
- XFrom – от какой продолжительности проживания действует акция
- XTo – до какой продолжительности проживания действует акция
- Y – количество бесплатных ночей или значение продолжительности проживания
- XYRuleRequst – массив данных правил изменения цены
Возвращаемый результат:
- 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 - за человека)
В случае некорректного запроса в ответе приходит описание ошибки и номер строки, в которой указаны некорректные данные.