Introduction
Welcome to the Airhost Checkin API! YOu can use our API to access basic booking information and guest informations.
We have language bindings in Ruby! You can view code examples in the dark area to the right, and you can switch the programming language of the examples with the tabs in the top right.
Authentication
To generate proper authentication header, use this code:
# With shell, you can just pass the correct header with each request
curl "api_endpoint_here"
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ=="
-H "APPID: APIKEY_FROM_AIRHOST"
require 'base64'
base64_encoded_string = Base64.encode64("username:password")
Base64.encode64("demo:nikuniku")
=> "ZGVtbzpuaWt1bmlrdQ=="
base64_encode("demo:nikuniku")
=> "ZGVtbzpuaWt1bmlrdQ=="
Buffer.from("demo:nikuniku").toString('base64')
#=> "ZGVtbzpuaWt1bmlrdQ=="
base64.b64decode("demo:nikuniku")
#=> "ZGVtbzpuaWt1bmlrdQ=="
Make sure to replace
APIKEY_FROM_AIRHOST
with your API key.
If you don't have one, please contact Airhost Support
Airhost expects for the API key plus the Authentication Key to be included in all API requests to the server in a header that looks like the following:
Authorization: Basic Base64(username:password)
APPID: APIKEY_FROM_AIRHOST
Base64(username:password) is host's username and password with the character ":" in the middle, then encode with base64 format.
Checkin Setting
Checkin Setting for a specific property
curl "https://test.airhost.co/api/v1/checkin/houses/:id/settings" \
-X GET -H "Content-Type: application/json" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST"
The above command returns JSON structured like this:
{
"name": "AirHost Hotel No. 1",
"welcome_msg": "Welcome to AirHost Hotel ^^",
"terms": "https://goo.gl/eydXgi",
"hotel_img": "https://s3-ap-northeast-1.amazonaws.com/triosky-airhost/uploads/house/292/app_background_img/TS_Hotel_King_lowrez.jpg",
"logo": "https://s3-ap-northeast-1.amazonaws.com/triosky-airhost/uploads/house/292/app_logo/icons8-service-bell-96.png",
"key_info_img_url": "https://s3-ap-northeast-1.amazonaws.com/triosky-airhost/uploads/house/292/key_info_img/TS_Hotel_King_lowrez.jpg",
"key_info_doc_url": "https://goo.gl/QJrtJu",
"checkin_type": "self_checkin",
"operator_id": null,
"checkin_settings":
{
"fields": [
{
"name": "photo",
"required": "all"
},
{
"name": "name",
"required": "all"
},
{
"name": "occupation",
"required": "all"
},
{
"name": "postal_code",
"required": "foreigner_only"
},
{
"name": "address",
"required": "represent_only"
},
{
"name": "phone",
"required": "hide"
},
{
"name": "nationality",
"required": "all"
},
{
"name": "visa_no",
"required": "all"
},
{
"name": "dob",
"required": "all"
}],
"enabled": "1"
}
}
This endpoint retrieves checkin setting of a listing.
HTTP Request
GET https://test.airhost.co/api/v1/checkin/houses/:id/settings
Query Parameters
Parameter | Default | Description |
---|---|---|
id | true | The house's ID |
Return Data Parameters
Parameter | Default | Description |
---|---|---|
name | true | Property Name |
welcome_msg | false | Default greeting message |
terms | false | Terms of Service |
hotel_img | false | Picture of the property |
logo | false | Logo of this property |
key_info_img_url | false | image information related to how to get key |
key_info_doc_url | false | document URL realted to how to get key |
checkin_settings[fields][name] | true | guest detail information fields |
checkin_settings[fields][required] | true | all means all guests are required to submit. \n represent_only means only the person made the reservation \n hide meaning, no need to ask. foreigner_only meaning it is for non-Japanese. |
checkin_settings[name] | false | Guest Name |
checkin_settings[photo] | false | Guest Passport Photos |
checkin_settings[dob] | false | Guest Date of Birth |
checkin_settings[nationality] | false | Guest Nationality (2 letters ISO3166) |
checkin_settings[postal_code] | false | Guest Postal Code |
checkin_settings[address] | false | Guest Address |
checkin_settings[occupation] | false | Guest Occupation |
checkin_settings[visa_no] | false | Guest Passport/Visa Number |
checkin_settings[phone] | false | Guest Phone number |
checkin_settings[last_port_embark] | false | Previous Country before arriving here |
checkin_settings[next_port_disembark] | false | Next Country will depart to |
checkin_settings[signature] | false | Guest signature |
Booking
Retrieve Bookings
curl "https://test.airhost.co/api/v1/bookings" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
-H "Content-Type: application/json" \
-X GET \
--data '{ \
"house_id"=1, \
"updated_at"=1533217109 \
}'
updated_at = Time.zone.now.to_i
The above command returns JSON structured like this:
{
"data": [
{
"id": 1358,
"uid": "123456789",
"guestnum": 3,
"summary": "John Smith (123456789)",
"dtstart": "2018-04-07T16:00:00.000+09:00",
"dtend": "2018-04-11T11:00:00.000+09:00",
"status": "confirmed",
"checkin_type": null,
"checkin_status": "checked_in",
"source": "airbnb",
"user":
{
"name": "John Smith",
"email": "john-smith@test.com"
},
"room":
{
"id": 123,
"name": "One Bedroom"
},
"booking_fees": [{
"id":3,
"fee_type":"transaction_fee",
"description":"Stripe service fee",
"dtdate":null,"amount":1008.0,
"included":true,"currency":null,
"paid":true,"per_night":false,
"per_person":false,
"percentage":0,
"created_at":"2018-12-11T12:17:43.378+09:00",
"updated_at":"2018-12-15T01:02:18.800+09:00"
}],
"fees":[
{"paid":false,
"fee_type":"per_day",
"amount":7700.0,
"date":"2020-04-08",
"description":"Standard Rate",
"ota_collect":false,
"included":false
}
],
"payment_status": "paid",
"payment_method": "hotel_collect",
"currency": "JPY",
"reservation_site" : "Booking.COM"
}],
"meta":
{
"total_pages": 1,
"total_count": 1
}
}
This endpoint retrieves all bookings from one house.
HTTP Request
GET https://test.airhost.co/api/v1/bookings
Query Parameters
Parameter | Default | Description |
---|---|---|
house_id | true | Search booking by House ID |
updated_at | true | Bookings updated after this time, it is in timestamp format. \n current epoch/unix timestamp |
Return Data Parameters
Parameter | Default | Description |
---|---|---|
id | true | Booking ID in Airhost |
uid | true | Booking ID from OTA |
guestnum | true | number of guests |
summary | true | Booking's description |
dtstart | true | checkin date |
dtend | true | checkout date |
checkin_type | false | self_checkin or operator_checkin |
checkin_status | false | :before_checkin, :checked_in, :checked_out |
source | true | OTA name |
room | true | room information |
house | true | property information |
user | true | guest information |
booking_fees | false | document any additional charges |
fees | false | charges from OTA |
cancellation_fee | false | cancellation fees if booking is cancelled |
payment_status | false | :not_paid, :paid, :partial_paid, :over_paid |
payment_method | false | :ota_collect, :hotel_collect, :hotel_collect_credit, :hotel_collect_cash |
currency | true | currency for this booking |
reservation_site | false | reservation is made from. |
Search a Booking
curl "https://test.airhost.co/api/v1/checkin/bookings" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
-H "Content-Type: application/json" \
-X GET \
--date '{ \
"uid":123, \
"last_name": "Smith", \
"first_name": "John", \
"house_id": 1 \
}'
The above command returns JSON structured like this:
{
"data": [
{
"id": 1358,
"uid": "123456789",
"guestnum": 3,
"summary": "John Smith (123456789)",
"dtstart": "2018-04-07T16:00:00.000+09:00",
"dtend": "2018-04-11T11:00:00.000+09:00",
"status": "confirmed",
"checkin_type": null,
"checkin_status": "checked_in",
"source": "airbnb",
"user":
{
"name": "John Smith",
"email": "john-smith@test.com"
},
"room":
{
"id": 123,
"name": "One Bedroom"
},
"booking_fees": [{
"id":3,
"fee_type":"transaction_fee",
"description":"Stripe service fee",
"dtdate":null,"amount":1008.0,
"included":true,"currency":null,
"paid":true,"per_night":false,
"per_person":false,
"percentage":0,
"created_at":"2018-12-11T12:17:43.378+09:00",
"updated_at":"2018-12-15T01:02:18.800+09:00"
}],
"fees":[
{"paid":false,
"fee_type":"per_day",
"amount":7700.0,
"date":"2020-04-08",
"description":"Standard Rate",
"ota_collect":false,
"included":false
}
],
"payment_status": "paid",
"payment_method": "hotel_collect",
"currency": "JPY",
"reservation_site" : "Booking.COM"
}],
"meta":
{
"total_pages": 1,
"total_count": 1
}
}
This endpoint retrieves all bookings match search query.
HTTP Request
GET https://test.airhost.co/api/v1/checkin/bookings
Query Parameters
Parameter | Default | Description |
---|---|---|
house_id | true | Search booking by House ID |
uid | true | Search booking by its OTA confirmation ID |
last_name | false | Search booking by guest last name |
first_name | false | Search booking by guest first name |
room_number | false | Search booking by Room Number (used for checkout mostly) |
Mark a Booking as Paid
curl -X POST "https://test.airhost.co/api/v1/checkin/bookings/:id/completed" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST"
--date '{ \
"payload": "some details about this transaction" \
"payment_method": "credit_card" \
}'
The above command returns JSON structured like this:
{
"id": 1358,
"uid": "123456789",
"guestnum": 3,
"summary": "John Smith (123456789)",
"dtstart": "2018-04-07T16:00:00.000+09:00",
"dtend": "2018-04-11T11:00:00.000+09:00",
"status": "confirmed",
"checkin_type": null,
"checkin_status": "checked_in",
"source": "airbnb",
"user":
{
"name": "John Smith",
"email": "john-smith@test.com"
},
"room":
{
"id": 123,
"name": "One Bedroom"
},
"booking_fees": [{
"id":3,
"fee_type":"transaction_fee",
"description":"Stripe service fee",
"dtdate":null,"amount":1008.0,
"included":true,"currency":null,
"paid":true,"per_night":false,
"per_person":false,
"percentage":0,
"created_at":"2018-12-11T12:17:43.378+09:00",
"updated_at":"2018-12-15T01:02:18.800+09:00"
}],
"fees":[
{"paid":false,
"fee_type":"per_day",
"amount":7700.0,
"date":"2020-04-08",
"description":"Standard Rate",
"ota_collect":false,
"included":false
}
],
"payment_status": "paid",
"payment_method": "hotel_collect",
"currency": "JPY",
"reservation_site" : "Booking.COM"
}
This endpoint marks the booking's payment status to paid
HTTP Request
POST http://cloud.airhost.co/api/v1/checkin/bookings/:id/paid
URL Parameters
Parameter | Default | Description |
---|---|---|
id | true | The Booking's ID |
payload | false | transaction data to save to the server. Such as transactionID or Paid Amount |
payment_method | false | Choose one: cash, credit_card, bank_transfer. Defaults to cash if payment method is not provided. |
Complete a Booking's checkin.
curl -X POST "https://test.airhost.co/api/v1/checkin/bookings/:id/completed" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST"
The above command returns JSON structured like this:
{
"room_unit": "101",
"checkin_information": "Checkin Instructure is at http://goog.gl/abc",
"room_code": "123",
"key_doc_url": "http://goo.gl/abc",
}
This endpoint mark the booking checkin is completed and receive the details room information.
HTTP Request
POST http://cloud.airhost.co/api/v1/checkin/bookings/:id/completed
URL Parameters
Parameter | Default | Description |
---|---|---|
booking_id | true | The Booking's ID |
Return Data Parameters
Parameter | Default | Description |
---|---|---|
room_unit | true | Guest's Room Number |
checkin_information | false | Instruction of How to get Key |
room_code | false | If it is smart lock |
key_doc_url | false | Additional informations. |
Email a Booking's checkin information.
curl -X POST "https://test.airhost.co/api/v1/checkin/bookings/:id/email" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
--date '{"name": "John Smith", \
"email": "john@smith.com" \
}'
The above command returns JSON structured like this:
{
"room_unit": "101",
"checkin_information": "Checkin Instructure is at http://goog.gl/abc",
"room_code": "123",
"key_doc_url": "http://goo.gl/abc",
}
This endpoint mark the booking checkin is completed and receive the details room information.
HTTP Request
POST http://cloud.airhost.co/api/v1/checkin/bookings/:id/completed
URL Parameters
Parameter | Default | Description |
---|---|---|
booking_id | true | The Booking's ID |
name | true | The new recipient's name |
true | The new recipient's email |
Complete a Booking's checkout.
curl -X POST "https://test.airhost.co/api/v1/checkin/bookings/:id/checked_out" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST"
The above command returns JSON structured like this:
{
"data": [
{
"id": 1358,
"uid": "123456789",
"guestnum": 3,
"summary": "John Smith (123456789)",
"dtstart": "2018-04-07T16:00:00.000+09:00",
"dtend": "2018-04-11T11:00:00.000+09:00",
"status": "confirmed",
"checkin_type": null,
"checkin_status": "checked_out",
"source": "airbnb",
"user":
{
"name": "John Smith",
"email": "john-smith@test.com"
}
}],
"meta":
{
"total_pages": 1,
"total_count": 1
}
}
This endpoint mark the booking checkout is completed and receive the details booking information.
HTTP Request
POST http://cloud.airhost.co/api/v1/checkin/bookings/:id/checked_out
URL Parameters
Parameter | Default | Description |
---|---|---|
id | true | The Booking's ID |
Guest
Get All Guests
curl -X GET "https://test.airhost.co/api/v1/checkin/bookings/:booking_id/guests" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
-H "Content-Type: application/json"
The above command returns JSON structured like this:
[{
"id": 2,
"name": "Tom Phillips",
"notes": "awesome",
"settings":
{
"dob": "2018-05-01",
"phone": "1234456",
"address": "USA",
"visa_no": "123456789",
"occupation": "CEO",
"nationality": "US",
"postal_code": "123"
},
"last_name": "Phillips",
"first_name": "Tom",
"gender": "male",
"dob": "2018-05-01",
"visa_no": "123456789",
"occupation": "CEO",
"nationality": "US",
"postal_code": "123",
"address": "USA",
"phone": "1234456",
"photo": {
"id": 36,
"checkin_guest_id": 13,
"booking_id": 530592,
"item": {
"url": "/uploads/development/checkin_attachment/36/item/id_photo.jpg",
"thumb": {
"url": "/uploads/development/checkin_attachment/36/item/thumb_id_photo.jpg"
}
},
"data": {},
"attachment_type": "photo",
"created_at": "2018-12-10T14:25:34.617+09:00",
"updated_at": "2018-12-10T14:25:34.617+09:00",
"name": "photo"
},
"ident_photo": null,
"last_port_embark": null,
"next_port_disembark": null,
"signature": {
"id": 37,
"checkin_guest_id": 13,
"booking_id": 530592,
"item": {
"url": "/uploads/development/checkin_attachment/37/item/signature.png",
"thumb": {
"url": "/uploads/development/checkin_attachment/37/item/thumb_signature.png"
}
},
"data": {},
"attachment_type": "photo",
"created_at": "2018-12-10T14:25:34.666+09:00",
"updated_at": "2018-12-10T14:25:34.666+09:00",
"name": "signature"
},
"email": "tom@airhost.co"
},
{
"id": 3,
"name": "Samanta Phillips",
"notes": "sad",
"settings":
{
"dob": "2018-05-17",
"phone": "123",
"address": "USA",
"visa_no": "123456789",
"occupation": "developer",
"nationality": "US",
"postal_code": "12345"
}
}]
This endpoint retrieves all guests associate with a booking match search query.
HTTP Request
GET https://test.airhost.co/api/v1/checkin/bookings/:booking_id/guests
Query Parameters
Parameter | Default | Description |
---|---|---|
booking_id | true | The Booking's ID |
Create a guest.
curl -X POST "https://test.airhost.co/api/v1/checkin/bookings/:booking_id/guests" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
-data '{ \
"first_name": "Samanta", \
"last_name": "Phillips", \
"notes": "test", \
"dob": "2018-05-17", \
"phone": "123", \
"address": "123 USA", \
"visa_no": "123456789", \
"occupation": "developer", \
"nationality": "US", \
"postal_code": "12345" \
}'
The above command returns JSON structured like this:
{
"id": 3,
"first_name": "Samanta",
"last_name": "Phillips",
"notes": "sad",
"settings":
{
"dob": "2018-05-17",
"phone": "123",
"address": "123 USA",
"visa_no": "123456789",
"occupation": "developer",
"nationality": "US",
"postal_code": "12345"
}
}
This endpoint add a guest into this booking
HTTP Request
POST http://cloud.airhost.co/api/v1/checkin/bookings/:booking_id/guests
URL Parameters
Parameter | Default | Description |
---|---|---|
booking_id | true | The Booking's ID |
first_name | false | Guest First Name |
last_name | false | Guest Last Name |
dob | false | Guest Date of Birth |
gender | false | Guest Gender (male or female) |
false | Guest Email Address | |
nationality | false | Guest Nationality (2 letters ISO3166) |
postal_code | false | Guest Postal Code |
address | false | Guest Address |
occupation | false | Guest Occupation |
visa_no | false | Guest Passport/Visa Number |
phone | false | Guest Phone number |
last_port_embark | false | Previous Country before arriving here |
next_port_disembark | false | Next Country will depart to |
Update a guest.
curl -X PUT "https://test.airhost.co/api/v1/checkin/bookings/:booking_id/guests/:id" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
-data '{ \
"first_name": "Samanta", \
"last_name": "Phillips", \
"notes": "test", \
"dob": "2018-05-17", \
"phone": "123", \
"address": "USA", \
"visa_no": "123456789", \
"occupation": "developer", \
"nationality": "Untied States", \
"postal_code": "12345" \
}'
The above command returns JSON structured like this:
{
"id": 3,
"first_name": "Samanta",
"last_name": "Phillips",
"notes": "sad",
"settings":
{
"dob": "2018-05-17",
"phone": "123",
"address": "USA",
"visa_no": "123456789",
"occupation": "developer",
"nationality": "Untied States",
"postal_code": "12345"
}
}
This endpoint add a guest into this booking
HTTP Request
PUT http://cloud.airhost.co/api/v1/checkin/bookings/:booking_id/guests/:id
URL Parameters
Parameter | Default | Description |
---|---|---|
booking_id | true | The Booking's ID |
id | true | The ID of the guest |
Attachment
Get All Attachments
curl -X GET "https://test.airhost.co/api/v1/checkin/bookings/:booking_id/guests/:guest_id/attachments" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
-H "Content-Type: application/json"
The above command returns JSON structured like this:
[{
"id": 2,
"remote_item_url": "http://xxxxxx.jpg",
"name": "photo"
},
{
"id": 3,
"remote_item_url": "http://xxxxxx.jpg",
"name": "signature"
}]
This endpoint retrieves all attachments associate with a booking match search query.
HTTP Request
GET https://test.airhost.co/api/v1/checkin/bookings/:booking_id/guests/:guest_id/attachments
Query Parameters
Parameter | Default | Description |
---|---|---|
booking_id | true | The Booking's ID |
guest_id | true | The ID of the guest |
name | true | the name of the attachment. |
Create a attachment.
curl -X POST "https://test.airhost.co/api/v1/checkin/bookings/:booking_id/guests/:guest_id/attachments" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
--data '{ \
"item": "image/jpeg;base64,(base64 encoded data)", \
"name": "ident_photo",
"file_name": "passport_photo.jpg" \
}'
The above command returns JSON structured like this:
{
"id": 3,
"name": "ident_photo",
"remote_item_url": "http://xxxxxx.jpg"
}
This endpoint add a attachment into this booking
HTTP Request
POST http://cloud.airhost.co/api/v1/checkin/bookings/:booking_id/guests/:guest_id/attachments
URL Parameters
Parameter | Default | Description |
---|---|---|
booking_id | true | The ID of the booking |
guest_id | true | The ID of the guest |
name | true | the name of this attachment. |
Use to distinguish if it is a passport or other type of attachment. | ||
please use name="photo" for passport photo | ||
Please use name="ident_photo" for holding passport photo | ||
please use name="signature" for signature photo | ||
file_name | false | the file name of the image. |
Update a attachment.
curl -X PUT "https://test.airhost.co/api/v1/checkin/bookings/:booking_id/guests/:guest_id/attachments/:id" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
-data '{ \
"id": 3, \
"item": ".....", \
"file_name": "passport_photo.jpg", \
"name": "photo" \
}'
The above command returns JSON structured like this:
{
"id": 3,
"name": "photo",
"remote_item_url": "http://xxxxxx.jpg"
}
This endpoint add a attachment into this booking
HTTP Request
PUT http://cloud.airhost.co/api/v1/checkin/bookings/:booking_id/guests/:guest_id/attachments/:id
URL Parameters
Parameter | Default | Description |
---|---|---|
booking_id | true | The ID of the booking |
guest_id | true | The ID of the guest |
id | true | The id of the attachment |
Video Chat
Create a Video Chat request.
curl -X POST "https://test.airhost.co/api/v1/checkin/bookings/:booking_id/video_chats" \
-H "Authorization: Basic ZGVtbzpuaWt1bmlrdQ==" \
-H "APPID: APIKEY_FROM_AIRHOST" \
The above command returns JSON structured like this:
{
"token": "xxxxxx",
"chat_room": "xxxx-xxx-xxx-xxx"
}
This endpoint create a video chat
HTTP Request
POST http://cloud.airhost.co/api/v1/checkin/bookings/:booking_id/video_chats
URL Parameters
Parameter | Default | Description |
---|---|---|
token | true | The Auth token to connect to the video chat service |
chat_room | true | the chat room that is created |
Errors
The Airhost API uses the following error codes:
Error Code | Description |
---|---|
400 | Bad Request -- Your request is invalid (missing_required_paramter) |
401 | Unauthorized -- Your API key is wrong (invalid_api_key) or \n invalid_username_password: invalid username and password, please make sure they are base64 encoded.\n invalid_api_call: you are not authorized to use this API endpoint. |
403 | Forbidden -- The kitten requested is hidden for administrators only. |
404 | Not Found -- The specified record could not be found. |
405 | Method Not Allowed -- You tried to access a record with an invalid method. |
406 | Not Acceptable -- You requested a format that isn't json. |
441 | Not ready for checkin -- You cannot check in now, but need to wait till check-in time (not_ready_for_checkin) |
442 | Already checked in -- This reservation has already checked in (reservation_already_checked_in) |
443 | Already checked out -- This reservation has already checked out (reservation_already_checked_out) |
429 | Too Many Requests -- You're requesting too many kittens! Slow down! |
500 | Internal Server Error -- We had a problem with our server. Try again later. |
503 | Service Unavailable -- We're temporarily offline for maintenance. Please try again later. |