ПОДПИСЫВАЙТЕСЬ НА НАШ ТЕЛЕГРАМ-КАНАЛ @nemo_travel_official

Интеграция со сторонними системами АПИ: различия между версиями

Материал из Центр поддержки системы бронировании
Перейти к навигации Перейти к поиску
(API Поиска авиабилетов)
(API Поиска отелей)
Строка 13: Строка 13:
 
==API Поиска отелей==
 
==API Поиска отелей==
 
'''Агентский API Отелей''' - система, которая предоставляет возможность поиска и бронирования отелей а так же получение информации о времени и размерах штрафов, уникальной информации об отеле, получение статической информации.
 
'''Агентский API Отелей''' - система, которая предоставляет возможность поиска и бронирования отелей а так же получение информации о времени и размерах штрафов, уникальной информации об отеле, получение статической информации.
 
=== Динамические данные ===
 
==== Поиск ====
 
 
Сервис предназначен для получения списка отелей, удовлетворяющих условиям запроса. В условия запроса входят: идентификатор города, где будет вестись поиск; дата заезда и дата выезда; информация о количестве людей и способе их размещения в комнатах. Так же указываются дополнительные необязательные поля фильтров.
 
 
Для получения списка доступных городов, воспользуйтесь запросом на выгрузку статики (см. ССЫЛКА). Список допустимых отелей для фильтра также доступен через сервис (см. ССЫЛКА). Рекомендуется выгрузить все данные по отелям, городам и странам в локальную базу, для экономии времени и запросов.
 
 
'''WSDL''' (тестовый сервер): [http://tst.nemo-ibe.com/wsdev/wsdl.php?for=HotelsSearch http://tst.nemo-ibe.com/wsdev/wsdl.php?for=HotelsSearch]
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Запрос =====
 
<div class="mw-collapsible-content">
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ver="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DHotelsSearch">
 
  <soapenv:Header/>
 
  <soapenv:Body>
 
    <ver:search>
 
      <RequestBin>
 
        <Request>
 
          <HotelSearch>
 
            <CityId>22046</CityId>
 
            <DateBegin>2013-10-15</DateBegin>
 
            <DateEnd>2013-10-18</DateEnd>
 
            <Rooms>
 
              <!--Zero or more repetitions:-->
 
              <Room>
 
                <Persons>
 
                  <!--Zero or more repetitions:-->
 
                  <Person Id="1" Type="ADT" Age="30"/>
 
                  <Person Id="2" Type="CLD" Age="10"/>
 
                </Persons>
 
                <!--Optional:-->
 
                <DoubleBed>false</DoubleBed>
 
              </Room>
 
              <Room>
 
                <Persons>
 
                  <!--Zero or more repetitions:-->
 
                  <Person Id="1" Type="ADT" Age="30"/>
 
                </Persons>
 
              </Room>
 
            </Rooms>
 
            <!--Optional:-->
 
            <Filters>
 
              <Hotels>
 
                <!--Zero or more repetitions:-->
 
                <!--<Id>123</Id>-->
 
              </Hotels>
 
            </Filters>
 
          </HotelSearch>
 
        </Request>
 
        <Source>
 
          <ClientId></ClientId>
 
          <APIKey></APIKey>
 
          <Language>ru</Language>
 
          <Currency>RUB</Currency>
 
        </Source>
 
      </RequestBin>
 
    </ver:search>
 
  </soapenv:Body>
 
</soapenv:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''HotelSearch'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| CityId
 
| Обязательный. Идентификатор города в системе Nemo.
 
| Целое число
 
|-
 
| DateBegin
 
| Обязательный. Дата заселения.
 
| Формат гггг-мм-дд.
 
|-
 
| DateEnd
 
| Обязательный. Дата выезда.
 
| Формат гггг-мм-дд.
 
|-
 
| Rooms
 
| Обязательный. Содержит массив запрашиваемых номеров/апартаментов.
 
| Элемент Room. Максимум 4 элемента Room.
 
|-
 
| Filters
 
| Необязательный. Содержит различные фильтры поиска отелей.
 
| Элемент Hotels.
 
|}
 
 
Элемент '''Room'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Persons
 
| Обязательный. Содержит данные о клиентах в номерах.
 
| Элемент Person
 
|-
 
| DoubleBed
 
| Необязательный. Может быть использован только если сумма количества детей и взрослых равна 2-м, а также
 
Если в запросе сумма детей и взрослых не равна 2, то данный элемент будет проигнорирован.
 
| true/false
 
true означает, что номер должен иметь двуспальную кровать
 
|}
 
 
Элемент '''Person'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Атрибут Id
 
| Уникальный идентификатор. См. результаты бронирования.
 
| Целое число
 
|-
 
| Атрибут Type
 
| Тип клиента.
 
Если не указан, будет определен по возрасту Age.
 
| Константы:
 
ADT - взрослый
 
CLD - ребенок 2-12 лет
 
INF - младенец до 2х лет
 
|-
 
| Атрибут Age
 
| Возраст. Обязателен для детей (CLD).
 
| Целое число. Количество лет.
 
|}
 
 
Элемент '''Filters'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Hotels
 
| Необязательный. Набор идентификаторов отелей в системе Nemo.
 
Результаты поиска будут ограничены только этими отелями. Данная опция может существенно ускорить поиск - рекомендуется всегда устанавливать при поиске конкретных отелей.
 
| Элемент Id – целое число
 
|}
 
 
Элемент '''Source'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| ClientID
 
| Обязательный. ID клиента в системе Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Целое число.
 
|-
 
| APIKey
 
| Обязательный. APIKey - секретный ключ доступа к API Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Латинские буквы и цифры. Всего 32 символа.
 
|}
 
</div>
 
</div>
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Ответ =====
 
<div class="mw-collapsible-content">
 
Система по заданным параметрам ищет отели и возвращает результаты поиска. Все результаты поиска хранятся в базе Nemo определенный срок и доступны для бронирования по идентификатору CacheId.
 
 
Структура ответа - это набор уникальных отелей. У каждого указан Id - это идентификатор из базы Nemo. По нему можно получить дополнительную статичную информацию из путеводителя Nemo.
 
 
Каждый отель содержит:
 
* Набор номеров &lt;Rooms&gt;. Типы номеров (одноместный, двухместный и т.д.)&nbsp;: устанавливается автоматически по количеству клиентов из запроса.
 
* Сервисы &lt;Services&gt;. Каждый отель предлагает различные типы обслуживания в номерах. Цена и доступность может различаться.
 
