Веб-служба бронирования

Материал из Центр поддержки системы бронировании
Перейти к навигации Перейти к поиску

Подключение

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

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

Запрос

  1 <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ver="http://CLIENT_DOMAIN/nemoflights/?version%3D1.0%26for%3DBookFlight">
  2    <soapenv:Header/>
  3    <soapenv:Body>
  4       <ver:BookFlight>
  5          <RequestBin>
  6             <Request>
  7                <BookFlight>
  8                   <FlightId>?</FlightId>
  9                   <!--FlightId — Id перелёта в системе Nemo-->
 10                   <!--Optional:-->
 11                   <CurrencyCode>?</CurrencyCode> <!--необязательный-->
 12                   <!--CurrencyCode — код валюты-->
 13                   <!--Optional:-->
 14                   <Agency Name="?"> <!--необязательный-->
 15                   <!--Name — название агентства-->
 16                      <Telephone Type="?">
 17                      <!--Type — тип номера, обязательный, возможные значения: 
 18                       M — мобильный, H — домашний, B — рабочий, A — агенство-->
 19                         <!--Optional:-->
 20                         <PhoneNumber>?</PhoneNumber>
 21                         <!--PhoneNumber — номер телефона-->
 22                         <!--Optional:-->
 23                         <CountryAccessCode>?</CountryAccessCode> <!--необязательный-->
 24                         <!--CountryAccessCode — код страны-->
 25                         <!--Optional:-->
 26                         <AreaCityCode>?</AreaCityCode> <!--необязательный-->
 27                         <!--AreaCityCode — код региона/города-->
 28                      </Telephone>
 29                      <Address City="?" State="?" StreetAddress="?" PostalCode="?" CountryCode="?"/> <!--необязательный-->
 30                      <!--City — город-->
 31 		     <!--State — штат-->
 32 		     <!--StreetAddress — адрес в городе (улица, дом, корпус, офис и т.д.)-->
 33 		     <!--PostalCode — почтовый индекс-->
 34 		     <!--CountryCode — код страны (RU, UA и т.п.)-->
 35 		  </Agency>
 36                   <Travellers>
 37                      <!--Zero or more repetitions:-->
 38                      <Traveller Type="?" IsContact="?" LinkedTo="?" Num="?" TravellerId="?">
 39                      <!--Type — тип пассажира, обязательный, возможные значения: ADT — взрослые,
 40                       CLD — дети со взрослыми,UNN — дети без сопровождения взрослых, INF — младенцы, INS — младенцы с местом-->
 41 		     <!--IsContact — если true — то данный пассажир является контактным лицом, если false — то не является,
 42 		      контактное лицо может быть только 1, если среди пассажиров есть взрослые, то только кто-то из них 
 43                       может быть контактным лицом, по умолчанию false-->
 44 		     <!--Num — порядковый номер пассажира, начинается с 1-->
 45                      <!--LinkedTo — номер взрослого, к которому привязан младенец/ребёнок (привязка ребёнка ко взрослому является опциональной)--> <!--необязательный-->
 46                      <!--TravellerId — устаревший параметр, не используется-->
 47                         <Meal>?</Meal> <!--необязательный-->
 48                         <!--Meal — код типа питания, возможные значения:
 49 						AVML — Азиатская вегетарианская кухня
 50 						BLML — Блюда щадящей диеты
 51 						CHML — Детское питание
 52 						CHPC — Детский холодный завтрак
 53 						СНСС — Детский горячий завтрак
 54 						CHHC — Детский ланч, ветчина и сыр
 55 						PBJS — Детский ланч, ореховое масло
 56 						CHMC — Детский обед макароны с сыром
 57 						DBML — Диабетическое питание
 58 						FPML — Фрукты
 59 						GFML — Питание без клейковины
 60 						HFML — Питание богатое клетчаткой
 61 						HNML — Индусская кухня
 62 						BBML — Питание для младенцев
 63 						KSML — Кошерная кухня
 64 						SMKB — Кошерный завтрак
 65 						SMKL — Кошерный ланч
 66 						SMKD — Кошерный обед
 67 						LPML — Малобелковое питание
 68 						LCML — Низкокалорийное питание
 69 						LFML — Низкохолестериновое питание
 70 						PRML — Низкопуриновое питание
 71 						LSML — Малосоленое питание
 72 						MOML — Мюсли
 73 						NLML — Безмолочные продукты
 74 						ORML — Восточная кухня
 75 						RVML — Сырые овощи
 76 						SFML — Морепродукты
 77 						SPML — Особое питание
 78 						VLML — Вегетарианское, молоко и яйца
 79 						VGML — Строго вегетарианское питание
 80 						VJML — Джайнизское вегетарианское
 81 						VOML — Восточное вегетарианское питание-->
 82                         <PersonalInfo DateOfBirth="?" Nationality="?" Gender="?">
 83                         <!--DateOfBirth — дата рождения в формате ДД.ММ.ГГГГ (например 31.12.2000)-->
 84 			<!--Nationality — гражданство, двух буквенный код страны (RU, UA, US и т.д.)-->
 85 			<!--Gender — пол пассажира, возможные значения: M — мужской(Male), F — женский(Female)-->
 86                            <FirstName>?</FirstName>
 87                            <!--FirstName — имя пассажира-->
 88                            <LastName>?</LastName>
 89                            <!--LastName — фамилия пассажира-->
 90                            <!--Optional:-->
 91                            <MiddleName>?</MiddleName> <!--необязательный-->
 92                            <!--MiddleName — отчество пассажира-->
 93                         </PersonalInfo>
 94                         <LoyaltyCard OpCode="?" Number="?"/> <!--необязательный-->
 95                         <!--OpCode — код авиакомпании-->
 96 			<!--Number — номер карточки-->
 97                         <ContactInfo> <!--необязательный-->
 98                            <!--Optional:-->
 99                            <EmailID>?</EmailID>
