Open Channel API
Details on how to connect your OTA, booking engine or channel manager as a channel on Channex.
Last updated
Details on how to connect your OTA, booking engine or channel manager as a channel on Channex.
Last updated
To connect your platform to Channex we have provided a Push API so you can get real time changes of Availability, Prices and Restrictions and push bookings to Channex. Please see the information below on how to integrate. As always we offer full developer support, just email andrew@channex.io if you have any questions.
We will cover the next key points:
Endpoint to test connection between your side and Channex
Endpoint to expose mapping details from your side to Channex
Endpoint to receive inventory changes from Channex at your side
How to push bookings from your side to Channex
Endpoint to request Full Sync from Channex to your side
To get started you need to sign up to the Channex staging server and create a test property at staging.channex.io
Once you have made your account you just need to make a test property, with some rooms and rates. You can find some help files on creating that here:
At Channex we allow any channel to connect, be assured if you want to be a Channex Channel you will be certified if your technical integration passes all our testing.
You just need to create a test property with some rooms and rates, then create a "Open Channel" so you can self integrate.
If you want to get in touch with us to make sure please send an email to evan@channex.io
Once you have created your test property go to channels and click Add New button
The "Open Channel" is our way to let you self connect as a channel instead of requiring any manual assistance from Channex. It's also flexible allowing you to integrate from any domain or test server before you certify.
Channel: This should be set to "Open Channel"
Group: What property group you want to use, if test account only one should show here
Title: This is just a text description of your connection, either property name or some other text is acceptable and not used apart from the UI
Property: Select you test property you have created
Connection Settings
Endpoint: Enter the endpoint where you will receive our api calls
API Key: Your API key to identify Channex api push. This is also needed when you push bookings back.
Hotel Code: Your hotel code to identify which property on your side. This will be your property ID.
To implement the connection between your service and Channex you should implement several API endpoints, these will provide information about the connected property from your side and / or receive changes that has happened at the property state.
All API endpoints should be placed at same level and should have predefined names: https://your-website.com/api/mapping_details/
At this example, the part written in bold (https://your-website.com/api/), can be custom and we expect to get this value as endpoint in the Open Channel configuration.
mapping_details/
part is predefined by Channex. Endpoint should end with a /
symbol.
As result, we expect to see the next API endpoints:
test_connection
mapping_details
changes
Example:
https://your-website.com/api/mapping_details/
https://your-website.com/api/test_connection/
https://your-website.com/api/changes/
API Endpoints can be protected by an API Key authorisation. If you choose this way, we will use a header with name api-key.
Please check the header for authorisation at your server side to make sure the request comes from Channex
This endpoint will be used to check the connection, using a hotel code which is provided by the user (hotel_code). Channex will send GET request to this endpoint and expect to receive a successful result.
We expect to see GET endpoint protected by API Key authentication. Endpoint should allow a GET argument with hotel_code
Query
Expected Response
Expected Response Status Code: 200 OK
This endpoint will be used to get information about Room Types and Rate Plans from your side. This will allow the user to map in the Channex interface.
We expect to see the GET endpoint protected by API Key authentication. Endpoint should allow a GET argument with a hotel_code
and return room and rate details for mapping.
Query
Expected Response
Expected Response Status Code: 200 OK
room_types
List of room types available at your side for mapping. Should contain id, title and rate_plans
rate_plans
List of rate plans associated with room type available at your side for mapping. Should contain id, title, sell_mode, max_persons, currency, read_only.
sell_mode
Flag to show how room is sell at your side. Can have one of 2 options: per_room or per_person. If rate plan is set as per_room Channex.io will provide updates only for max_persons occupancy. If rate plan is set as per_person channex.io will provide updates for each mapped occupancy (from 1 to max_persons).
max_persons
Max count of guests allowed by rate plan. Integer value greater than 0.
currency
ISO 4217 3-alpha currency code of rate plan.
read_only
If your rate plan does not allow updates, but can be sold at 3rd party side, you can pass it with flag read_only equal to true. In that case, we will allow user to map this rate plan but not provide updates for this rate plan.
Each time Channex catches any changes at the property state associated with Rate Plans or Room Types mapped to your system, we will generate a changes message and send it to changes endpoint at your side via POST request.
Min Stay Requirements
Does your system accept Min Stay Arrival & Min Stay Through? If you only support one please get in touch with us for workaround.
If you support only 1 type of min stay, the final minimum stay field will be "min_stay" instead of arrival or through.
We expect to see the POST endpoint protected by API Key authentication. Query will contain JSON message with changes.
Query:
Expected response:
Where unique_id
is a unique key, which can be used to identify the query at an incident review process.
Changes Notification node contain unique request identifier (UUID v4) represented at field request_id
and changes
list.
Changes can be 2 types:
availability changes
restriction_changes
Availability Changes represented as type availability_changes
and contains information about:
Room Type (room_type_id
at your system)
Date From (date_from
) represented as Date at ISO 8601 (YYYY-MM-DD) format
Date To (date_to
) represented as Date at ISO 8601 (YYYY-MM-DD) format
Availability (availability
) integer value with count of available rooms
Restriction Changes represented as type restriction_changes
and contain information about:
Rate Plan (rate_plan_id
at your system)
Date From (date_from
) represented as Date at ISO 8601 (YYYY-MM-DD
) format
Date To (date_to
) represented as Date at ISO 8601 (YYYY-MM-DD
) format
Stop Sell (stop_sell
) represented as Boolean value
Closed To Arrival (closed_to_arrival
) represented as Boolean value
Closed To Departure (closed_to_departure
) represented as Boolean value
Min Stay Arrival (min_stay_arrival
) represented as positive Integer value
Min Stay Through (min_stay_through
) represented as positive Integer value
Max Stay (max_stay
) represented as non-negative Integer value, where 0 mean restriction is not applicable
Prices (rates
)
If your system does not support both types of minimum stay please work with min_stay_arrival
. And then let us know this limitation when we work with you in production. We will create an extra option for your channel to send the correct min stay the customer uses.
Prices can be represented at different ways depending on your pricing model (sell_mode
).
For Rate Plans with sell_mode
equal to per_room
we will provide prices like the next message:
For Rate Plans with sell_mode
equal to per_person
we will provide prices like the next message:
To provide bookings from your side, you should send a POST request to the endpoint https://secure-staging.channex.io/api/v1/channel_webhooks/open_channel/new_booking signed by API key header:
Our Open Channel use API Key open_channel_api_key
, when you finish your implementation, we will provide API Key specific for your channel connection.
Keep in mind, you should use secure
domain name to push bookings to keep provided credit cards at our PCI Storage.
With next message structure:
status [required]
String. Status of Booking, can be one of three values: new
, modified
, cancelled
.
provider_code [required]
String. Your unique provider_code. Under test, you should use value OpenChannel
.
hotel_code [required]
String. Hotel Code used at Mapping details.
ota_name [optional] String. OTA Unique Code. Full list of codes is here - https://docs.channex.io/api-v.1-documentation/channel-codes. If your system passes bookings from 3rd party OTA, field is required. If your system provides bookings created by your own platform, you can ignore this field.
reservation_id [optional]
String. Booking unique ID. For messages with status new
can be empty, in that case Channex will generate unique UUID for booking. If your system passes bookings from 3rd party OTA, you should provide original reservation ID.
arrival_date [required]
String. Arrival Date represented as string with date in ISO 8601 format by mask YYYY-MM-DD
.
departure_date [required]
String. Departure Date represented as string with date in ISO 8601 format by mask YYYY-MM-DD
.
arrival_hour [optional]
String. Arrival Time represented as string with time in HH:MM
format at 24h.
currency [required]
String. Booking currency code. 3 symbols long string with Currency Alphabetic code based at ISO 4217.
payment_collect [optional]
String. Information about payment collect point. If payment collected via OTA, it should be ota
, in other case it should be property
. Default value is property
.
payment_type [optional]
String. Information about how payment should be collected. Support bank_transfer
or credit_card
. Can be null
if not specified. bank_transfer
value suitable for OTA collect case.
notes [optional]
String. Guest notes or special request.
meta [optional]
Object. Valid JSON object with free-form meta information. This field can be used to pass some additional information about booking.
Information about the Customer (Who made the booking)
name [optional]
String with maximum length of 255 symbols. Name of Customer.
surname [required]
String with maximum length of 255 symbols. Surname of Customer.
country [optional]
String. 2 symbols long string with Country Alpha-2 code based at ISO-3166-1.
city [optional]
String with maximum length of 255 symbols. Customer City name.
address [optional]
String with maximum length of 255 symbols. Customer Address.
zip [optional]
String with maximum length of 32 symbols. Customer ZIP Code.
mail [optional]
String with a valid email address. Customer Email address.
phone [optional]
String with maximum length of 32 symbols. Can contain digits, spaces, brackets and special characters. Customer Phone number.
Please if possible pass in friendly format with country code like this example: +447749617211
This can be simple for the property to contact the guest.
language [optional]
String. 2 symbols long string with language locale code.
company [optional]
Object with information about Customer Company (if customer is Business). Can contain next fields:
title [optional]
String with maximum length of 255 symbols.
number [optional]
String with maximum length of 255 symbols. Tax Number.
number_type [optional]
String with maximum length of 255 symbols. Tax Name (eg: VAT)
meta [optional]
Object without any specific structure where you can pass any additional information about Customer.
Information about the Credit Card.
If you'd like to pass information about the credit card you must use secure-staging.channex.io
or secure.channex.io
(for production environment) endpoints. Otherwise the credit card will be masked without ability to restore the original card.
expiration_date [required]
String with Card Expiration date in MM/YYYY
format.
cvv [required]
String with 3 or 4 numbers. Service code for payment systems.
cardholder_name [required]
String. Cardholder name from Card front.
card_type [required]
String. Card type name.
card_number [required]
String. Card number.
meta [optional]
Object. Can contain any additional information for booking recipient. Also, if you work with Virtual Credit Cards, you can use next fields:
virtual_card_currency_code Currency of virtual card
virtual_card_current_balance Current balance of virtual card as Integer value
virtual_card_decimal_places Info about decimal places at provided current_balance field
virtual_card_effective_date Date when card will be available to charge
virtual_card_expiration_date Date when card is expired
Booking rooms should be passed as Array of Objects. Each room object should contain information about room_type_code
, occupancy
, and days breakdown.
index [optional]
Integer. Room Index to associate Services at Room level. Incremented value, start from 0.
room_type_code [required]
String. Code of Room Type received at Get Rooms List operation.
occupancy [required]
Object with information about occupancy. Should contain next fields:
adults [required]
Integer. Count of adults (persons older then 16 years old)
children [required]
Integer. Count of children (persons between 2 and 16 years old)
infants [required]
Integer. Count of infants (persons younger then 2 years old)
guests [optional]
Array with objects. Information about guest names.
days [required]
Array with objects. Information about daily prices and rate plans. Keep in mind, our Shopping API support Mixed Rate Plans. Each object should contain next fields:
date [required]
Date represented as string with date in ISO 8601 format by mask YYYY-MM-DD
.
price [required]
String or Integer. Price of room at specific date.
rate_plan_code [required]
String. Rate Plan Code received at Get Rooms List operation.
meta [optional]
Object without any specific structure where you can pass any additional information about Booking Room.
Services is Array of Objects to represent additional service or fees sold with bookings. Also, this field can contain Cancellation Fee when booking is cancelled with payment. Each object should contain next fields:
excluded [optional]
Boolean. Is the service not included into the price of the room
true - We will add the fees from this service to the total of the booking
false - Booking total will be unaffected (Default)
type [required]
String. Type of Service. One of possible values: Meal, Fee, Extra
total_price [required]
String. Total Service price.
price_per_unit [required]
String. Price per one unit of Service.
price_mode [required]
String. Service calculation price logic. One of possible values: Per stay, Per night, Per person, Per person per night
persons [required]
Integer. Count of persons associated with Service.
nights [required]
Integer. Count of nights associated with Service.
name [required]
String. Name of service.
room_index [optional]
Integer. Index of room which is associated with Service. Keep in mind, Room should have index
.
applicable_date [optional]
ISO Date. Date when extra is applicable or should be served. Useful for meal extras or some rent-based extras.
Deposits is Array of Objects to represent charges for bookings. Each object should contain next fields:
amount [required]
String or Positive Integer.
currency [required]
String. Currency code.
charged_at [optional]
Timestamp to represent when charge was processed.
type [required]
String. Free form type of payment. Example: credit_card
, cash
, bank_transfer
.
notes [optional]
String. Free form notes about deposit.
provider_meta [optional]
JSON. Meta field for information from Payment processor. Example: transaction object from Stripe.
Sometimes, you would like to request Property to send full information about Restrictions and Availability. To trigger this action you can use our request_full_sync
method.