* Категория &lt;Categories&gt;. Это допустимые комбинации номер + обслуживание. Для бронирования отеля пользователь должен выбрать одну из предлагаемых ему категорий.
 
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ns1="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DHotelsSearch">
 
  <SOAP-ENV:Body>
 
    <ns1:searchResponse>
 
      <ResponseBin>
 
        <Response>
 
          <HotelSearch>
 
            <Hotels>
 
              <Hotel Id="1872666">
 
                <Supplier>GTA</Supplier>
 
                <CityId>22046</CityId>
 
                <DateBegin>2013-10-15</DateBegin>
 
                <DateEnd>2013-10-18</DateEnd>
 
                <CacheId>1872666</CacheId>
 
                <Name>ADLON KEMPINSKI</Name>
 
                <Categories>
 
                  <Category Id="1">
 
                    <Rooms>
 
                      <Room Count="1" Id="1" ServiceId="1"/>
 
                      <Room Count="1" Id="2" ServiceId="2"/>
 
                    </Rooms>
 
                    <TotalPrice Currency="RUB">74733.84</TotalPrice>
 
                  </Category>
 
                </Categories>
 
                <Services>
 
                  <Service Id="1" Status="OK">
 
                    <Desc>Standard Twin</Desc>
 
                    <Meal>Full Breakfast</Meal>
 
                    <Price/>
 
                  </Service>
 
                  <Service Id="2" Status="OK">
 
                    <Desc>Standard Twin</Desc>
 
                    <Meal>Full Breakfast</Meal>
 
                    <Price/>
 
                  </Service>
 
                </Services>
 
                <Rooms>
 
                  <Room Id="1" Type="TWIN"/>
 
                  <Room Id="2" Type="SNGL"/>
 
                </Rooms>
 
              </Hotel>
 
...
 
            </Hotels>
 
          </HotelSearch>
 
        </Response>
 
      </ResponseBin>
 
    </ns1:searchResponse>
 
  </SOAP-ENV:Body>
 
</SOAP-ENV:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''Hotel'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Атрибут Id
 
| Обязательный. Идентификатор отеля как одного из результатов поиска в системе Nemo.
 
| Целое число.
 
|-
 
| Supplier
 
| Обязательный. Тип поставщика, в котором найден отель.
 
| Строка.
 
Возможные значения:
 
GTA
 
HOTELBEDS
 
DOTW
 
SERHS
 
MIKI
 
TRAVCO
 
ACADEM
 
TOURICO
 
|-
 
| CityId
 
| Обязательный. Идентификатор города в системе Nemo.
 
| Целое число.
 
|-
 
| CacheId
 
| Обязательный. Идентификатор результата поиска для данного отеля в системе Nemo.
 
| Целое число.
 
|-
 
| Name
 
| Обязательный. Название отеля.
 
| Строка в произвольном формате.
 
|-
 
| Services
 
| Обязательный. Услуги в отеле.
 
| Элемент Service
 
|-
 
| Rooms
 
| Обязательный. Комнаты в отеле.
 
| Элемент Room
 
|-
 
| Categories
 
| Обязательный. Категории, доступные для бронирования в отеле.
 
| Элемент Category
 
|}
 
 
Элемент '''Service'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Атрибут Id
 
| Обязательный. Идентификатор услуги.
 
| Целое число
 
|-
 
| Атрибут Status
 
| Обязательный. Доступность отеля. ОК означает доступен (мгновенное подтверждение).
 
RQ - недоступен (по запросу).
 
| ОК/RQ
 
|-
 
| Desc
 
| Необязательный. Описание отеля.
 
| Строка в произвольном формате.
 
|-
 
| Meal
 
| Обязательный. Питание для данного сервиса.
 
| Строка в произвольном формате.
 
|-
 
| Price
 
| Необязательный. Указывает на стоимость номера с данной услугой.
 
| Вещественное число.
 
Атрибут Currency - код валюты.
 
|}
 
 
Элемент '''Room'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Атрибут Id
 
| Обязательный. Идентификатор комнаты в отеле.
 
| Целое число.
 
|-
 
| Type
 
| Обязательный. Тип номера.
 
| Строка. Возможные значения:
 
SNGL – одноместный
 
DBL – двухместный с двухспальной кроватью
 
TWIN – двухместный с двумя кроватями
 
TRIP – трёхместный
 
QUAD – четырёхместный
 
|}
 
 
Элемент '''Category'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Атрибут Id
 
| Обязательный. Идентификатор категории.
 
| Целое число.
 
|-
 
| Rooms
 
| Обязательный. Массив комнат с соответствием услуг.
 
| Целое число.
 
|-
 
| Room
 
| Атрибут: Count
 
 
Обязательный.
 
Количество комнат данного типа.
 
 
Атрибут: Id
 
 
Обязательный. Идентификатор комнаты из атрибута Id в элементе Hotel-> Rooms-> Room.
 
 
Атрибут: ServiceId
 
 
- Идентификатор услуги из атрибута Id элемента Service.
 
| Целое число.
 
 
Целое число.
 
 
Целое число.
 
|-
 
| TotalPrice
 
| Обязательный. Суммарная стоимость бронируемого сочетания “Комнаты - услуги”.
 
| Вещественное число.
 
Атрибут Currency - код валюты.
 
|}
 
</div>
 
</div>
 
 
 
 
==== Расширенная информация по одному отелю ====
 
Сервис получения дополнительной информации об отеле требует указания идентификатора отеля в системе Nemo и категории.
 
 
'''WSDL''' (тестовый сервер): http://tst.nemo-ibe.com/wsdev/wsdl.php?for=HotelExtInfo
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Запрос =====
 
<div class="mw-collapsible-content">
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ver="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DHotelExtInfo">
 
  <soapenv:Header/>
 
  <soapenv:Body>
 
    <ver:extInfo>
 
      <RequestBin>
 
        <Request>
 
          <HotelExtInfo>
 
            <Item>
 
              <CacheId>1867246</CacheId>
 
              <!--Optional:-->
 
              <CategoryId>1</CategoryId>
 
            </Item>
 
          </HotelExtInfo>
 
        </Request>
 
        <Source>
 
          <ClientId></ClientId>
 
          <APIKey></APIKey>
 
          <Language>ru</Language>
 
          <Currency>RUB</Currency>
 
        </Source>
 
      </RequestBin>
 
    </ver:extInfo>
 
  </soapenv:Body>
 
</soapenv:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''Item'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| CacheId
 
| Обязательный. Идентификатор результата поиска.
 
| Целое число
 
|-
 
| CategoryId
 
| ID выбранной категории.
 
| Целое число
 
|}
 
 
Элемент '''Source'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| ClientID
 
| Обязательный. ID клиента в системе Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Целое число.
 
|-
 
| APIKey
 
| Обязательный. APIKey - секретный ключ доступа к API Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Латинские буквы и цифры. Всего 32 символа.
 
|}
 
</div>
 
</div>
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Ответ =====
 
<div class="mw-collapsible-content">
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ns1="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DHotelExtInfo"
 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
 
  <SOAP-ENV:Body>
 
    <ns1:extInfoResponse>
 
      <ResponseBin>
 
        <Response>
 
          <HotelExtInfo>
 
            <CategoryId>1</CategoryId>
 
            <PriceInfo>
 
              <PriceBreakDown>
 
                <Date>
 
                  <From>2013-10-15</From>
 
                  <To>2013-10-18</To>
 
                  <Price Currency="RUB">12455.64</Price>
 
                </Date>
 
                <Date>
 
                  <From>2013-10-15</From>
 
                  <To>2013-10-18</To>
 
                  <Price Currency="RUB">12455.64</Price>
 
                </Date>
 
              </PriceBreakDown>
 
              <Netto Currency="EUR">1821</Netto>
 
              <Gross xsi:nil="true"/>
 
            </PriceInfo>
 
          </HotelExtInfo>
 
        </Response>
 
      </ResponseBin>
 
    </ns1:extInfoResponse>
 
  </SOAP-ENV:Body>
 