100                            <!--EmailID — контактный email-->
101                            <!--Optional:-->
102                            <Telephone Type="?">
103                            <!--Type — тип номера, возможные значения: M — мобильный, H — домашний, B — рабочий-->
104                               <!--Optional:-->
105                               <PhoneNumber>?</PhoneNumber>
106                               <!--PhoneNumber — номер телефона-->
107                               <!--Optional:-->
108                               <CountryAccessCode>?</CountryAccessCode>
109                               <!--CountryAccessCode — код страны-->
110                               <!--Optional:-->
111                               <AreaCityCode>?</AreaCityCode>
112                               <!--AreaCityCode — код региона/города-->
113                            </Telephone>
114                         </ContactInfo>
115                         <DocumentInfo DocType="?" DocNum="?" CountryCode="?" DocElapsedTime="?"/>
116                         <!--DocType — тип документа, возможные значения:
117 								Р — Паспорт
118 								A – Паспорт иностранца
119 								С — Внутренний гражданский паспорт
120 								F – Документ заменяющий паспорт
121 								М — Воинское удостоверение
122 								N – Сертификат натурализации(специфичный документ США)
123 								T – Док.повторного въезда, паспорт беженца
124 								V – Документ для пересечения границы
125                                                                  F – Свидетельство о рождении (для ГРС Сирена Трэвел, для 
126                                                                  других гдс рекомендуется использовать тип документа P)-->
127 			<!--DocNum — номер документа-->
128 			<!--CountryCode — двух буквенный код страны выдачи паспорта (RU, UA, US и т.д.)-->
129 			<!--DocElapsedTime — срок истечения срока действия паспорта в ДД.ММ.ГГГ (например 31.12.2000)-->
130                         <VisaInfo Num="?" IssueCountry="?" IssuePlace="?" BirthCountry="?" BirthCity="?" IssueDate="?"/> 
131                         <!--необязательный-->
132                         <!--Num — номер визы-->
133                         <!--IssueDate — дата(ДД.ММ.ГГГГ) выдачи визы-->
134                         <!--IssueCountry — страна выдачи визы-->
135                         <!--IssuePlace — место выдачи визы-->
136                         <!--BirthCountry — страна рождения(IATA код страны)-->
137                         <!--BirthCity — город рождения(название)-->
138                         <ArrAddress City="?" State="?" StreetAddress="?" PostalCode="?" CountryCode="?"/> <!--необязательный-->
139                         <!--City — город-->
140 			<!--State — штат или область въезда-->
141 			<!--StreetAddress — адрес: улица, номер дома, квартиры и т.д.-->
142 			<!--PostalCode — почтовый код-->
143 			<!--CountryCode — код страны-->
144                        </Traveller>
145                   </Travellers>
146                   <!--Optional:-->
147                   <DeviceId> <!--необязательный-->
148                      <Type>?</Type>
149                      <!--Type — Тип мобильного устройства (apple/android)-->
150                      <Token>?</Token>
151                      <!--Token — Токен мобильного устройства-->
152                   </DeviceId>
153                 </BookFlight>
154             </Request>
155             <Source>
156                <ClientId>?</ClientId>
157                <!--ClientId — ID клиента в системе Nemo. Можно посмотреть/добавить в разделе 
158                 "Администрирование" ? "Веб-служба. Авторизация".-->
159                <APIKey>?</APIKey>
160                <!--APIKey — секретный ключ доступа к API Nemo. Можно посмотреть/добавить в разделе 
161                 "Администрирование" ? "Веб-служба. Авторизация".-->
162                <Language>?</Language>
163                <!--Language — язык-->
164                <Currency>?</Currency>
165                <!-- CUrrency — валюта-->
166                <EndUserData>
167                   <!--Блок с данными о конечном пользователе, необязательный, но необходим при при использовании запросов поиска и бронирования для поставщика TravelFusion-->
168                   <EndUserIP>123.123.123.123</EndUserIP>
169                   <!--IP адрес пользователя-->
170                   <EndUserBrowserAgent>firefox</EndUserBrowserAgent>
171                   <!--Браузер пользователя-->
172                   <RequestOrigin>Russia-nemo.travel</RequestOrigin>
173                   <!--Страна и домен, с которого пользователь совершает поиск/бронирование-->
174                </EndUserData>         
175             </Source>
176          </RequestBin>
177       </ver:BookFlight>
178    </soapenv:Body>
179 </soapenv:Envelope>

Ответ

  1 <SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ns1="http://CLIENT_DOMAIN/nemoflights/?version%3D1.0%26for%3DBookFlight" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  2    <SOAP-ENV:Body>
  3       <ns1:BookFlightResponse>
  4          <ResponseBin>
  5             <Response>
  6                <BookFlight ID="?" Status="?" Code="?">
  7                <!--ID — Id брони в системе Nemo, целое число, обязательный-->
  8 	       <!--Status — индикатор состояния брони, возможные значения:
  9 						booked — забронировано,
 10 						canceled — бронь отменена,
 11  						ticket — выписана
 12 						UNDEFINED — статус не определён-->
 13 	       <!--Code — код брони в системе поставщика-->
 14                   <QueryPlace xsi:nil="true"/>
 15                   <!--QueryPlace — положение брони в очереди, Number — номер брони в очереди-->
 16                   <Flight FlightId="?">
 17                   <!--FlightId — Id перелёта в системе Nemo-->
 18                      <WebService>?</WebService>
 19                      <!--WebService — поставщик перелёта-->
 20                      <ValCompany>?</ValCompany>
 21                      <!--ValCompany — код авиакомпании, являющейся валидирующим перевозчиком, IATA-->
 22                      <URL>?</URL>
 23                      <!--URL — ссылка на бронирование конкретного перелета-->
 24                      <Segments>
 25                         <Segment SegNum="?" SegGroupNum="?">
 26                         <!--SegNum — номер сегмента в перелёте-->
 27 		        <!--SegGroupNum – номер плеча перелёта-->
 28                            <SupplierCode>?</SupplierCode>
 29                            <!--SupplierCode – номер заказа в системе АК--> 
 30                            <DepAirp CodeType="IATA">?</DepAirp>
 31                            <!--DepAirp — аэропорт отправления, например: MOW — любой аэропорт в г.Москва 
 32                             или SVO — Шереметьево-->
 33                            <DepTerminal>?</DepTerminal>
 34                            <!--DepTerminal — терминал пункта отправления, если пустое значение, 
 35                             то в аэропорту всего 1 терминал-->
 36                            <ArrAirp CodeType="IATA">?</ArrAirp>
 37                            <!--ArrAirp — аэропорт прибытия-->
 38                            <ArrTerminal>?</ArrTerminal>
 39                            <!--ArrTerminal — терминал пункта прибытия, если пустое значение, 
 40                             то в аэропорту всего 1 терминал-->
 41                            <OpAirline>?</OpAirline>
 42                            <!--OpAirline — авиакомпания перевозчик, например: SU — Аэрофлот-->
 43                            <MarkAirline>?</MarkAirline>
 44                            <!--MarkAirline — авиакомпания, продающая перелёт-->
 45                            <FlightNumber>?</FlightNumber>
 46                            <!--FlightNumber — номер рейса-->
 47                            <AircraftType>?</AircraftType>
 48                            <!--AircraftType — тип воздушного судна, код-->
 49                            <DepDateTime>?</DepDateTime>
 50                            <!--DepDateTime — дата и время отправления, формат ГГГГ-MM-ДДTЧЧ:ММ:СС-->
 51                            <ArrDateTime>?</ArrDateTime>
 52                            <!--ArrDateTime — дата и время прибытия, формат ГГГГ-MM-ДДTЧЧ:ММ:СС-->
 53                            <StopNum>?</StopNum>
 54                            <!--StopNum — количество остановок-->
 55                            <BookingCodes>
 56                               <BookingCode ClassType="?">
 57                               <!--ClassType — класс перелета, например: economy-->
 58                                  <BookingCode>?</BookingCode>
 59                                  <!--BookingCode — код класса бронирования, у разных авиакомпаний один и тот же класс 
 60                                   может записываться разными литерами, например: L-->
 61                               </BookingCode>
 62                            </BookingCodes>
 63                            <FlightTime>?</FlightTime>
 64                            <!--FlightTime — время перелёта в минутах-->
 65                            <TimeZone Departure="?" Arrival="?"/>
 66                            <!--Departure временная зона аэропорта отправления-->
 67 			   <!--Arrival — временная зона аэропорта прибытия-->
 68                            <ETicket>?</ETicket>
 69                            <!--ETicket — признак электронного билета, значения: true / false-->
 70                            <isCharter>?</isCharter>
 71                            <!--isCharter — признак чартерного перелета, значения: true / false-->
 72                            <BaggageAllowances>
 73                            <!--BaggageAllowances — информация о багаже-->
 74                               <BaggageAllowance>
 75                                  <PassengerType>?</PassengerType>
 76                                  <!--PassengerType — тип пассажира, соответствует типу тарифа в PricingInfo -->
 77                                  <Value>?</Value>
 78                                  <!--Value — количество-->
 79                                  <Measurement>?</Measurement>
 80                                  <!--Measurement — мера измерения, может принимать значения: kg — килограмм, pc — багажное место, lb — фунт-->
 81                               </BaggageAllowance>
 82                            </BaggageAllowances>
 83                         </Segment>
 84                      </Segments>
 85                      <PricingInfo Refundable="?">
 86                      <!--Refundable — возвратный/невозвратный, true/false. Если пустое, то не известно-->
 87                         <PassengerFare Type="?" Quantity="?">
 88                         <!--Type — тип тарифа-->
 89 		        <!--Quantity — количество пассажиров данного типа-->
 90                            <TravellerRef>
 91                            <!--TravellerRef — Ссылка на пассажиров, к которым относится данный тариф-->
 92                               <Ref>?</Ref>
 93                               <!--Ref — Номера пассажиров, к которым относится данный тариф-->
 94                            </TravellerRef>
 95                            <BaseFare Currency="?" Amount="?"/>
 96                            <!--BaseFare — базовая стоимость, в базовой валюте. Currency — код валюты, Amount — значение цены-->
 97                            <EquiveFare Currency="?" Amount="?"/>
 98                            <!--EquiveFare — базовая стоимость, в эквивалентной валюте(валюте продажи). 
 99                             Currency — код валюты, Amount — значение цены-->