</SOAP-ENV:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''HotelExtInfo'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| CategoryId
 
| Обязательный. Идентификатор категории.
 
| Целое число
 
|-
 
| PriceInfo
 
| Обязательный. Элемент содержащий информацию о цене
 
| см. Элемент PriceInfo
 
|}
 
 
Элемент '''PriceInfo'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| style="width:208px; height:35px" |
 
PriceBreakDown
 
| style="width:208px; height:35px" |
 
Необязательный. Информация о ценах, расписанная по каждому дню.
 
| style="width:208px; height:35px" |
 
Список элементов Date
 
|-
 
| Netto
 
| Обязательный. Стоимость от поставщика.
 
| Вещественное число.
 
Атрибут Currency - код валюты.
 
|-
 
| Gross
 
| Обязательный. Общая стоимость.
 
| Вещественное число.
 
Атрибут Currency - код валюты.
 
|}
 
 
Элемент '''Date'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| From
 
| Обязательный. Дата начала действия тарифа
 
| Формат гггг-мм-дд
 
|-
 
| To
 
| Обязательный. Дата окончания действия тарифа
 
| Формат гггг-мм-дд
 
|-
 
| Price
 
| Цена за одну ночь.
 
| Вещественное число.
 
Атрибут Currency - код валюты.
 
|}
 
</div>
 
</div>
 
 
=== Статические данные ===
 
Для работы с веб-сервисом Nemo необходимо выгрузить статичные данные. Это данные о странах, городах и отелях.
 
==== Страна ====
 
'''WSDL''' (тестовый сервер): http://tst.nemo-ibe.com/wsdev/wsdl.php?for=CountryStatic
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Запрос =====
 
<div class="mw-collapsible-content">
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ver="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DCountryStatic">
 
  <soapenv:Header/>
 
  <soapenv:Body>
 
      <ver:countries>
 
        <RequestBin>
 
            <Request>
 
              <CountryStatic>
 
              </CountryStatic>
 
            </Request>
 
            <Source>
 
              <ClientId></ClientId>
 
              <APIKey></APIKey>
 
              <Language>ru</Language>
 
              <Currency>RUB</Currency>
 
            </Source>
 
        </RequestBin>
 
      </ver:countries>
 
  </soapenv:Body>
 
</soapenv:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''Request'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| CountryStatic
 
| Пустой элемент
 
| <br/>
 
|}
 
 
Элемент '''Source'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| ClientID
 
| Обязательный. ID клиента в системе Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Целое число.
 
|-
 
| APIKey
 
| Обязательный. APIKey - секретный ключ доступа к API Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Латинские буквы и цифры. Всего 32 символа.
 
|}
 
</div>
 
</div>
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Ответ =====
 
<div class="mw-collapsible-content">
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ns1="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DCountryStatic"
 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
 
  <SOAP-ENV:Body>
 
      <ns1:countriesResponse>
 
        <ResponseBin>
 
            <Response>
 
              <CountryStatic>
 
                  <Countries>
 
                    <Country Id="4">
 
                        <Code>AF</Code>
 
                        <Continent>asia</Continent>
 
                        <Data>
 
                          <Info Language="RU">
 
                              <Name>Афганистан</Name>
 
                          </Info>
 
                          <Info Language="EN">
 
                              <Name>Afghanistan</Name>
 
                          </Info>
 
                        </Data>
 
                    </Country>
 
                  </Countries>
 
              </CountryStatic>
 
            </Response>
 
        </ResponseBin>
 
      </ns1:countriesResponse>
 
  </SOAP-ENV:Body>
 
</SOAP-ENV:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''CountryStatic'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Countries
 
| Обязательный
 
| Набор элементов Country
 
|}
 
 
Элемент '''Country'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Атрибут Id
 
| Обязательный. Идентификатор страны (ISO).
 
| Целое число
 
|-
 
| Code
 
| Обязательный. Код страны ISO.
 
| Строка из 2-х латинских букв
 
|-
 
| Continent
 
| Обязательный. Название континента.
 
| Строка.
 
|-
 
| Data
 
| Обязательный. Информация требующая перевода.
 
| Набор элементов Info.
 
|}
 
 
Элемент '''Info'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Атрибут Language
 
| Обязательный. Язык в котором представлена информация.
 
| Строка из 2-х латинских букв.
 
|-
 
| Name
 
| Обязательный. Наименование страны.
 
| Строка в произвольном формате.
 
|}
 
</div>
 
</div>
 
 
 
 
==== Город ====
 
Параметры поиска всех услуг требуют указания ID города. Города выгружаются по каждой стране следующим запросом:
 
 
'''WSDL''' (тестовый сервер): http://tst.nemo-ibe.com/wsdev/wsdl.php?for=CityStatic
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Запрос =====
 
<div class="mw-collapsible-content">
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ver="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DCityStatic">
 
  <soapenv:Header/>
 
  <soapenv:Body>
 
      <ver:cities>
 
        <RequestBin>
 
            <Request>
 
              <CityStatic>
 
                  <CountryId>4</CountryId>
 
              </CityStatic>
 
            </Request>
 
            <Source>
 
              <ClientId></ClientId>
 
              <APIKey></APIKey>
 
              <Language>ru</Language>
 
              <Currency>RUB</Currency>
 
            </Source>
 
        </RequestBin>
 
      </ver:cities>
 
  </soapenv:Body>
 
</soapenv:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''CityStatic'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| CountryId
 
| Обязательный. Идентификатор страны.
 
| Целое число
 
|}
 
 
Элемент '''Source'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| ClientID
 
| Обязательный. ID клиента в системе Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Целое число.
 
|-
 
| APIKey
 
| Обязательный. APIKey - секретный ключ доступа к API Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Латинские буквы и цифры. Всего 32 символа.
 
|}
 
</div>
 
</div>
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Ответ =====
 
<div class="mw-collapsible-content">
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ns1="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DCityStatic">
 
  <SOAP-ENV:Body>
 
      <ns1:citiesResponse>
 
        <ResponseBin>
 
            <Response>
 
              <CityStatic>
 
                  <Cities>
 
                    <City Id="1">
 
                        <Name>Кабул</Name>
 
                        <CountryId>4</CountryId>
 
                        <Data>
 
                          <Info Language="EN">
 
                              <Name>Kabul</Name>
 
                          </Info>
 
                          <Info Language="RU">
 
                              <Name>Кабул</Name>
 
                          </Info>
 
                        </Data>
 
                    </City>
 
                    <City Id="204793">
 
                        <Name>Aibak</Name>
 
                        <CountryId>4</CountryId>
 
                        <Data>
 
                          <Info Language="EN">
 
                              <Name>Aibak</Name>
 
                          </Info>
 
                          <Info Language="RU">
 
                              <Name>Aibak</Name>
 
                          </Info>
 
                        </Data>
 
                    </City>
 
                    <City Id="204785">
 
                        <Name>Anar Darah</Name>
 
                        <CountryId>4</CountryId>
 
                        <Data>
 
                          <Info Language="EN">
 
                              <Name>Anar Darah</Name>
 
                          </Info>
 
                          <Info Language="RU">
 
                              <Name>Anar Darah</Name>
 
                          </Info>
 
                        </Data>
 
                    </City>
 