100                            <TotalFare Currency="?" Amount="?"/>
101                            <!--TotalFare — суммарная стоимость, в эквивалентной валюте. 
102                             Currency — код валюты, Amount — значение цены-->
103                            <Taxes>
104                               <Tax CurCode="?" TaxCode="?" Amount="?"/>
105                               <!--CurCode — код валюты, TaxCode — код таксы, Amount — сумма таксы-->
106                            </Taxes>
107                            <Tariffs>
108                               <Tariff Code="?" SegNum="?"/>
109                               <!--Code — код тарифа, SegNum — номер сегмента, к которому применён тариф-->
110                            </Tariffs>
111                            <FareCalc>?</FareCalc>
112                            <!--FareCalc — строка расчёта цены-->
113                            <LastTicketDateTime>?</LastTicketDateTime>
114                            <!--LastTicketDateTime — дата и время таймлимита по выписке в формате ГГГГ-MM-ДДTЧЧ:ММ:СС-->
115                         </PassengerFare>
116                      </PricingInfo>
117                      <Charges Currency="?">?</Charges>
118                      <!--Charges — сборы, Currency — код валюты-->
119                      <TotalPrice Currency="?">?</TotalPrice>
120                      <!--TotalPrice — итоговая цена, Currency — код валюты-->
121                   </Flight>
122                   <Agency Name="?"> 
123                   <!--Name — название агентства-->
124                      <Telephone Type="?">
125                      <!--Type — тип номера, обязательный, возможные значения: 
126                       M — мобильный, H — домашний, B — рабочий, A — агенство-->
127                         <!--Optional:-->
128                         <PhoneNumber>?</PhoneNumber>
129                         <!--PhoneNumber — номер телефона-->
130                         <!--Optional:-->
131                         <CountryAccessCode>?</CountryAccessCode> 
132                         <!--CountryAccessCode — код страны-->
133                         <!--Optional:-->
134                         <AreaCityCode>?</AreaCityCode> 
135                         <!--AreaCityCode — код региона/города-->
136                      </Telephone>
137                      <Address City="?" State="?" StreetAddress="?" PostalCode="?" CountryCode="?"/> 
138                      <!--City — город-->
139 		     <!--State — штат-->
140 		     <!--StreetAddress — адрес в городе (улица, дом, корпус, офис и т.д.)-->
141 		     <!--PostalCode — почтовый индекс-->
142 		     <!--CountryCode — код страны (RU, UA и т.п.)-->
143 		  </Agency>
144                   <ItinReceipts Encoding="?" Format="?">
145                   <!--ItinReceipts — маршрут квитанция, Encoding — кодировка, Format — формат-->
146                   <FareStored xsi:nil="true"/>
147                   <Travellers>
148                      <!--Zero or more repetitions:-->
149                      <Traveller Type="?" IsContact="?" LinkedTo="?" Num="?" TravellerId="?">
150                      <!--Type — тип пассажира, обязательный, возможные значения: ADT — взрослые,
151                       CLD — дети со взрослыми,UNN — дети без сопровождения взрослых, INF — младенцы, INS — младенцы с местом-->
152 		     <!--IsContact — если true — то данный пассажир является контактным лицом, если false — то не является,
153 		      контактное лицо может быть только 1, если среди пассажиров есть взрослые, то только кто-то из них 
154                       может быть контактным лицом, по умолчанию false-->
155 		     <!--Num — порядковый номер пассажира, начинается с 1-->
156                      <!--LinkedTo — номер взрослого, к которому привязан младенец/ребёнок (привязка ребёнка ко взрослому является опциональной)--> 
157                      <!--TravellerId — устаревший параметр, не используется--> 
158                         <Meal>?</Meal> 
159                         <!--Meal — код типа питания, возможные значения:
160 						AVML — Азиатская вегетарианская кухня
161 						BLML — Блюда щадящей диеты
162 						CHML — Детское питание
163 						CHPC — Детский холодный завтрак
164 						СНСС — Детский горячий завтрак
165  						CHHC — Детский ланч, ветчина и сыр
166 						PBJS — Детский ланч, ореховое масло
167 						CHMC — Детский обед макароны с сыром
168 						DBML — Диабетическое питание
169 						FPML — Фрукты
170 						GFML — Питание без клейковины
171 						HFML — Питание богатое клетчаткой
172 						HNML — Индусская кухня
173  						BBML — Питание для младенцев
174 						KSML — Кошерная кухня
175 						SMKB — Кошерный завтрак
176 						SMKL — Кошерный ланч
177 						SMKD — Кошерный обед
178  						LPML — Малобелковое питание
179 						LCML — Низкокалорийное питание
180 						LFML — Низкохолестериновое питание
181 						PRML — Низкопуриновое питание
182 						LSML — Малосоленое питание
183 						MOML — Мюсли
184 						NLML — Безмолочные продукты
185  						ORML — Восточная кухня
186 						RVML — Сырые овощи
187 						SFML — Морепродукты
188 						SPML — Особое питание
189 						VLML — Вегетарианское, молоко и яйца
190 						VGML — Строго вегетарианское питание
191 						VJML — Джайнизское вегетарианское
192  						VOML — Восточное вегетарианское питание-->
193                         <PersonalInfo DateOfBirth="?" Nationality="?" Gender="?">
194                         <!--DateOfBirth — дата рождения в формате ДД.ММ.ГГГГ (например 31.12.2000)-->
195 			<!--Nationality — гражданство, двух буквенный код страны (RU, UA, US и т.д.)-->
196 			<!--Gender — пол пассажира, возможные значения: M — мужской(Male), F — женский(Female)-->
197                            <FirstName>?</FirstName>
198                            <!--FirstName — имя пассажира-->
199                            <LastName>?</LastName>
200                            <!--LastName — фамилия пассажира-->
201                            <!--Optional:-->
202                            <MiddleName>?</MiddleName> 
203                            <!--MiddleName — отчество пассажира-->
204                         </PersonalInfo>
205                         <LoyaltyCard OpCode="?" Number="?"/> 
206                         <!--OpCode — код авиакомпании-->
207 			<!--Number — номер карточки-->
208                         <ContactInfo> 
209                            <!--Optional:-->
210                            <EmailID>?</EmailID>
211                            <!--EmailID — контактный email-->
212                            <!--Optional:-->
213                            <Telephone Type="?">
214                            <!--Type — тип номера, возможные значения: M — мобильный, H — домашний, B — рабочий-->
215                               <!--Optional:-->
216                               <PhoneNumber>?</PhoneNumber>
217                               <!--PhoneNumber — номер телефона-->
218                               <!--Optional:-->
219                               <CountryAccessCode>?</CountryAccessCode>
220                               <!--CountryAccessCode — код страны-->
221                               <!--Optional:-->
222                               <AreaCityCode>?</AreaCityCode>
223                               <!--AreaCityCode — код региона/города-->
224                            </Telephone>
225                         </ContactInfo>
226                         <DocumentInfo DocType="?" DocNum="?" CountryCode="?" DocElapsedTime="?"/>
227                         <!--DocType — тип документа, возможные значения:
228 								Р — Паспорт
229 								A – Паспорт иностранца
230 								С — Внутренний гражданский паспорт
231 								F – Документ заменяющий паспорт
232 								М — Воинское удостоверение
233 								N – Сертификат натурализации(специфичный документ США)
234 								T – Док.повторного въезда, паспорт беженца
235   								V – Документ для пересечения границы-->
236 			<!--DocNum — номер документа-->
237 			<!--CountryCode — двух буквенный код страны выдачи паспорта (RU, UA, US и т.д.)-->
238 			<!--DocElapsedTime — срок истечения срока действия паспорта в ДД.ММ.ГГГ (например 31.12.2000)-->
239                         <VisaInfo Num="?" IssueCountry="?" IssuePlace="?" BirthCountry="?" BirthCity="?" IssueDate="?"/> 
240                         <!--Num — номер визы-->
241                         <!--IssueDate — дата(ДД.ММ.ГГГГ) выдачи визы-->
242                         <!--IssueCountry — страна выдачи визы-->
243                         <!--IssuePlace — место выдачи визы-->
244                         <!--BirthCountry — страна рождения(IATA код страны)-->
245                         <!--BirthCity — город рождения(название)-->
246                         <ArrAddress City="?" State="?" StreetAddress="?" PostalCode="?" CountryCode="?"/> 
247                         <!--City — город-->
248 			<!--State — штат или область въезда-->
249 			<!--StreetAddress — адрес: улица, номер дома, квартиры и т.д.-->
250 			<!--PostalCode — почтовый код-->
251 			<!--CountryCode — код страны-->
252                         <DocStringFormats>
253                            <!--Zero or more repetitions:-->
254                            <DocStringFormat>?</DocStringFormat>
255                            <!--DocStringFormat — формат паспортной строки, возможные значения: 
256                             DOCS — строка формата DOCS, FOID — строка формата FOID-->
257                         </DocStringFormats>
258                      </Traveller>
259                   </Travellers>
260                </BookFlight>
261                <Requisites/>
262                <RequestType xsi:nil="true"/>
263                <UserID xsi:nil="true"/>
264                <Error Code="?">Сообщение об ошибке</Error>
265             </Response>
266          </ResponseBin>
267       </ns1:BookFlightResponse>
268    </SOAP-ENV:Body>
269 </SOAP-ENV:Envelope>

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

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

Запрос

 1 <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ver="http://CLIENT_DOMAIN/nemoflights/?version%3D1.0%26for%3DBookFlight">
 2    <soapenv:Header/>
 3    <soapenv:Body>
 4       <ver:BookFlight>
 5          <RequestBin>
 6             <Request>
 7                <BookFlight>
 8                   <FlightId>171430002</FlightId>
 9                    <Travellers>
10                      <!--Zero or more repetitions:-->
11                      <Traveller Type="ADT" IsContact="true" Num="1">
12                         <PersonalInfo DateOfBirth="20.05.1980" Nationality="RU" Gender="M">
13                            <FirstName>Petr</FirstName>
14                            <LastName>Ivanov</LastName>
15                         </PersonalInfo>
16                         <ContactInfo>
17                            <!--Optional:-->
18                            <EmailID>testmail@mail.ru</EmailID>
19                            <!--Optional:-->
20                            <Telephone Type="M">
21                               <!--Optional:-->
22                               <PhoneNumber>79051234567</PhoneNumber>
23                            </Telephone>
24                         </ContactInfo>
25                         <DocumentInfo DocType="A" DocNum="123456" CountryCode="RU" DocElapsedTime="01.01.2020"/>
26                      </Traveller>
27                   </Travellers>
28                </BookFlight>
29             </Request>
30             <Source>
31                <ClientId>---</ClientId>
32                <APIKey>---</APIKey>
33                <Language>RU</Language>
34                <Currency>RUB</Currency>
35             </Source>
36          </RequestBin>
37       </ver:BookFlight>
38    </soapenv:Body>
39 </soapenv:Envelope>