...
 
                  </Cities>
 
              </CityStatic>
 
            </Response>
 
        </ResponseBin>
 
      </ns1:citiesResponse>
 
  </SOAP-ENV:Body>
 
</SOAP-ENV:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''CityStatic'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Cities
 
| Обязательный. Массив городов.
 
| Набор элементов City
 
|}
 
 
Элемент '''City'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Атрибут '''Id'''
 
| Обязательный. Идентификатор города.
 
| Целое число
 
|-
 
| Name
 
| Название города.
 
|
 
|-
 
| Data
 
| Названия городов на разных языках. В данный момент поддерживаются названия на русском и английском.
 
| См. описание элемента Data в ответе получения информации о стране.
 
|}
 
</div>
 
</div>
 
 
==== Статика по отелям и апартаментам ====
 
Этот запрос будет использоваться для выгрузки статичной информации по одному или нескольким отелям.
 
 
'''WSDL''' (тестовый сервер): http://tst.nemo-ibe.com/wsdev/wsdl.php?for=HotelStatic
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Запрос =====
 
<div class="mw-collapsible-content">
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ver="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DHotelStatic">
 
  <soapenv:Header/>
 
  <soapenv:Body>
 
      <ver:hotels>
 
        <RequestBin>
 
            <Request>
 
              <HotelStatic>
 
                  <CityId>58166</CityId>
 
              </HotelStatic>
 
            </Request>
 
            <Source>
 
              <ClientId></ClientId>
 
              <APIKey></APIKey>
 
              <Language>ru</Language>
 
              <Currency>RUB</Currency>
 
            </Source>
 
        </RequestBin>
 
      </ver:hotels>
 
  </soapenv:Body>
 
</soapenv:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''Hotels'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| CityId
 
| Обязательный. Идентификатор города из которого необходимо получить отели.
 
| Целое число
 
|}
 
 
Элемент '''Source'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| ClientID
 
| Обязательный. ID клиента в системе Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Целое число.
 
|-
 
| APIKey
 
| Обязательный. APIKey - секретный ключ доступа к API Nemo.
 
Можно посмотреть/добавить в "Администрирование" ⇨ "Веб-служба. Авторизация".
 
| Латинские буквы и цифры. Всего 32 символа.
 
|}
 
</div>
 
</div>
 
 
<div class="toccolours mw-collapsible mw-collapsed" style="width:1000px">
 
===== Ответ =====
 
<div class="mw-collapsible-content">
 
<syntaxhighlight lang="xml" line enclose="div" style="font-size:9pt;background: #F9F9F9; border: 1px dashed #2F6FAB; padding: 10px 5px; margin: 10px 0;">
 
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
 
xmlns:ns1="http://tst.nemo-ibe.com/wsdev/?version%3D1.0%26for%3DHotelStatic"
 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
 
  <SOAP-ENV:Body>
 
      <ns1:hotelsResponse>
 
        <ResponseBin>
 
            <Response>
 
              <HotelStatic>
 
                  <Hotels>
 
                    <Hotel Id="271714" Apartment="false">
 
                        <CityId>58166</CityId>
 
                        <CountryId>643</CountryId>
 
                        <Latitude xsi:nil="true"/>
 
                        <Longitude xsi:nil="true"/>
 
                        <Rating>3</Rating>
 
                        <Floors xsi:nil="true"/>
 
                        <Data>
 
                          <Info>
 
                              <Name>* Azimut (business)</Name>
 
                              <Area xsi:nil="true"/>
 
                              <Location>Within city</Location>
 
                              <Desc>This 3 star hotel is located within the city of St Petersburg.</Desc>
 
                              <Address>43/1 Lermoutovsky Prospect, St Petersburg, 190103</Address>
 
                          </Info>
 
                        </Data>
 
                        <Phones>
 
                          <Phone>812 7402640</Phone>
 
                        </Phones>
 
                        <Fax>812 2518890</Fax>
 
                        <Images/>
 
                    </Hotel>
 
                    <Hotel Id="159535" Apartment="false">
 
                        <CityId>58166</CityId>
 
                        <CountryId>643</CountryId>
 
                        <Latitude>59.935011</Latitude>
 
                        <Longitude>30.309284</Longitude>
 
                        <Rating>5</Rating>
 
                        <Floors xsi:nil="true"/>
 
                        <Data>
 
                          <Info>
 
                              <Name>W St.petersburg</Name>
 
                              <Area xsi:nil="true"/>
 
                              <Location>City centre</Location>
 
                              <Desc>This 5 star hotel is located in the city centre of St Petersburg
 
                                    and was established in 2011. It is close to the St.Isaac's Cathedral
 
                                    and the nearest station is Admiralteyskaya station. The Hotel has
 
                                    a restaurant, 2 bars, a conference room, a coffee shop, an indoor
 
                                    swimming pool and a fitness centre/gym. All 137 rooms are equipped
 
                                    with minibar, hairdryer, safe, trouser press and air conditioning.</Desc>
 
                              <Address>6 Voznesensky Prospect, St. Petersburg, 190000, St Petersburg, Russia</Address>
 
                          </Info>
 
                        </Data>
 
                        <Phones/>
 
                        <Fax>+7 812 6106160</Fax>
 
                        <Images>
 
                          <Image>
 
                              <Path>https://www.miki.co.uk/live/hotel/mikiNet/image/v1.0/RU/44018/406/lr/ext.jpg</Path>
 
                              <Icon>https://www.miki.co.uk/live/hotel/mikiNet/image/v1.0/RU/44018/406/ext-t.jpg</Icon>
 
                          </Image>
 
                          <Image>
 
                              <Path>https://www.miki.co.uk/live/hotel/mikiNet/image/v1.0/RU/44018/406/lr/unknown.jpg</Path>
 
                              <Icon>https://www.miki.co.uk/live/hotel/mikiNet/image/v1.0/RU/44018/406/unknown-t.jpg</Icon>
 
                          </Image>
 
                          <Image>
 
                              <Path>https://www.miki.co.uk/live/hotel/mikiNet/image/v1.0/RU/44018/406/lr/bed room.jpg</Path>
 
                              <Icon>https://www.miki.co.uk/live/hotel/mikiNet/image/v1.0/RU/44018/406/bed room-t.jpg</Icon>
 
                          </Image>
 
                        </Images>
 
                    </Hotel>
 
                    ...
 
                  </Hotels>
 
              </HotelStatic>
 
            </Response>
 
        </ResponseBin>
 
      </ns1:hotelsResponse>
 
  </SOAP-ENV:Body>
 