Ответ

  1 <SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ns1="http://CLIENT_DOMAIN/nemoflights/?version%3D1.0%26for%3DBookFlight" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  2    <SOAP-ENV:Body>
  3       <ns1:BookFlightResponse>
  4          <ResponseBin>
  5             <Response>
  6                <BookFlight ID="262872" Status="booked" Code="LQHZWU">
  7                   <QueryPlace xsi:nil="true"/>
  8                   <Flight FlightId="171430002">
  9                      <WebService>SABRE</WebService>
 10                      <ValCompany>SU</ValCompany>
 11                      <URL>http%3A%2F%2FCLIENT_DOMAIN%2F%3Fgo%3Dbooking%2Finfo%26uid%3D14290%26flight%3D171430002</URL>
 12                      <Segments>
 13                         <Segment SegNum="1" SegGroupNum="0">
 14                            <DepAirp CodeType="IATA">SVO</DepAirp>
 15                            <DepTerminal>D</DepTerminal>
 16                            <ArrAirp CodeType="IATA">BCN</ArrAirp>
 17                            <ArrTerminal>1</ArrTerminal>
 18                            <OpAirline>SU</OpAirline>
 19                            <MarkAirline>SU</MarkAirline>
 20                            <FlightNumber>2512</FlightNumber>
 21                            <AircraftType>321</AircraftType>
 22                            <DepDateTime>2014-03-20T20:40:00</DepDateTime>
 23                            <ArrDateTime>2014-03-20T22:20:00</ArrDateTime>
 24                            <StopNum>0</StopNum>
 25                            <BookingCodes>
 26                               <BookingCode ClassType="economy">
 27                                  <BookingCode>E</BookingCode>
 28                               </BookingCode>
 29                            </BookingCodes>
 30                            <FlightTime>280</FlightTime>
 31                            <TimeZone Departure="4" Arrival="1"/>
 32                            <ETicket>true</ETicket>
 33                         </Segment>
 34                         <Segment SegNum="2" SegGroupNum="0">
 35                            <DepAirp CodeType="IATA">BCN</DepAirp>
 36                            <DepTerminal>1</DepTerminal>
 37                            <ArrAirp CodeType="IATA">MAD</ArrAirp>
 38                            <ArrTerminal>2</ArrTerminal>
 39                            <OpAirline>UX</OpAirline>
 40                            <MarkAirline>SU</MarkAirline>
 41                            <FlightNumber>3403</FlightNumber>
 42                            <AircraftType>738</AircraftType>
 43                            <DepDateTime>2014-03-21T12:05:00</DepDateTime>
 44                            <ArrDateTime>2014-03-21T13:25:00</ArrDateTime>
 45                            <StopNum>0</StopNum>
 46                            <BookingCodes>
 47                               <BookingCode ClassType="economy">
 48                                  <BookingCode>E</BookingCode>
 49                               </BookingCode>
 50                            </BookingCodes>
 51                            <FlightTime>80</FlightTime>
 52                            <TimeZone Departure="1" Arrival="1"/>
 53                            <ETicket>true</ETicket>
 54                         </Segment>
 55                      </Segments>
 56                      <PricingInfo Refundable="false">
 57                         <PassengerFare Type="ADT" Quantity="1">
 58                            <BaseFare Currency="EUR" Amount="165"/>
 59                            <EquiveFare Currency="RUB" Amount="8335"/>
 60                            <TotalFare Currency="RUB" Amount="14025"/>
 61                            <Taxes>
 62                               <Tax CurCode="RUB" TaxCode="YQF" Amount="4242"/>
 63                               <Tax CurCode="RUB" TaxCode="YRI" Amount="374"/>
 64                               <Tax CurCode="RUB" TaxCode="JD" Amount="844"/>
 65                               <Tax CurCode="RUB" TaxCode="QV" Amount="230"/>
 66                            </Taxes>
 67                            <Tariffs/>
 68                            <FareCalc>MOW SU X/BCN SU MAD225.45NUC225.45END ROE0.731857</FareCalc>
 69                            <LastTicketDateTime>2014-03-14T12:45:00</LastTicketDateTime>
 70                         </PassengerFare>
 71                      </PricingInfo>
 72                      <Charges Currency="RUB">140.25</Charges>
 73                      <TotalPrice Currency="RUB">14165.25</TotalPrice>
 74                   </Flight>
 75                   <Agency/>
 76                   <ItinReceipts xsi:nil="true"/>
 77                   <FareStored xsi:nil="true"/>
 78                   <Travellers>
 79                      <Traveller Type="ADT" IsContact="true" Num="1">
 80                         <Meal/>
 81                         <Ticket/>
 82                         <Seats/>
 83                         <PersonalInfo DateOfBirth="20.05.1980" Nationality="RU" Gender="M">
 84                            <FirstName>PETR</FirstName>
 85                            <LastName>IVANOV</LastName>
 86                            <MiddleName/>
 87                         </PersonalInfo>
 88                         <LoyaltyCard/>
 89                         <ContactInfo>
 90                            <EmailID>TESTMAIL@MAIL.ru</EmailID>
 91                            <Telephone Type="M">
 92                               <PhoneNumber>79051234567</PhoneNumber>
 93                               <CountryAccessCode/>
 94                               <AreaCityCode/>
 95                            </Telephone>
 96                         </ContactInfo>
 97                         <DocumentInfo DocType="A" DocNum="123456" CountryCode="RU" DocElapsedTime="01.01.2020"/>
 98                         <VisaInfo/>
 99                         <ArrAddress/>
100                         <PreferedPlace/>
101                         <DocStringFormats/>
102                      </Traveller>
103                   </Travellers>
104                </BookFlight>
105                <Requisites/>
106                <RequestType xsi:nil="true"/>
107                <UserID xsi:nil="true"/>
108                <Errors xsi:nil="true"/>
109             </Response>
110          </ResponseBin>
111       </ns1:BookFlightResponse>
112    </SOAP-ENV:Body>
113 </SOAP-ENV:Envelope>

Ответ с ошибкой

1 <SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ns1="http://release.mlsd.ru/nemoflights/?version%3D1.0%26for%3DBookFlight">
2    <SOAP-ENV:Body>
3       <ns1:BookFlightResponse>
4          <ResponseBin>
5             <Error Code="E001936">Invalid Flight ID</Error>
6          </ResponseBin>
7       </ns1:BookFlightResponse>
8    </SOAP-ENV:Body>
9 </SOAP-ENV:Envelope>

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

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

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

Запрос

 1 <soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ver="http://CLIENT_DOMAIN/nemoflights/?version%3D1.0%26for%3DCancelBook">
 2    <soapenv:Header/>
 3    <soapenv:Body>
 4       <ver:CancelBook>
 5          <RequestBin>
 6             <Request>
 7                <CancelBook BookID="?"/>
 8                <!--BookID — Id брони в системе Nemo, целое число-->
 9             </Request>