</SOAP-ENV:Envelope>
 
</syntaxhighlight>
 
 
Элемент '''Hotel'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Атрибут Id
 
| Обязательный. Идентификатор отеля в системе Nemo.
 
| Целое число.
 
|-
 
| CityId
 
| Обязательный. Идентификатор города.
 
| Целое число.
 
|-
 
| CountryId
 
| Обязательный. Идентификатор страны .
 
| Целое число.
 
|-
 
| Latitude
 
| Необязательный. Широта.
 
| Вещественное число.
 
|-
 
| Longitude
 
| Необязательный. Долгота.
 
| Вещественное число.
 
|-
 
| Rating
 
| Необязательный. Рейтинг.
 
| Вещественное число.
 
|-
 
| Floors
 
| Необязательный. Количество этажей
 
| Целое число.
 
|-
 
| Data
 
| Необязательный.
 
| Набор элементов Info.
 
|-
 
| Phones
 
| Необязательный. Массив телефонов.
 
| Набор элементов Phone.
 
|-
 
| Fax
 
| Необязательный. Факс.
 
| Строка в произвольном формате.
 
|-
 
| Images
 
| Необязательный. Маcсив изображений.
 
| Набор элементов Image.
 
|}
 
 
Элемент '''Info'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Name
 
| Обязательный. Наименование отеля.
 
| Строка в произвольном формате.
 
|-
 
| Area
 
| Необязательный. Описание места расположения отеля.
 
| Строка в произвольном формате.
 
|-
 
| Location
 
| Необязательный. Район города.
 
| Строка в произвольном формате.
 
|-
 
| Desc
 
| Необязательный. Описание отеля.
 
| Строка в произвольном формате.
 
|-
 
| Address
 
| Необязательный. Адрес отеля.
 
| Строка в произвольном формате.
 