10             <Source>
11                <ClientId>?</ClientId>
12                <!--ClientId — ID клиента в системе Nemo. Можно посмотреть/добавить в разделе 
13                 "Администрирование" ? "Веб-служба. Авторизация".-->
14                <APIKey>?</APIKey>
15                <!--APIKey — секретный ключ доступа к API Nemo. Можно посмотреть/добавить в разделе 
16                 "Администрирование" ? "Веб-служба. Авторизация".-->
17                <Language>?</Language>
18                <!--Language — язык-->
19                <Currency>?</Currency>
20                <!-- CUrrency — валюта-->
21             </Source>
22          </RequestBin>
23       </ver:CancelBook>
24    </soapenv:Body>
25 </soapenv:Envelope>

Ответ

 1 <SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ns1="http://CLIENT_DOMAIN/nemoflights/?version%3D1.0%26for%3DCancelBook" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
 2    <SOAP-ENV:Body>
 3       <ns1:CancelBookResponse>
 4          <ResponseBin>
 5             <Response>
 6                <CancelBook BookID="?">
 7                <!--BookID — Id брони в системе Nemo, целое число-->
 8                   <Result Success="?"/>
 9                   <!--Success — результат отмены брони, true или false-->
10                </CancelBook>
11                <Requisites/>
12                <RequestType xsi:nil="true"/>
13                <UserID xsi:nil="true"/>
14                <Error Code="?">Сообщение об ошибке</Error>
15             </Response>
16          </ResponseBin>
17       </ns1:CancelBookResponse>
18    </SOAP-ENV:Body>
19 </SOAP-ENV:Envelope>

См. также