|}
 
 
Элемент '''Phones'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Phone
 
| Обязательный. Телефон.
 
| Строка в произвольном формате.
 
|}
 
 
Элемент '''Image'''
 
{| style="width: 800px" class="wikitable"
 
|-
 
! scope="col" width="200" | Элемент
 
! scope="col" width="300" | Описание
 
! scope="col" width="300" | Допустимые значения
 
|-
 
| Path
 
| Необязательный. Путь к полному изображению.
 
| Строка в произвольном формате.
 
|-
 
| Icon
 
| Необязательный. Путь к миниатюре, иконке.
 
| Строка в произвольном формате.
 
|}
 
</div>
 
</div>
 
 
 
  
 
==API бронирования, аннуляции, войдирования авиабилетов==
 
==API бронирования, аннуляции, войдирования авиабилетов==

Версия 18:31, 24 апреля 2015

!!!СТАТЬЯ В РАЗРАБОТКЕ!!!

Содержание

API Поиска авиабилетов

Это сервис внутри Nemo, который позволяет получить результаты поиска.

Для подключения к веб-службе поиска авиабилетов необходимо открыть доступ нужному пользователю. Это можно сделать в разделе «Администрирование»«Веб-служба. Авторизация».

После добавления пользователя, ему будут присвоены Номер (ClientId) и API ключ клиента, которые нужно использовать для подключения.

Подробнее можно узнать в специальной статье Веб-служба поиска авиабилетов

API Поиска отелей

Агентский API Отелей - система, которая предоставляет возможность поиска и бронирования отелей а так же получение информации о времени и размерах штрафов, уникальной информации об отеле, получение статической информации.

API бронирования, аннуляции, войдирования авиабилетов

Подключение

Получить доступ к результатам бронирования в данном сервисе можно через SOAP клиента. Для получения результата необходим параметр — «FlightId» — Id перелёта, для которого будет производится бронирование. WSDL находится по адресу: http://CLIENT_DOMAIN/nemoflights/wsdl.php?for=BookFlight.

Общий формат запроса / ответа бронирования

развернуть
Запрос
развернуть
Ответ

Пример использования

Пример одностороннего перелета Москва — Мадрид.

развернуть
Запрос
развернуть
Ответ

Общий формат запроса / ответа отмены бронирования

После бронирования, если не истек таймлимит можно аннулировать сделанный заказ. Аннуляция заказа в Nemo может быть ручной (сделанной пользователем) и автоматической — по истечению таймлимита, установленного для заказа система сама аннулирует заказ.

WSDL: http://CLIENT_DOMAIN/nemoflights/wsdl.php?for=CancelBook

развернуть
Запрос
развернуть
Ответ

API бронирования, отмены отелей

Штрафы за аннуляцию

Всегда в явном виде нужно указывать пользователю информацию о штрафах за аннуляцию до бронирования.

Штрафы получаются по каждой услуге отдельным запросом. Нужно указать тип услуги, идентификатор результата поиска и выбранную категорию.

Внимание. Для отелей из Hotelbeds (Supplier=HOTELBEDS) штрафы до бронирования получить невозможно.

WSDL (тестовый сервер): http://tst.nemo-ibe.com/wsdev/wsdl.php?for=Penalty

развернуть
Запрос
развернуть
Ответ


Бронирование

развернуть
Запрос
развернуть
Ответ


Подтверждение бронирования

развернуть
Запрос
развернуть
Ответ


Выгрузка актуальных данных по заказу(ам)

Используется для экспорта бронирований и для обновления данных в локальной клиентской базе.

WSDL (тестовый сервер): http://tst.nemo-ibe.com/wsdev/wsdl.php?for=Export

развернуть
Запрос
развернуть
Ответ


Аннуляция заказа

WSDL (тестовый сервер): http://tst.nemo-ibe.com/wsdev/wsdl.php?for=CancelBooking

развернуть
Запрос
Ответ

см. результаты бронирования.

Выгрузки статистики продаж через API

Метапоисковая система (метапоисковая машина, метапоисковик) — это поисковая система, которая в отличие от классических поисковых машин не имеет собственной базы данных и собственного поискового индекса, а формирует поисковую выдачу за счет смешивания и переранжирования результатов поиска других поисковых систем.

Необходимо убедиться, что API запросы на поиск отправляются на доменное имя, указанное для агентства (субагента) в разделе Администрирование -> Настройки агентства


Запрос

Пример запроса

http://host/index.php?go=settings/download_metasearch_stat&date1=2012-05-01&date2=2012-06-01&partner=aviasales&password=secret

Параметры запроса

Параметр запроса Описание
date1 YYYY-MM-DD дата.
date2 YYYY-MM-DD дата.
partner Идентификатор партнёра - алиас источника переходов модуля метрики.
password Пароль партнёра - пароль источника переходов модуля метрики.
развернуть
Ответ

Время и дата бронирования created_at передается в таймзоне UTC+4.

Состояние брони state может принимать значения:

  • PROCESSING - забронирован;
  • PAID - выписан;
  • CANCELLED - аннулирован (по любым причинам).

Прибыль партнёра profit от данного бронирования в формате 00.99 (через точку). Размер прибыли партнера устанавливается для конкретного источника трафика в Модуле метрики и считается как процент от стоимости оплаченного заказа, включая комиссию платежного шлюза и апсейловые продажи. В последующем расчет прибыли может измениться. При возврате авиабилетов сумма ранее засчитанная как прибыль партнера (метапоисковой системы) должна подставляться с минусом в данном периоде.

Количество детей до 2 лет infants относится только к младенцам без места. Количество младенцев с местом объединяются с количеством детей до 12 лет children.

Выгрузка информации о заказах

Выгрузка заказов — это экспорт данных заказа или заказов для различных компонентов системы Nemo.

Процесс выгрузки

Схематично процесс выгрузки заказов представлен на блок-схеме.

Export.png

Статусы выгрузки заказа

Коды статусов выгрузки заказа соответствуют кодам состояния HTTP. Фактически указывается последний полученный код состояния HTTP, полученный при выгрузке данных по адресу, указанному в настройках выгрузки. Коды относятся к серверу, на который происходит выгрузка заказов.

Код Описание
0 Неизвестный ответ. Адрес для выгрузки не доступен.
200 OK — успешный запрос.
301 Запрошенный документ был окончательно перенесен на новый URI, указанный в поле Location заголовка.
403 Сервер понял запрос, но он отказывается его выполнять из-за ограничений в доступе для клиента к указанному ресурсу.
404 Сервер понял запрос, но не нашёл соответствующего ресурса по указанному URI.
422 Unprocessable Entity — сервер успешно принял запрос, может работать с указанным видом данных, в теле запроса XML-документ имеет верный синтаксис, но имеется какая-то логическая ошибка, из-за которой невозможно произвести операцию над ресурсом.
500 Любая внутренняя ошибка сервера.

Выгрузка заказа для компонента «Авиабилеты»

Для компонента «Авиабилеты» доступна выгрузка заказов в форматах Nemo и/или Софи (при включенном модуле «Выгрузка заказов Софи»).

развернуть

Формат Nemo

развернуть

Формат Софи

Выгрузка заказа для компонента «Отели»

Для компонента «Отели» доступна выгрузка заказов в формате Nemo.

развернуть

Формат Nemo

Выгрузка заказа для компонента «ЖД»

Для компонента «ЖД» доступна выгрузка заказов в формате Nemo.

развернуть

Формат Nemo

Пакетный экспорт заказов по категориям в формате Nemo

Сервис выгрузки заказов позволяет экспортировать интересующие выборки по заказам в формате XML. Например, можно выбрать все заказы по дате бронирования и получить информацию по ним в XML-виде.

Экспорт заказов под авторизованным пользователем (в личном кабинете)

Фильтры пакетного экспорта заказов в личном кабинете

Порядок пользования сервисом:

  1. Перейти в личный кабинет
  2. В адресной строке браузера к текущему адресу дописать параметр &exportxml. Должен получиться адрес вида:
    http://DOMAIN/index.php?go=poffice/table&exportxml
    
  3. После обновления страницы под блоком фильтров должна появиться кнопка «Экспортировать в XML». При ее нажатии на странице появляется предложение сохранить в XML-файл выборку отфильтрованных заказов.

Выгружаются только заказы выбранного пользователя/компании с учетом примененных параметров фильтра.

Пользователь может произвести выгрузку только своих заказов.

Пакетный экспорт заказов по категориям в формате СОФИ

Для использования выгрузки заказов в формате СОФИ у агентства должен быть включен модуль "Выгрузка заказов Софи" и заданы настройки:

  • "Тип выгрузки СОФИ" должен иметь значение "Выгрузка заказов СОФИ" или должна быть включена настройка "Выгрузка одновременно и Nemo, и Софи",
  • Должен быть указан "Url скрипта для выгрузки в формате СОФИ",
  • Должен быть указан "Код сайта в системе СОФИ".

Выгрузка конкретного заказа:

http://DOMAIN/booking__sofi_export_bookings&booking_id=123456
где booking_id — номер заказа в системе Немо.

Выгрузка заказов забронированных за определенный период:

http://DOMAIN/booking__sofi_export_bookings&date_begin=01.01.2014&date_end=01.01.2015
где [date_begin; date_end] — период бронирования заказа (забронированные заказы с датой бронирования совпадающей с началом/окончанием периода, заданного в запросе, попадают в экспорт), формат — дд.мм.гггг.

Фиксация оплаты внешним запросом

!!! не нашел, есть просто фиксация оплаты, но это вроде немного не то !!!

API универсального платежного шлюза

!!! сказано спросить у КШ, я спросил, у него нет информации !!!

API Синхронизации пользователей и субагентов

Назначение данного модуля — обеспечение взаимодействия между сторонней программой (например, системой автоматизации туроператора "САМО-тур") и Nemo в части синхронизации списка B2B-пользователей.

Модуль является компонентом, включаемым и отключаемым из административной части.

Авторизация B2B-пользователей

Все B2B-пользователи, загруженные через модуль взаимодействия со сторонней программой, будут иметь случайным образом сгенерированный криптостойкий пароль. Механизм авторизации работает следующим образом:

1.Система пытается авторизовать пользователя через собственную службу авторизации. 2.В случае неудачи, но присутствия в системе введенного логина, она должна попытаться авторизовать пользователя во внешней службе авторизации («САМО-тур»), при включенном компоненте взаимодействия с «САМО-тур». 3.В случае неудачного опознавания пользователя выводится соответствующее сообщение и процедура может быть повторена путем повторного ввода логина и пароля.

Регистрация неудачных попыток входа производится только в двух случаях:

  • Компонент взаимодействия выключен.
  • Компонент взаимодействия включен и провалены обе попытки авторизации (внутренней и внешней).

Для сторонней авторизации пользователей в системе Nemo внешняя программа должна иметь веб-службу, основанную на WSDL определенного формата. Ссылка на веб-службу прописывается в настройках системы Nemo на странице конфигурации интеграции с внешней системой.

Для импортированных пользователей в Nemo имеется поле «Идентификатор внешней системы», который отвечает за сопоставление с ID пользователя в сторонней системе. Для менеджеров агентств оно равно номеру партнера (агента) во внешней системе, для пользователей — номеру пользователя в «САМО-туре».

Для пользователей, имеющих какое-либо значение в поле «идентификатор во внешней системе», запрещен функционал смены пароля или его восстановления по электронной почте.

Пример запросов и ответов на авторизацию:

Request

<?xml version="1.0" encoding="utf-8"?>
<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"
 xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">
  <soap12:Body>
    <getAuthorization xmlns="http://tempuri.org/">
      <login>string</login>
      <pass>string</pass>
    </getAuthorization>
  </soap12:Body>
</soap12:Envelope>

Response

<?xml version="1.0" encoding="utf-8"?>
<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">
  <soap12:Body>
    <getAuthorizationResponse xmlns="http://tempuri.org/">
      <getAuthorizationResult>
        <session_id>string</session_id>
        <user_id>string</user_id>
        <login>string</login>
        <status>string</status>
      </getAuthorizationResult>
    </getAuthorizationResponse>
  </soap12:Body>
</soap12:Envelope>

Сервис реализует функцию «getAuthorization», на вход которой передается конструкция «getAuthorizationRequest»:

  • login (строка) - введенный пользователем логин
  • pass (строка) - введенный пользователем пароль

Функция должна отдавать системе конструкцию getAuthorizationResponse:

  • session_id (строка) - пустое значение
  • user_id (строка) - идентификатор менеджера в системе «САМО-тур»
  • login (строка) - логин пользователя (для контроля)
  • status (строка) - может иметь значения:

1. adm - администратор 2. mgr - менеджер 3. usr - пользователь (возвращается всегда это значение)

Импорт и синхронизация учетных записей

Со стороны внешней системы должно быть приложение, отправляющее в формате XML данные по учетным записям B2B-клиентов (агентств и пользователей). Со стороны Nemo имеется скрипт, который принимает XML в формате, приведенном в описании документов, передаваемых в Nemo, с ключом авторизации, определенным в Nemo в административной части модуля.

Передаваемые элементы с описанием учетных записей и партнеров имеют аккаунт (Account ID) во внешней системе и атрибут action, который может быть в состоянии update или delete, т.е. обновления/добавления и удаления, соответственно.

В административной части модуля в Nemo задается ключ авторизации для защиты от несанкционированного доступа. Значение не должно быть пустым.

Скрипт получает данные об обновлении и добавлении (проходят как одно и то же действие) или удалении информации по аккаунту. XML-данные могут содержать несколько элементов.

Описание передаваемых в Nemo XML-документов:

<?xml version="1.0" encoding="UTF-8" ?>
<changes key="ключ_авторизации">
    <accounts> - список изменений по аккаунтам пользователей
        <item id=3 partnerId=10 action="update" admin="1">
            <login>Логин пользователя</login>
        </item>
        <item id=6 partnerId=15 action="update">
            ...
        </item>
        <item id=9 partnerId=30 action="delete" />
    </accounts>
    <partners> - список изменений по партнерам
        <item id=140 action="update">
            <name>Название агентства</name>
            <ofname>Официальное Название агентства</ofname>
            <phone>Телефон</phone>
            <tax>Форма налогообложения</tax>
            <group>123</group>
            <code>ABCD</item>
  </partners></changes></code>

При импорте информации об агентствах будут возвращаться следующие значения:

Поле во внешней системе Путь к элементу xml Тип данных Сопоставляемое поле в Nemo Примечание
Идентификатор партнера/changes/partners/item[@id]Целое число Идентификатор во внешней системе для менеджера / администратора
Название юридического лица/changes/partners/item/ofnameСтрокаПолное официальное название юридического лица Необходимо для выписки счетов юридическими лицами
Сокращенное название/changes/partners/item/nameСтрокаИмя агентства
Код агентства/changes/partners/item/codeСтрокаИспользуется при создании логина администратора
Номер группы в самотуре/changes/partners/item/groupЦелое число, либо пустоНа основании таблицы сопоставлений (см. ниже) определяется, к какой группе агентство принадлежит в Nemo
Форма налогообложения/changes/partners/item/taxЦелое число, равное идентификатору во внешней системе

Для каждого возвращенного агентства Nemo проверяет наличие его в своей базе. Если агентство не найдено, то создается новое, для него создается менеджер (админ) с логином ABCD-1234, где ABCD – буквенный идентификатор партнера во внешней системе, 1234 — id партнера во внешней системе. Пароль генерируется случайный и криптостойкий.

Если агентство найдено, то в случае необходимости производится обновление всех полей на основании данных из внешней системы. Если изменился буквенный код агентства, то Nemo переименовывает менеджера в соответствии с новым кодом. При импорте информации о пользователях агентств в Nemo будут посылаться следующие поля:

Поле во внешней системеПуть к элементу xmlТип данныхСопоставляемое поле в NemoПримечание
Идентификатор пользователя/changes/accounts/item[@id]Целое числоИдентификатор внешней системыХраним как дополнительное поле
Идентификатор партнера/changes/accounts/item[@partnerId]Целое числоИдентификатор внешней системы менеджера агентства
Логин/changes/accounts/item/loginСтрокаЛогин пользователя
Администратор/changes/accounts/item[@admin]0 - нет, 1 - даЭксперт по бронированию

Для каждого возвращенного пользователя Nemo проверяет наличие его в своей базе. Если пользователь не найден, то создается новый. Пароль генерируется случайный и криптостойкий.

Если пользователь найден, то в случае необходимости производится обновление всех полей на основании данных из внешней системы. При запросе на удаление пользователя, в Nemo указанный логин удаляться не будет в целях сохранения целостности старых данных, а просто помечается как удаленный, и логин переименовывается и становится вида [логин_пользователя]_X_[числовой идентификатор_пользователя в Само].

<item id=[идентификатор] action="delete" />

Таблица сопоставлений групп

В административной части Nemo надо создать отдельную страницу, на которой можно сопоставить имеющиеся группы в Nemo номерам групп в САМО-тур (поле group в XML). Выводится список существующих групп для текущего (корневого) агентства.

API Кросс­авторизации

Система Nemo позволяет обращаться к ней как базе пользователей для авторизации из других систем (например форума на сайте, собственного ПО компании и т.п)

Для этого нужно подключиться к веб-службе авторизации, WSDL-описание которой располагается по адресу:

http://hostname/authorization_reol.wsdl

развернуть
Запрос


Передача параметров в форму поиска

Описанная функциональность не входит в стандартную поставку системы.

Для получения возможности использовать ее, пожалуйста, обратитесь в коммерческий отдел.

В системе Nemo имеется возможность перенаправлять пользователей на страницу с уже заполненными параметрами поиска или сразу напрямую на результаты поиска.

Применение

Эта технология может использоватся к примеру для формирования ссылок с баннеров, при клике на которые пользователь попадает на форму, на которой уже могут быть заполнены пункты назначения, даты, количество пассажиров и прочие параметры.

Также, при указании всех необходимых параметров, пользователя можно перебрасывать сразу на процесс поиска авиабилетов с указанными критериями.

Для использования заполнения формы из URL следует включить опцию: АдминистрированиеНастройки системыВключить FastSearch (передачу параметров поиска)

После этого можно использовать ссылки на форму поиска вида

http://SITEMANE/?trip_type=OW&out_iata=MOW&in_iata=BER&departure_date=21.10.2009&adults=1&children=0&input_vendors=SU,PS&param_by_get=on

Переменные FastSearch

Имена полей - такие же как имена инпутов на поисковой форме.

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

Переменные, которые предполагают в качестве значения "true" можно просто не включать в запрос, чтобы их логика не отработала.

Форма поиска

Чтобы перенаправить пользователя на страницу с заполненными параметрами поиска, необходимо указать get-параметр &param_by_get=on, иначе сработают стандартные предустановки полей формы поиска.

Процесс поиска

Если вы указываете все необходимые для поиска параметры, то для того чтобы отправить пользователя сразу на результаты поиска, нужно указать get-параметр &fast_search=on.

Маршрут «В одну сторону» и «Туда и обратно»

Элемент Переменная Допустимые значения
Тип маршрута trip_type
OW В одну сторону
RT Туда и обратно
CR Сложный маршрут
Пункт вылета out_iata
MOW Код аэропорта ИАТА
Пункт прилета in_iata
LED Код аэропорта ИАТА
Дата вылета departure_date
25.10.2013 Дата в формате ДД.ММ.ГГГГ
Дата обратного вылета back_departure_date
27.10.2013 Дата в формате ДД.ММ.ГГГГ
Время вылета prefered_departure_type
not_important Любое время
morning Утром
afternoon Днем
evening Вечером
night Ночью
Время обратного вылета prefered_back_departure_type
not_important Любое время
morning Утром
afternoon Днем
evening Вечером
night Ночью
Поиск только среди прямых рейсов ("Без пересадок") direct true
Дополнительные параметры
Элемент Переменная Допустимые значения
Нижнее ограничение по цене по умолчанию money_from
0 Целое число большее либо равное 0
Верхнее ограничение по цене по умолчанию money_to
10000 Целое число большее 0
Поиск в окружных датах district_date true
Диапазон соседних дат +(-) [дней] date_range
1 Целое число большее [1..3]
Поиск по соседним аэропортам district_airport true
Класс обслуживания class
econom Перелет эконом-классом
business Перелет бизнес-классом
first Перелет первым-классом
Фильтр по авиакомпании input_vendors
SU,PS Коды авиакомпании ИАТА через запятую без пробелов
Сортировка sort
price По стоимости
out_date По расписанию
company По авиакомпании
fltduration По длительности перелёта

Сложный маршрут

 Данные переменные применимы только для сложного маршрута (trip_type=CR).

[X] - номера отдельных перелетов. Нумерация начинается с 0, что означает первый перелет.

Максимальное количество сегментов для сложного маршрута определяется одноименной настройкой в разделе Авиабилеты ⇨ Поиск ⇨ Ограничения поиска.

Элемент Переменная Допустимые значения
Пункты вылета cr_iata[0]

cr_iata[1]
...
cr_iata[8]

MOW Код аэропорта ИАТА
Пункты прилета cr_back_iata[0]

cr_back_iata[1]
...
cr_back_iata[8]

LED Код аэропорта ИАТА
Дата вылета cr_date[0]

cr_date[1]
...
cr_date[8]

25.10.2013 Дата в формате ДД.ММ.ГГГГ
Время вылета cr_pref_departure[0]

cr_pref_departure[1]
...
cr_pref_departure[8]

not_important Любое время
morning Утром
afternoon Днем
evening Вечером
night Ночью
Класс обслуживания cr_class[0]

cr_class[1]
...
cr_class[8]

econom Перелет эконом-классом
business Перелет бизнес-классом
first Перелет первым классом
Окружные аэропорты (±XX км) cr_district_airport[0]

cr_district_airport[1]
...
cr_district_airport[8]

true

Пассажиры

Элемент Переменная Допустимые значения
Взрослых от 12 лет adults
1 Целое число большее либо равное 0
Детей от 2 до 12 лет children
1 Целое число большее либо равное 0
Младенцев до 2 лет infants
1 Целое число большее либо равное 0
Младенцев с местом до 2 лет infants_seat
1 Целое число большее либо равное 0
Молодых от 12 до 24 лет
youths
1 Целое число большее либо равное 0

 Данный параметр доступен только в новой базовой теме.

Пожилых от 65 лет seniors
1 Целое число большее либо равное 0

 Данный параметр доступен только в новой базовой теме.

Примеры FastSearch запросов

развернуть

В одну сторону (простой)

развернуть

В одну сторону (с фильтрами по авиакомпаниям)

развернуть

Туда-обратно

развернуть

Сложный маршрут

Взаимодействие FastSearch и Метрики

Для того, чтобы переход был зарегистрирован системой как переход с определенного источника, необходимо передать в запросе дополнительный параметр utm_source (Metrics Session ID). Например:

http://SITEMANE/?(some_parameters=vals&)utm_source=source_alias

где source_alias - алиас источника переходов. Дополнительная информация по использованию модуля Метрики.

Пример FastSearch запроса с параметром для модуля Метрики

развернуть

FastSearch (с учетом источника перехода для модуля Метрики)

Проверка в сторонней системе возможности тикетинга

При выписки билета через стороннюю систему 1С, отправляется запрос "GetDebtCounterparty", который спрашивает, можно ли с счета в 1С списать средства для оплаты. В ответе содержится заключение от 1С, в случае если ошибок нет, в ответе будет

<m:Opportunity>Да</m:Opportunity>

Пример запроса "GetDebtCounterparty"

<?xml version="1.0" encoding="UTF-8"?>

  <SOAP-ENV:Body>
    <ns1:GetDebtCounterparty>
      <ns1:ExternalUserId>00000001</ns1:ExternalUserId>
      <ns1:ExternalPaymentId>00000001</ns1:ExternalPaymentId>
      <ns1:BaseFare>2490</ns1:BaseFare>
      <ns1:Tax>643</ns1:Tax>
      <ns1:ValVendorCommission>49.8</ns1:ValVendorCommission>
      <ns1:Locator>0X97T6</ns1:Locator>
      <ns1:Discount>0</ns1:Discount>
      <ns1:Charge>0</ns1:Charge>
      <ns1:Sum>3133</ns1:Sum>
      <ns1:TotalPrice>3658.1</ns1:TotalPrice>
      <ns1:GDSCurrency>RUB</ns1:GDSCurrency>
      <ns1:OrderCurrency>RUB</ns1:OrderCurrency>
      <ns1:OrderCurrencyRate>1</ns1:OrderCurrencyRate>
      <ns1:beginDate>2014-08-30T11:05:00</ns1:beginDate>
    </ns1:GetDebtCounterparty>
  </SOAP-ENV:Body>
</SOAP-ENV:Envelope>

Пример ответа "GetDebtCounterparty"

<?xml version="1.0"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
  <soap:Header/>
  <soap:Body>
    <m:GetDebtCounterpartyResponse xmlns:m="http://DOMEN_NAME/avia">
      <m:return xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="m:AnswerDebt">
        <m:Opportunity>Да</m:Opportunity>
        <m:Message1/>
      </m:return>
    </m:GetDebtCounterpartyResponse>
  </soap:Body>
</soap:Envelope>

Загрузка счетов из сторонней системы

При взаимодействии с веб-сервисом 1С, на этапе бронирования отправляется запрос, на создание аккаунта 1С, содержащий в себе данные счета. В системе логирования этот запрос можно найти под именем «[GDS] Запрос "NewAccount"» и ответ «[GDS] Ответ "NewAccount"»

развернуть

Пример запроса

развернуть

Пример ответа