TABLE OF CONTENTS

Introduction

The Reservation APIs are used by distributors to support the real-time booking flow. In this article, 7 types of Reservation APIs will be introduced:


APIs marked with "☆" are mandatory for Distributors to implement, while those marked with "◎" are optional but recommended.

  • ☆ Live Check(/availability)-This API is used to check real-time availability to get all available rooms and rates. A call will be sent to the hotel supplier’s system to get real-time results.
  • ☆ Prebook(/reservation/prebook)-This API is used to do a final check before a booking. A call will be sent to the hotel supplier‘s system to get real-time results.
  • ☆ Book(/reservation/book)-This API is used by distributors to book the rooms. A call will be sent to the hotel supplier’s system to get a real-time confirmation.
  • ◎ Modify(/reservation/modify)-This API is used by distributors to modify an existing booking. A call will be sent to the hotel supplier's system to get a real-time confirmation. For any hotel supplier that cannot support a modification, it will be processed as a cancel->rebook strategy.Please be aware that distributors who connect with Disney are required to implement the API.
  • ☆ Cancel(/reservation/cancel)-This API is used by distributors to cancel an existing booking. A call will be sent to the hotel supplier's system to get a real-time cancel confirmation.
  • ◎ Query Reservation List(/reservations)-This API is used by distributors to query existing bookings.
  • ◎ Query Reservation Detail(/reservation/detail)-This API is used by distributors to query existing bookings. It can be used to check the reservation status of some timeout booking requests.


Live Check

This API is used to check real-time availability to get all available rooms and rates from hotel suppliers. Please note that if hotel suppliers don't support the live check function, GO will call DerbySoft ARI cache instead. Besides, the maximum stay can be supported up to 61 days for a live check request if hotel suppliers support it.

POST /availability HTTP/1.1
URL: {endpoint}/availability
Authorization:Bearer 53ac07777cdffac2d53000002d698728ce964432d7167596bc005c5fc
Accept-Encoding: gzip
Content-Encoding: gzip
Content-Type: application/json;charset=utf-8

Request Example

{
    "header": {
      "supplierId": "HILTON",
      "distributorId": "GTA",
      "version": "v4",
      "token": "18393849028490234"
    },
    "hotelId": "GATHI",
    "stayRange": {
      "checkin": "2018-01-01",
      "checkout": "2018-01-04"
    },
    "roomCriteria": {
      "roomCount": 2,
      "adultCount": 1,
      "childCount": 2,
      "childAges": [
        4,
        8
      ]
    },
    "productCandidate": {
      "roomId": "K1D",
      "rateId": "ODAD01"
    },
    "iata": "string",
    "loyaltyAccount": {
      "programCode": "BW",
      "accountId": "1234567890123457"
    },
    "corpAccount": {
      "corpProgramCode": "CR",
      "corpId": "A-1232"
    },
    "isAfterPromotion": false,
    "promoteCode": "string",
    "bookingChannel": "string",
    "extensions": {
      "key1": "value1",
      "key2": "value2"
    }
  }

Request  Specification

AttributeTypeRequiredDescriptionExample

header

object

Yes

 /

 /

@supplierId

string

Yes

MaxLength: 32

The ID of the hotel supplier in DerbySoft's system

HILTON

@distributorId

string

Yes

MaxLength: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

MaxLength: 20

Version of API

v4

@token

string

Yes

MaxLength: 64

A unique ID to identify request and response, normally it should be UUID.

18393849028490234

hotelId

string

Yes

Hotel ID in supplier's system

GATHI

stayRange

object

Yes

 /

 /

@checkin

string

Yes

Check-in, format with yyyy-MM-dd

2018-01-01

@checkout

string

Yes

Check out, format with yyyy-MM-dd

2018-01-04

roomCriteria

object

Yes

 /

 /

@roomCount

integer

Yes

Total room count per request

2

@adultCount

integer

Yes

Adult count per room

1

@childCount

integer

No

Child count per room

2

@childAges

array

No

Child ages for each child, array size MUST be the same as a child count.

[ 4, 8 ]

productCandidate

object

No

 /

 /

@roomId

string

No

Room ID in supplier's system

K1D

@rateId

string

No

Rate ID in supplier's system

ODAD01

iata

string

No

IATA of distributor

 /

loyaltyAccount

object

No

 /

 /

@programCode

string

Yes

Loyalty program code of the supplier

BW

@accountId

string

Yes

Loyalty program account ED

1234567890123457

corpAccount

object

No

 /

 /

@corpProgramCode

string

Yes

Corporate Hotel Program of hotel supplier

CR

@corpId

string

Yes

Corporate ID in the program account

A-1232

isAfterPromotion

boolean

No

The flag indicates calculating the available room rates with the promotion rules or not.

  • TRUE means checking the availability under the promotion rules provided by the supplier.
  • FALSE means you do not need to check the availability under any promotions, basic live-check only.

false

promoteCode

string

 No

Promote code defined by the hotel, is an optional field when you want to request the promotion rates (isAfterPromotion=true).

If promote code is empty and there are multiple promotions available for one product at the same time, the promotion rule will be chosen according to multiPromotionsStategy.

 /

bookingChannelstringNoSub-distributor ID/

extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

 /


Response Example

  • Success Response (HTTP Status 200)
{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "hotelId": "GATHI",
  "stayRange": {
    "checkin": "2018-01-01",
    "checkout": "2018-01-04"
  },
  "roomCriteria": {
    "roomCount": 2,
    "adultCount": 1,
    "childCount": 2,
    "childAges": [
      4,
      8
    ]
  },
  "productCandidate": {
    "roomId": "K1D",
    "rateId": "ODAD01"
  },
  "iata": "string",
  "roomRates": [
    {
      "inventory": 2,
      "isAfterPromotion": true,
      "promoteCode": "discount001",
      "roomId": "K1D",
      "rateId": "ODAD01",
      "currency": "USD",
      "amountBeforeTax": [
        100,
        100,
        120
      ],
      "amountAfterTax": [
        110,
        110,
        130
      ],
      "mealPlan": "RO",
      "paymentType": "PayNow",
      "guarantee": {
        "guaranteeType": "CCG"
      },
      "fees": [
        {
          "dateRange": {
            "startDate": "2018-01-01",
            "endDate": "2018-01-04"
          },
          "fee": {
            "name": "Service Charge",
            "type": "Exclusive",
            "amount": 10,
            "amountType": "Percent",
            "chargeType": "PerRoomPerNight",
            "paymentType": "PayNow",
            "effectivePerson": 0
          }
        }
      ],
      "cancelPolicy": {
        "code": "AD100P_100P",
        "description": "Non Refundable",
        "cancelPenalties": [
          {
            "noShow": true,
            "cancellable": true,
            "cancelDeadline": {
              "offsetTimeDropType": "BeforeArrival",
              "offsetTimeUnit": "D",
              "offsetTimeValue": 0,
              "deadline": "string"
            },
            "penaltyCharge": {
              "chargeBase": "FullStay",
              "nights": 0,
              "amount": 0,
              "percent": 0
            }
          }
        ]
      }
    }
  ],
  "extensions": {
    "key1": "value1",
    "key2": "value2"
  }
}
  • Successful Response from Exchange Connection and RETAIL Rate Model(HTTP Status 200)
{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "hotelId": "GATHI",
  "stayRange": {
    "checkin": "2018-01-01",
    "checkout": "2018-01-04"
  },
  "roomCriteria": {
    "roomCount": 2,
    "adultCount": 1,
    "childCount": 2,
    "childAges": [
      4,
      8
    ]
  },
  "productCandidate": {
    "roomId": "K1D",
    "rateId": "ODAD01"
  },
  "iata": "string",
  "roomRates": [
    {
      "inventory": 2,
      "isAfterPromotion": true,
      "promoteCode": "discount001",
      "roomId": "K1D",
      "rateId": "ODAD01",
      "connectionType": "Exchange",
      "commission": {
        "value": 10,
        "type": "percentage"
      },
      "currency": "USD",
      "amountBeforeTax": [
        100,
        100,
        120
      ],
      "amountAfterTax": [
        110,
        110,
        130
      ],
      "mealPlan": "RO",
      "paymentType": "PayNow",
      "guarantee": {
        "guaranteeType": "CCG"
      },
      "fees": [
        {
          "dateRange": {
            "startDate": "2018-01-01",
            "endDate": "2018-01-04"
          },
          "fee": {
            "name": "Service Charge",
            "type": "Exclusive",
            "amount": 10,
            "amountType": "Percent",
            "chargeType": "PerRoomPerNight",
            "paymentType": "PayNow",
            "effectivePerson": 0
          }
        }
      ],
      "cancelPolicy": {
        "code": "AD100P_100P",
        "description": "Non Refundable",
        "cancelPenalties": [
          {
            "noShow": true,
            "cancellable": true,
            "cancelDeadline": {
              "offsetTimeDropType": "BeforeArrival",
              "offsetTimeUnit": "D",
              "offsetTimeValue": 0,
              "deadline": "string"
            },
            "penaltyCharge": {
              "chargeBase": "FullStay",
              "nights": 0,
              "amount": 0,
              "percent": 0
            }
          }
        ]
      }
    }
  ],
  "extensions": {
    "key1": "value1",
    "key2": "value2"
  }
}
  • Successful Response from Exchange Connection and NET Rate Model(HTTP Status 200)
{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "hotelId": "GATHI",
  "stayRange": {
    "checkin": "2018-01-01",
    "checkout": "2018-01-04"
  },
  "roomCriteria": {
    "roomCount": 2,
    "adultCount": 1,
    "childCount": 2,
    "childAges": [
      4,
      8
    ]
  },
  "productCandidate": {
    "roomId": "K1D",
    "rateId": "ODAD01"
  },
  "iata": "string",
  "roomRates": [
    {
      "inventory": 2,
      "isAfterPromotion": true,
      "promoteCode": "discount001",
      "roomId": "K1D",
      "rateId": "ODAD01",
      "connectionType": "Exchange",
      "currency": "USD",
      "amountBeforeTax": [
        100,
        100,
        120
      ],
      "amountAfterTax": [
        110,
        110,
        130
      ],
      "suggestedTotalPrice": {
        "amountBeforeTax": 600,
        "amountAfterTax": 700
      },
      "mealPlan": "RO",
      "paymentType": "PayNow",
      "guarantee": {
        "guaranteeType": "CCG"
      },
      "fees": [
        {
          "dateRange": {
            "startDate": "2018-01-01",
            "endDate": "2018-01-04"
          },
          "fee": {
            "name": "Service Charge",
            "type": "Exclusive",
            "amount": 10,
            "amountType": "Percent",
            "chargeType": "PerRoomPerNight",
            "paymentType": "PayNow",
            "effectivePerson": 0
          }
        }
      ],
      "cancelPolicy": {
        "code": "AD100P_100P",
        "description": "Non Refundable",
        "cancelPenalties": [
          {
            "noShow": true,
            "cancellable": true,
            "cancelDeadline": {
              "offsetTimeDropType": "BeforeArrival",
              "offsetTimeUnit": "D",
              "offsetTimeValue": 0,
              "deadline": "string"
            },
            "penaltyCharge": {
              "chargeBase": "FullStay",
              "nights": 0,
              "amount": 0,
              "percent": 0
            }
          }
        ]
      }
    }
  ],
  "extensions": {
    "key1": "value1",
    "key2": "value2"
  }
}


  • Error Response(HTTP Status 403)
{
    "error": "Key not authorized"
}
  • Error Response (HTTP Status 500)
{
  "errorCode": "string",
  "supplierErrorCode": "string",
  "errorMessage": "string"
}

Response Specification

Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

MaxLength: 32

The ID of the hotel supplier in DerbySoft's system

HILTON

@distributorId

string

Yes

MaxLength: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

MaxLength: 20

Version of API

v4

@token

string

Yes

MaxLength: 64

A unique ID to identify request and response, normally it should be UUID.

18393849028490234

hotelId

string

Yes

 Hotel ID in supplier's system

GATHI

stayRange

object

Yes

 /

 /

@checkin

string

Yes

Check-in, format with yyyy-MM-dd

2018-01-01

@checkout

string

Yes

Check out, format with yyyy-MM-dd

2018-01-04

roomCriteria

object

Yes

 /

 /

@roomCount

integer

Yes

Total room count per request

2

@adultCount

integer

Yes

Adult count per room

1

@childCount

integer

No

Child count per room

2

@childAges

array

No

Child ages for each child, array size MUST be the same as the child count/

[ 4, 8 ]

productCandidate

object

No

 /

 /

@roomId

string

No

Room ID in supplier system

K1D

@rateId

string

No

Rate ID in supplier system

ODAD01

iata

string

No

IATA of distributor

 /

roomRates

 

Yes

Meal plan, fee, and cancel policy are optional fields as some distributors do not support these in the API.

 /

@inventory

integer

Yes

Available inventory count according to request criteria

1

@isAfterPromotion

boolean

No

The flag indicates calculating the available room rates with the promotion rules or not. Default is false if null

TRUE means to check the availability that is under the promotion rules provided by the supplier.

FALSE means you do not need to check the availability under any promotions, basic live-check only.

false

@promoteCode

string

No

the code for the promotion applied to this rate, It's required when isAfterPromotion = true.

discount001

@roomId

string

Yes

Room ID in supplier system

10000101

@rateId

string

Yes

Rate ID in supplier system

123456

@connectionType
enumNo

Enum: [Exchange, Standard]

Indicates the connection type of product. 

Notes: If the field is omitted, it means the Connection Type is Standard.

Exchange
roomRates/commissionobjectNoNotes: If the connection type is "Exchange" and "RETAIL" Rate Model, the node will be visible; otherwise, it will not appear.
/
@valuenumberYes/10
@typeenumYes

Commission type

Enum: [percentage, amount]

percentage

@currency

string

Yes

Currency code [ISO-4217]

USD

@amountBeforeTax

array[number]

No

The daily amount of rate without tax & fee

[ 100, 100, 120 ]

@amountAfterTax

array[number]

No

The daily amount of rate with tax & fee

[ 110, 110, 130 ]

rooomRates/suggestedTotalPrice

object
NoNotes: If the connection type is "Exchange" and "NET" Rate Model, the node will be visible; otherwise, it will not appear.
/
@amountBeforeTaxnumberNo/600
@amountAfterTaxnumber
No/700

@mealPlan

string

No

For meal plan code, refer to the standard meal plan code list.

RO

@paymentType

enum

No

Indicates the product is prepaid to the hotel (PayNow) or pay at the hotel (PayLater)
Enum: [ PayLater, PayNow ]

PayNow

roomRates/guarantee

object

No

Guarantee information for this room rate.

 /

@guaranteeType

string

Yes

The type of guarantee method, refer to the standard guarantee type list.

CCG

roomRates / fees

array[object]

No

Fee or tax by date range.

 /

fees/dateRange

object

Yes

 /

 /

@startDate

string

Yes

Start date of date range, format with yyyy-MM-dd

2018-01-01

@endDate

string

Yes

End date of date range, format with yyyy-MM-dd

2018-01-04

fees/fee

 

Yes

 /

 /

@name

string

Yes

Pattern: \w[\w\d]+

Service Charge

@type

enum

Yes

The fee or tax is included in the amount before tax or not.

Enum: [ Inclusive, Exclusive ]

Exclusive

@amount

number

Yes

Amount value of fee or tax

10

@amountType

string

Yes

Indicates how to charge the tax, 10% per room per night in this example

Enum: [ Fix, Percent ]

Percent

@chargeType

string

Yes

Enum: [ PerRoomPerNight, PerPersonPerNight, PerRoomPerStay, PerPersonPerStay ]

PerRoomPerNight

@paymentType

enum

No

Indicates the fee is prepaid to the hotel (PayNow) or pay at the hotel (PayLater)

Enum: [ PayLater, PayNow ]

PayNow

@effectivePerson

number

No

It indicates the fee will be charged starting from which occupancy, such as the "Extra Person Charge" fee. The EffectivePerson is 3, meaning an extra fee will be applied from the third person onward.

 3

roomRates/cancelPolicy

object

No

Cancellation policy defines what penalty will be charged when a guest cancels the booking at a certain advance time range. The penalty is related to No-show or a time range before No-show/

 /

@code

string

 Yes

Max Length: 128

Code of cancel policy

AD100P_100P

@description

string

 No

Max Length: 1024

the description of the cancel policy

Non Refundable

cancelPolicy/cancelPenalties

 

Yes

Detail about the cancel Penalty

 /

@noShow

boolean

Yes

If true, it means the penaltyCharge applied for No-Show, and the cancellable, cancelDeadline will NOT exist.

 /

@cancellable

boolean

No

Indicates cancel is allowed or not. If false, it cannot be canceled. If true, the cancelDeadline will exist.

 /

cancelPenalties / cancelDeadline

 

 No

 /

 /

@offsetTimeDropType

enum

No

Enum: [ BeforeArrival ]

An enumerated type indicates when the deadline drop time goes into effect.

 /

@offsetTimeUnit

enum

No

Enum: [ D, H ]

 

 /

@offsetTimeValue

number

No

The number of offset times with the time unit.

 /

@deadline

string

No

local deadline time allowed for cancellation, like 4 PM, or 6 PM.

 /

cancelPenalties / penaltyCharge

 /

 /

 /

 /

@chargeBase

enum

No

Enum: [ FullStay, NightBase ]

if FullStay, it will be a percentage or amount, if NightBase, the nights are required.

 /

@nights

number

No 

Exists if the penalty charge is based on the night, like the first night.

 /

@amount

number

No 

Exists if the penalty charge is a flat charge, like USD 30.00.

 /

@percent

number

No 

Exists if the penalty charge is percent, like 15.5 means 15.5%.

 /

extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

 /


PreBook

Final check availability of target room and rate before booking. The maximum length of stay is 61 for a reservation if hotel suppliers support it.

POST /reservation/prebook HTTP/1.1
URL: {endpoint}/reservation/prebook
Authorization:Bearer 53ac07777cdffac2d53000002d698728ce964432d7167596bc005c5fc
Accept-Encoding: gzip
Content-Encoding: gzip
Content-Type: application/json;charset=utf-8

Request Example

{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "reservationIds": {
    "distributorResId": "C2084DFL0"
  },
  "iata": "string",
  "hotelId": "GATHI",
  "stayRange": {
    "checkin": "2018-01-01",
    "checkout": "2018-01-04"
  },
  "contactPerson": {
    "firstName": "Thomas",
    "lastName": "Hintz",
    "email": "[email protected]",
    "phone": "260-975-4091",
    "address": "3946 Freddy Locks"
  },
  "roomCriteria": {
    "roomCount": 1,
    "adultCount": 2,
    "childCount": 1,
    "childAges": [
      5
    ]
  },
  "total": {
    "amountBeforeTax": 640,
    "amountAfterTax": 700
  },
  "payment": {
    "cardCode": "VI",
    "cardNumber": "4111111111111111",
    "cardHolderName": "Sherlock Holmes",
    "expireDate": "0119",
    "securityCode": "123"
  },
  "loyaltyAccount": {
    "programCode": "BW",
    "accountId": "1234567890123457"
  },
  "corpAccount": {
    "corpProgramCode": "CR",
    "corpId": "A-1232"
  },
  "promoteCode": "string",
  "guests": [
    {
      "firstName": "Thomas",
      "lastName": "Hintz",
      "email": "[email protected]",
      "phone": "260-975-4091",
      "address": "3946 Freddy Locks",
      "age": 32,
      "gender": "Male",
      "birthday": "1990-01-01",
      "type": "Adult",
      "index": 1,
      "extensions": {
        "key1": "value1",
        "key2": "value2"
      }
    },
    {
      "firstName": "Hillary",
      "lastName": "Ullrich",
      "email": "[email protected]",
      "phone": "260-975-4091",
      "address": "3946 Freddy Locks",
      "age": 28,
      "gender": "Female",
      "birthday": "1994-01-01",
      "type": "Adult",
      "index": 1
    },
    {
      "firstName": "Alex",
      "lastName": "Hintz",
      "age": 5,
      "type": "Child",
      "index": 1
    }
  ],
  "comments": [
    "no smoking",
    "high floor"
  ],
  "roomRates": [
    {
      "roomId": "K1D",
      "rateId": "ODAD01",
      "currency": "USD",
      "amountBeforeTax": [
        100,
        100,
        120
      ],
      "amountAfterTax": [
        110,
        110,
        130
      ],
      "mealPlan": "RO",
      "paymentType": "PayNow",
      "guarantee": {
        "guaranteeType": "CCG"
      },
      "fees": [
        {
          "dateRange": {
            "startDate": "2018-01-01",
            "endDate": "2018-01-04"
          },
          "fee": {
            "name": "Service Charge",
            "type": "Exclusive",
            "amount": 10,
            "amountType": "Percent",
            "chargeType": "PerRoomPerNight",
            "paymentType": "PayNow",
            "effectivePerson": 0
          }
        }
      ],
      "cancelPolicy": {
        "code": "AD100P_100P",
        "description": "Non Refundable",
        "cancelPenalties": [
          {
            "noShow": true,
            "cancellable": true,
            "cancelDeadline": {
              "offsetTimeDropType": "BeforeArrival",
              "offsetTimeUnit": "D",
              "offsetTimeValue": 0,
              "deadline": "string"
            },
            "penaltyCharge": {
              "chargeBase": "FullStay",
              "nights": 0,
              "amount": 0,
              "percent": 0
            }
          }
        ]
      }
    }
  ],
  "bookingChannel": "string",
  "productAddons": [
    {
      "type": "DisneyTicket",
      "code": "code",
      "date": "2018-01-01",
      "quantity": 1,
      "officeId": "string",
      "rate": {
        "ageQualifyingType": {
          "type": "Adult",
          "minAge": 18,
          "maxAge": 99
        },
        "currency": "USD",
        "amountBeforeTax": 123.23,
        "amountAfterTax": 134.34
      }
    }
  ],
  "extensions": {
    "key1": "value1",
    "key2": "value2"
  }
}

Request Specification


Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

Max Length: 32

The ID of hotel supplier in DerbySoft's system.

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify requests and responses, normally it should be UUID.

18393849028490234

reservationIds

 /

Yes

 /

 /

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.


PS: If distributors don't generate reservation IDs during the stage, you can fill in a blank value in the request for the field like distributorResId="", but the null value doesn't be accepted since it's a mandatory field.

C2084DFL0

iata

string

No

IATA

 /

hotelId

string

Yes

Hotel ID in supplier's system

100001

stayRange

object

Yes

 /

 /

@checkin

string

Yes

Check-in, format with yyyy-MM-dd

2018-01-01

@checkout

string

Yes

Check out, format with yyyy-MM-dd

2018-01-04

contactPerson

object

Yes

 /

 /

@firstName

string

Yes

First Name

James

@lastName

string

Yes

Last Name

Bond

@email

string

No

Email

[email protected]

@phone

string

No

 /

 /

@address

string

No

 /

 /

roomCriteria

object

Yes

 /

 /

@roomCount

integer

Yes

Total room count per request

 /

@adultCount

integer

Yes

Adult count per room

 /

@childCount

integer

No

Child count per room

 /

@childAges

array

No

Child ages for each child, array size MUST be the same as the child count/

 /

total

object

Yes

 /

 /

@amountBeforeTax

number

No

 abbr. ABT

It's required if AAT is not provided

640

@amountAfterTax

number

No

 abbr. AAT

It's required if ABT is not provided

700

payment

 

No

 /

 /

@cardCode

string

Yes

VI, MC, AX, etc.

Card Code

VI

@cardNumber

string

Yes

Credit card number

4111111111111111

@cardHolderName

string

Yes

Cardholder name

Sherlock Holmes

@expireDate

string

Yes

It should be 2 digits for the month, and 2 digits for the year, as "MMYY".

0119

@securityCodestringNo

Card verification value

123

loyaltyAccount

object

No

 /

 /

@programCode

string

Yes

Loyalty program code of the supplier

BW

@accountId

string

Yes

Loyalty program account ID

1234567890123457

corpAccount

object

No

 /

 /

@corpProgramCode

string

Yes

Corporate Hotel Program of hotel supplier

CR

@corpId

string

Yes

Corporate ID in the program account

A-1232

promoteCode

string

No

Promotion code defined by the hotel, the promotion code is required if making a reservation under the promotion

 /

guests

array[object]

Yes

 /

 /

@firstName

string

Yes

First Name

James

@lastName

string

Yes

Last Name

Bond

@email

string

No

Email

[email protected]

@phone

string

No

 /

 /

@address

string

No

 /

 /

@age

integer

No

Age of guest

 /

@genderenumNoGender of guest
Enum: [Male,Female ]
Male
@birthdaystringNoBirthday of guest
format with yyyy-MM-dd
1970-12-20

@type

string

No

Type of guest Adult, Child, or Infant

Enum: [ Adult, Child, Infant ]

 /

@index

integer

No

Indicate which guests will be allocated to which room.


For one room reservation, the room index is 1 for all guests.

For multi-room reservations, the index starts from 1 and the max room index is equal to the number of booked rooms.

index = 1, Indicate the guest will allocate to the first room.

index = 2, Indicate the guest will allocate to the second room.

@extensionsobject
NoOptional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format).
/

comments

array[string]

No

 /

[ "no smoking", "high floor" ]

roomRates

array[object]

Yes

Min Items: 1 Max Items: 1

meal plan, fee, and cancel policy are optional fields as some distributors do not support these in the API.

 /

@roomId

string

Yes

Room ID in supplier's system

10000101

@rateId

string

Yes

Rate ID in supplier's system

123456

@currency

string

Yes

Currency code [ISO-4217]

USD

@amountBeforeTax

array[number]

No

abbr. ABT

The daily amount of rate without tax and fee

It's required if AAT is not provided

[ 100, 100, 120 ]

@amountAfterTax

array[number]

No

abbr. AT

The daily amount of rate with tax and fee

It's required if ABT is not provided

[ 110, 110, 130 ]

@mealPlan

string

No

Meal plan code, refer to the standard meal plan code list.

RO

@paymentType

enum

No

Indicates the product is prepaid to the hotel (PayNow) or pay at the hotel (PayLater)
Enum: [ PayLater, PayNow ]

PayNow

roomRates/guarantee

object

No

Guarantee information for this room rate.

 /

@guaranteeType

string

Yes

The type of guarantee method, refer to the standard guarantee type list.

CCG

roomRates/fees

array[object]

No

Fee or tax by date range.

 /

fees / dateRange

object

Yes

 /

 /

@startDate

string

Yes

Start date of date range, format with yyyy-MM-dd

2018-01-01

@endDate

string

Yes

End date of date range, format with yyyy-MM-dd

2018-01-04

fees/fee

 

Yes

 /

 /

@name

string

Yes

Pattern: \w[\w\d]+

Service Charge

@type

enum

Yes

The fee or tax is included in the amount before tax or not

Enum: [ Inclusive, Exclusive ]

Exclusive

@amount

number

Yes

Amount value of fee or tax

10

@amountType

string

Yes

Indicates how to charge the tax, 10% per room per night in this example

Enum: [ Fix, Percent ]

Percent

@chargeType

string

Yes

Enum: [ PerRoomPerNight, PerPersonPerNight, PerRoomPerStay, PerPersonPerStay ]

PerRoomPerNight

@paymentType

enum

No

Indicates the fee is prepaid to the hotel (PayNow) or pay at the hotel (PayLater)

Enum: [ PayLater, PayNow ]

PayNow

@effectivePerson

number

No

It indicates the fee will be charged starting from which occupancy, such as the "Extra Person Charge" fee. The EffectivePerson is 3, meaning an extra fee will be applied from the third person onward.

 /

roomRates/cancelPolicy

object

No

Cancellation policy defines what penalty will be charged when a guest cancels the booking at a certain advance time range. The penalty is related to No-show or a time range before No-show

 /

@code

string

 Yes

MaxLength: 128

code of cancel policy

AD100P_100P

@description

string

 No

MaxLength: 1024

the description of the cancel policy

Non Refundable

cancelPolicy/cancelPenalties

 

Yes

Detail about the cancel Penalty

@noShow

boolean

Yes

If true, it means the penaltyCharge applied for No-Show, and the cancellable, cancelDeadline will NOT exist.

 /

@cancellable

boolean

No

Indicates cancel is allowed or not. If false, it cannot be canceled. If true, the cancelDeadline will exist.

 /

cancelPenalties/cancelDeadline

 /

 /

 /

 /

@offsetTimeDropType

enum

No

Enum: [ BeforeArrival ]

An enumerated type indicates when the deadline drop time goes into effect.

 /

@offsetTimeUnit

enum

No

Enum: [ D, H ]

 

 /

@offsetTimeValue

number

No

The number of offset times with the time unit/

 /

@deadline

string

No

local deadline allowed for cancellation, like
4 PM, 6 PM.

 /

cancelPenalties/penaltyCharge

 /

 /

 /

 /

@chargeBase

enum

No

Enum: [ FullStay, NightBase ]

if FullStay, it will be a percentage or amount, if NightBase, the nights are required.

 /

@nights

number

No

Exists if the penalty charge is based on the night, like the first night

 /

@amount

number

No

Exists if the penalty charge is a flat charge, like USD 30.00

 /

@percent

number

No

Exists if the penalty charge is percent, like 15.5 means 15.5%

 /

bookingChannelstringNoSub-distributor ID/
productAddonsarray[object]No//
@typestringYesproduct addon type/
@codestringYesproduct addon code/
@datestringYesformat with yyyy-MM-dd2022-01-01
@quantityintegerYes/1
@officeIdstringNo//
productAddons/rateobjectNo//
rate/ageQualifyingTypeobjectNo//
@typeenumYesEnum: [Adult, Child]Adult
@minAgeintegerYes/18
@maxAgeintegerYes/18
rate/currencystringYes/USD
rate/amountBeforeTaxnumberNo/123.23
rate/amountAfterTaxnumberNo/134.34

extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

 /


Response Example

  • Success Response (HTTP Status 200)
{
    "header": {
      "supplierId": "HILTON",
      "distributorId": "GTA",
      "version": "v4",
      "token": "18393849028490234"
    },
    "bookingToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c",
    "extensions": {
      "key1": "value1",
      "key2": "value2"
    }
  }
  • Error Response (HTTP Status 403)
{
    "error": "Key not authorised"
}
  • Error Response (HTTP Status 500)
{
    "errorCode": "string",
    "supplierErrorCode": "string",
    "errorMessage": "string"
 }


Response Specification

Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

MaxLength: 32

The ID of the hotel supplier in DerbySoft's system

HILTON

@distributorId

string

Yes

MaxLength: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

MaxLength: 20

Version of API

v4

@token

string

Yes

MaxLength: 64

A unique ID to identify request and response, normally it should be UUID.

18393849028490234

bookingToken

string

Yes

Booking token used for booking

/

extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

 /


Book

This API is utilized by distributors to reserve rooms. A request is sent to the hotel supplier system to receive immediate confirmation.

POST /reservation/book HTTP/1.1
URL: {{endpoint}}/reservation/book
Authorization:Bearer 53ac07777cdffac2d53000002d698728ce964432d7167596bc005c5fc
Accept-Encoding: gzip
Content-Encoding: gzip
Content-Type: application/json;charset=utf-8

Request Example

{
    "header": {
      "supplierId": "HILTON",
      "distributorId": "GTA",
      "version": "v4",
      "token": "18393849028490234"
    },
    "reservationIds": {
      "distributorResId": "C2084DFL0"
    },
    "iata": "string",
    "hotelId": "GATHI",
    "stayRange": {
      "checkin": "2018-01-01",
      "checkout": "2018-01-04"
    },
    "contactPerson": {
      "firstName": "Thomas",
      "lastName": "Hintz",
      "email": "[email protected]",
      "phone": "260-975-4091",
      "address": "3946 Freddy Locks"
    },
    "roomCriteria": {
      "roomCount": 1,
      "adultCount": 2,
      "childCount": 1,
      "childAges": [
        5
      ]
    },
    "total": {
      "amountBeforeTax": 640,
      "amountAfterTax": 700
    },
    "payment": {
      "cardCode": "VI",
      "cardNumber": "4111111111111111",
      "cardHolderName": "Sherlock Holmes",
      "expireDate": "0119",
      "securityCode": "123"
    },
    "loyaltyAccount": {
      "programCode": "BW",
      "accountId": "1234567890123457"
    },
    "corpAccount": {
      "corpProgramCode": "CR",
      "corpId": "A-1232"
    },
    "promoteCode": "string",
    "guests": [
      {
        "firstName": "Thomas",
        "lastName": "Hintz",
        "email": "[email protected]",
        "phone": "260-975-4091",
        "address": "3946 Freddy Locks",
        "age": 32,
        "gender": "Male",
        "birthday": "1990-01-01",
        "type": "Adult",
        "index": 1,
        "extensions": {
          "key1": "value1",
          "key2": "value2"
        }
      },
      {
        "firstName": "Hillary",
        "lastName": "Ullrich",
        "email": "[email protected]",
        "phone": "260-975-4091",
        "address": "3946 Freddy Locks",
        "age": 28,
        "gender": "Female",
        "birthday": "1994-01-01",
        "type": "Adult",
        "index": 1
      },
      {
        "firstName": "Alex",
        "lastName": "Hintz",
        "age": 5,
        "type": "Child",
        "index": 1
      }
    ],
    "comments": [
      "no smoking",
      "high floor"
    ],
    "roomRates": [
      {
        "roomId": "K1D",
        "rateId": "ODAD01",
        "currency": "USD",
        "amountBeforeTax": [
          100,
          100,
          120
        ],
        "amountAfterTax": [
          110,
          110,
          130
        ],
        "mealPlan": "RO",
        "paymentType": "PayNow",
        "guarantee": {
          "guaranteeType": "CCG"
        },
        "fees": [
          {
            "dateRange": {
              "startDate": "2018-01-01",
              "endDate": "2018-01-04"
            },
            "fee": {
              "name": "Service Charge",
              "type": "Exclusive",
              "amount": 10,
              "amountType": "Percent",
              "chargeType": "PerRoomPerNight",
              "paymentType": "PayNow",
              "effectivePerson": 0
            }
          }
        ],
        "cancelPolicy": {
          "code": "AD100P_100P",
          "description": "Non Refundable",
          "cancelPenalties": [
            {
              "noShow": true,
              "cancellable": true,
              "cancelDeadline": {
                "offsetTimeDropType": "BeforeArrival",
                "offsetTimeUnit": "D",
                "offsetTimeValue": 0,
                "deadline": "string"
              },
              "penaltyCharge": {
                "chargeBase": "FullStay",
                "nights": 0,
                "amount": 0,
                "percent": 0
              }
            }
          ]
        }
      }
    ],
    "bookingChannel": "string",
    "productAddons": [
      {
        "type": "DisneyTicket",
        "code": "code",
        "date": "2018-01-01",
        "quantity": 1,
        "officeId": "string",
        "rate": {
          "ageQualifyingType": {
            "type": "Adult",
            "minAge": 18,
            "maxAge": 99
          },
          "currency": "USD",
          "amountBeforeTax": 123.23,
          "amountAfterTax": 134.34
        }
      }
    ],
    "threeDomainSecurity": {
      "cavv": "string",
      "eci": "string",
      "xid": "string",
      "threeDomainSecurityVersion": "string",
      "transactionId": "string",
      "merchantName": "string",
      "channelCode": "EC",
      "exemptionType": "SC",
      "extensions": {
        "key1": "value1",
        "key2": "value2"
      }
    },
    "bookingToken": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c",
    "extensions": {
      "key1": "value1",
      "key2": "value2"
    }
  }

Request Specification

Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

Max Length: 32

The ID of the hotel supplier in DerbySoft's system

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of distributor in DerbySoft's system

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify requests and responses, normally it should be UUID.

18393849028490234

reservationIds

 

Yes

 /

 /

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.

C2084DFL0

iata

string

No

IATA

 /

hotelId

string

Yes

Hotel ID in supplier's system

100001

stayRange

object

Yes

 /

 /

@checkin

string

Yes

Check-in, format with yyyy-MM-dd

2018-01-01

@checkout

string

Yes

Check out, format with yyyy-MM-dd

2018-01-04

contactPerson

object

Yes

 /

 /

@firstName

string

Yes

First Name

James

@lastName

string

Yes

Last Name

Bond

@email

string

No

Email

[email protected]

@phone

string

No

 /

 /

@address

string

No

 /

 /

roomCriteria

object

Yes

 /

 /

@roomCount

integer

Yes

Total room count per request

 /

@adultCount

integer

Yes

Adult count per room

 /

@childCount

integer

No

Child count per room

 /

@childAges

array

No

For child ages for each child, the array size MUST be the same as the child count.

 /

total

object

Yes

 /

 /

@amountBeforeTax

number

No

abbr. ABT

It's required if AAT is not provided

640

@amountAfterTax

number

No

abbr. AAT

It's required if ABT is not provided

700

payment

 /

No

 /

 /

@cardCode

string

Yes

VI, MC, AX, etc.

Card Code

VI

@cardNumber

string

Yes

Credit card number

4111111111111111

@cardHolderName

string

Yes

Cardholder name

Sherlock Holmes

@expireDate

string

Yes

It should be 2 digits for the month, 2 digits for the year, as "MMYY"

0119

@securityCodestringNo

Card verification value

123

loyaltyAccount

object

No

 /

 /

@programCode

string

Yes

Loyalty program code of the supplier

BW

@accountId

string

Yes

Loyalty program account ID

1234567890123457

corpAccount

object

No

 /

 /

@corpProgramCode

string

Yes

Corporate Hotel Program of hotel supplier

CR

@corpId

string

Yes

Corporate ID in the program account

A-1232

promoteCode

string

No

Promotion code defined by the hotel, the promotion code is required if making a reservation under the promotion

 /

guests

array[object]

Yes

 /

 

@firstName

string

Yes

First Name

James/

@lastName

string

Yes

Last Name

Bond

@email

string

No

Email

[email protected]

@phone

string

No

 /

 /

@address

string

No

 /

 /

@age

integer

No

Age of guest

 /

@genderenumNoGender of guest
Enum: [Male, Female]
Male
@birthdaystringNoBirthday of guest
format with yyyy-MM-dd
1970-12-20

@type

string

No

Type of guest, Adult, Child, or Infant

Enum: [ Adult, Child, Infant ]

 /

@index

integer

No

Indicate which guests will be allocated to which room.

 

For one room reservation, the room index is 1 for all guests.

For multi-room reservations, the index starts from 1 and the max room index is equal to the number of booked rooms. 

index = 1, Indicate the guest will allocate to the first room.

index = 2, Indicate the guest will allocate to the second room.

@extensions

objectNoOptional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format).
/

comments

array[string]

No

 /

[ "no smoking", "high floor" ]

roomRates

array[object]

Yes

Min Items: 1 Max Items: 1

Meal plan, fee, and cancel policy are optional fields as some distributors do not support these in the API

 /

@roomId

string

Yes

Room ID in supplier's system

10000101

@rateId

string

Yes

Rate ID in supplier's system

123456

@currency

string

Yes

Currency code [ISO-4217]

USD

@amountBeforeTax

array[number]

No

abbr. ABT
The daily amount of rate without tax and fee.

It's required if AAT is not provided

[ 100, 100, 120 ]

@amountAfterTax

array[number]

No

abbr. AAT

The daily amount of rate with tax and fee.
It's required if ABT is not provided

[ 110, 110, 130 ]

@mealPlan

string

No

Meal plan code, refer to the standard meal plan code list.

RO

@paymentType

enum

No

Indicates the product is prepaid to hotel (PayNow) or pay at hotel (PayLater).
Enum: [ PayLater, PayNow ]

PayNow

roomRates/guarantee

object

No

Guarantee information for this room rate.

 /

@guaranteeType

string

Yes

The type of guarantee method, refer to the standard guarantee type list.

CCG

roomRates/fees

array[object]

No

Fee or tax by date range.

 /

fees/dateRange

object

Yes

 /

 /

@startDate

string

Yes

Start date of date range, format with yyyy-MM-dd

2018-01-01

@endDate

string

Yes

End date of date range, format with yyyy-MM-dd

2018-01-04

fees/fee

 

Yes

 /

 /

@name

string

Yes

Pattern: \w[\w\d]+

Service Charge

@type

enum

Yes

The fee or tax is included in the amount before tax or not

Enum: [ Inclusive, Exclusive ]

Exclusive

@amount

number

Yes

Amount value of fee or tax

10

@amountType

string

Yes

Indicates how to charge the tax, 10% per room per night in this example

Enum: [ Fix, Percent ]

Percent

@chargeType

string

Yes

Enum: [ PerRoomPerNight, PerPersonPerNight, PerRoomPerStay, PerPersonPerStay ]

PerRoomPerNight

@paymentType

enum

No

Indicates the fee is prepaid to the hotel (PayNow) or pay at the hotel (PayLater).

Enum: [ PayLater, PayNow ]

PayNow

@effectivePerson

number

No

It indicates the fee will be charged starting from which occupancy, such as the "Extra Person Charge" fee. The EffectivePerson is 3, meaning an extra fee will be applied from the third person onward.

 /

roomRates/cancelPolicy

object

No

Cancellation policy defines what penalty will be a charge when a guest cancels the booking at a certain advance time range. The penalty is related to No-show or a time range before No-show.

 /

@code

string

 Yes

Max Length: 128

code of cancel policy

AD100P_100P

@description

string

 No

Max Length: 1024

the description of the cancellation policy

Non Refundable

cancelPolicy/cancelPenalties

 

Yes

Detail about the cancel Penalty

 /

@noShow

boolean

Yes

If true, it means the penaltyCharge applied for No-Show, and the cancellable, cancelDeadline will NOT exist

 /

@cancellable

boolean

No

Indicates cancel is allowed or not. If false, it cannot be canceled. If true, the cancelDeadline will exist.

 /

cancelPenalties/cancelDeadline

 /

 /

 /

 /

@offsetTimeDropType

enum

No

Enum: [ BeforeArrival ]

An enumerated type indicates when the deadline drop time goes into effect.

 /

@offsetTimeUnit

enum

No

Enum: [ D, H ]

 

 /

@offsetTimeValue

number

No

The number of offset times with the time unit

 /

@deadline

string

No

Local deadline times allowed for cancellation, like 4 PM, or 6 PM

 /

cancelPenalties/penaltyCharge

 /

 /

 /

 /

@chargeBase

enum

No

Enum: [ FullStay, NightBase ]

If FullStay, it will be a percentage or amount, if NightBase, the nights are required.

 /

@nights

number

No

It exists if the penalty charge is based on the night, like the first night.

 /

@amount

number

No

It exists if the penalty charge is a flat charge, like USD 30.00.

 /

@percent

number

No

It exists if the penalty charge is percent, like 15.5 means 15.5%.

 /

bookingChannelstringNoSub-distributor ID/
productAddonsarray[object]No//
@typestringYesproduct addon type/
@codestringYesproduct addon code/
@datestringYesformat with yyyy-MM-dd2022-01-01
@quantityintegerYes/1
@officeIdstringNo//
productAddons/rateobjectNo//
rate/ageQualifyingTypeobjectNo//
@typeenumYesEnum: [Adult, Child]Adult
@minAgestringYes/18
@maxAgeintegerYes/18
rate/currencystringYes/USD
rate/amountBeforeTaxnumberNo/123.23
rate/amountAfterTaxnumberNo/134.34

threeDomainSecurity

object

No

 /

 /

@cavv

string

No

Cardholder Authentication Verification Value Information is retrieved from the 3DS provider when authentication is successful.

 /

@eci

string

No

The electronic commerce indicator.

 /

@xid

string

No

Transaction identifier for a 3DS Version 1 provider, assigned by the Directory Server to identify a single transaction.

 /

@threeDomainSecurityVersion

string

No

Include this only for 3D Secure 2.

 /

@transactionId

string

No

Transaction identifier for a 3DS Version 2 provider, assigned by the Directory Server to identify a single transaction.

 /

@merchantName

string

No

Identifier of the merchant completing the 3DS transaction.

 /

@channelCodeenumNoSpecify the collection channel of payment cards
Enum: [TO, EC, MO, FA]
Refer to:
PSD2-Channel Code
EC
@exemptionTypeenumNoDetermines which exemption was used by the Payment Service Provider (PSP)
Enum: [SC, DA, TA, TB, LV]
Refer to:
PSD2-Exemption Type
SC

bookingToken

string

Yes

Booking token used for booking

/

extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

 /


Response Example

  • Success Response (HTTP Status 200)
{
    "header": {
      "supplierId": "HILTON",
      "distributorId": "GTA",
      "version": "v4",
      "token": "18393849028490234"
    },
    "reservationIds": {
      "distributorResId": "C2084DFL0",
      "derbyResId": "D15F893D34DF",
      "supplierResId": "89389494"
    },
    "extensions": {
      "key1": "value1",
      "key2": "value2"
    }
  }
  • Successful Response from Exchange Connection and RETAIL Rate Model(HTTP Status 200)

{
    "header": {
      "supplierId": "HILTON",
      "distributorId": "GTA",
      "version": "v4",
      "token": "18393849028490234"
    },
    "reservationIds": {
      "distributorResId": "C2084DFL0",
      "derbyResId": "D15F893D34DF",
      "supplierResId": "89389494"
    },
    "connectionType": "Exchange",
    "commission": {
      "value": 10,
      "type": "percentage"
    },
    "extensions": {
      "key1": "value1",
      "key2": "value2"
    }
  }
  • Successful Response from Exchange Connection and NET Rate Model(HTTP Status 200)

{
    "header": {
      "supplierId": "HILTON",
      "distributorId": "GTA",
      "version": "v4",
      "token": "18393849028490234"
    },
    "reservationIds": {
      "distributorResId": "C2084DFL0",
      "derbyResId": "D15F893D34DF",
      "supplierResId": "89389494"
    },
    "connectionType": "Exchange",
    "suggestedTotalPrice": {
      "amountBeforeTax": 600,
      "amountAfterTax": 700
    },
    "extensions": {
      "key1": "value1",
      "key2": "value2"
    }
  }
  • Error Response (HTTP Status 403)

{
    "error": "Key not authorized"
}
  • Error Response (HTTP Status 500)
{
    "errorCode": "string",
    "supplierErrorCode": "string",
    "errorMessage": "string"
}

Response Specification

Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

Max Length: 32

The ID of the hotel supplier in DerbySoft's system

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify requests and responses, normally it should be UUID.

18393849028490234

reservationIds

 

Yes

 /

 /

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.

C2084DFL0

@derbyResId

string

No

Reservation ID in DerbySoft system, this is a unique ID as DerbySoft would be splitting the reservation.

D15F893D34DF

@supplierResId

string

No

Reservation ID in supplier's system

89389494

connectionTypeenumNo

Enum: [Exchange, Standard]

Indicates the connection type of product. 

Notes: If the field is omitted, it means the Connection Type is Standard.

Exchange
commissionobjectNoNotes: If the connection type is "Exchange" and "RETAIL" Rate Model, the node will be visible; otherwise, it will not appear.
/
@valuenumberYes/
10
@typeenumYes

Commission type

Enum: [percentage, amount]

percentage
suggestedTotalPrice
objectNoNotes: If the connection type is "Exchange" and "NET" Rate Model, the node will be visible; otherwise, it will not appear.
/
@amountBeforeTax
numberNo/600
@amountAfterTax
numberNo/700

extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

 /


Modify

Distributors utilize this API to make changes to an existing booking. Upon calling the hotel supplier system, a real-time confirmation will be obtained. In cases where the hotel supplier cannot facilitate modifications, the process will involve canceling the booking and rebooking it. 

POST /reservation/modify HTTP/1.1
URL: {endpoint}/reservation/modify
Authorization:Bearer 53ac07777cdffac2d53000002d698728ce964432d7167596bc005c5fc
Accept-Encoding: gzip
Content-Encoding: gzip
Content-Type: application/json;charset=utf-8

Request Example

{
    "header": {
      "supplierId": "HILTON",
      "distributorId": "GTA",
      "version": "v4",
      "token": "18393849028490234"
    },
    "reservationIds": {
      "distributorResId": "C2084DFL0",
      "derbyResId": "D15F893D34DF",
      "supplierResId": "89389494"
    },
    "iata": "string",
    "hotelId": "GATHI",
    "stayRange": {
      "checkin": "2018-01-01",
      "checkout": "2018-01-04"
    },
    "contactPerson": {
      "firstName": "Thomas",
      "lastName": "Hintz",
      "email": "[email protected]",
      "phone": "260-975-4091",
      "address": "3946 Freddy Locks"
    },
    "roomCriteria": {
      "roomCount": 1,
      "adultCount": 2,
      "childCount": 1,
      "childAges": [
        5
      ]
    },
    "total": {
      "amountBeforeTax": 640,
      "amountAfterTax": 700
    },
    "payment": {
      "cardCode": "VI",
      "cardNumber": "4111111111111111",
      "cardHolderName": "Sherlock Holmes",
      "expireDate": "0119",
      "securityCode": "123"
    },
    "loyaltyAccount": {
      "programCode": "BW",
      "accountId": "1234567890123457"
    },
    "corpAccount": {
      "corpProgramCode": "CR",
      "corpId": "A-1232"
    },
    "promoteCode": "string",
    "guests": [
      {
        "firstName": "Thomas",
        "lastName": "Hintz",
        "email": "[email protected]",
        "phone": "260-975-4091",
        "address": "3946 Freddy Locks",
        "age": 32,
        "gender": "Male",
        "birthday": "1990-01-01",
        "type": "Adult",
        "index": 1
      },
      {
        "firstName": "Hillary",
        "lastName": "Ullrich",
        "email": "[email protected]",
        "phone": "260-975-4091",
        "address": "3946 Freddy Locks",
        "age": 28,
        "gender": "Female",
        "birthday": "1994-01-01",
        "type": "Adult",
        "index": 1,
        "extensions": {
          "key1": "value1",
          "key2": "value2"
        }
      },
      {
        "firstName": "Alex",
        "lastName": "Hintz",
        "age": 5,
        "type": "Child",
        "index": 1
      }
    ],
    "comments": [
      "no smoking",
      "high floor"
    ],
    "roomRates": [
      {
        "roomId": "K1D",
        "rateId": "ODAD01",
        "currency": "USD",
        "amountBeforeTax": [
          100,
          100,
          120
        ],
        "amountAfterTax": [
          110,
          110,
          130
        ],
        "mealPlan": "RO",
        "paymentType": "PayNow",
        "guarantee": {
          "guaranteeType": "CCG"
        },
        "fees": [
          {
            "dateRange": {
              "startDate": "2018-01-01",
              "endDate": "2018-01-04"
            },
            "fee": {
              "name": "Service Charge",
              "type": "Exclusive",
              "amount": 10,
              "amountType": "Percent",
              "chargeType": "PerRoomPerNight",
              "paymentType": "PayNow",
              "effectivePerson": 0
            }
          }
        ],
        "cancelPolicy": {
          "code": "AD100P_100P",
          "description": "Non Refundable",
          "cancelPenalties": [
            {
              "noShow": true,
              "cancellable": true,
              "cancelDeadline": {
                "offsetTimeDropType": "BeforeArrival",
                "offsetTimeUnit": "D",
                "offsetTimeValue": 0,
                "deadline": "string"
              },
              "penaltyCharge": {
                "chargeBase": "FullStay",
                "nights": 0,
                "amount": 0,
                "percent": 0
              }
            }
          ]
        }
      }
    ],
    "bookingChannel": "string",
    "productAddons": [
      {
        "type": "DisneyTicket",
        "code": "code",
        "date": "2018-01-01",
        "quantity": 1,
        "officeId": "string",
        "rate": {
          "ageQualifyingType": {
            "type": "Adult",
            "minAge": 18,
            "maxAge": 99
          },
          "currency": "USD",
          "amountBeforeTax": 123.23,
          "amountAfterTax": 134.34
        }
      }
    ],
    "threeDomainSecurity": {
      "cavv": "string",
      "eci": "string",
      "xid": "string",
      "threeDomainSecurityVersion": "string",
      "transactionId": "string",
      "merchantName": "string",
      "channelCode": "EC",
      "exemptionType": "SC",
      "extensions": {
        "key1": "value1",
        "key2": "value2"
      }
    },
    "extensions": {
      "key1": "value1",
      "key2": "value2"
    }
  }

Request Specification

Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

Max Length: 32

The ID of the hotel's source is in DerbySoft's system.

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of the distributor in DerbySoft's system.

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify request and response, normally it should be UUID.

18393849028490234

reservationIds

 

Yes

 /

 /

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.

C2084DFL0

@derbyResId

string

Yes

Reservation ID in DerbySoft's system, it's a unique ID as DerbySoft would be splitting the reservation 

D15F893D34DF

@supplierResId

string

Yes

Reservation ID in supplier's system

89389494

iata

string

No

IATA

 /

hotelId

string

Yes

Hotel ID in supplier's system

100001

stayRange

object

Yes

 /

 /

@checkin

string

Yes

Check-in, format with yyyy-MM-dd

2018-01-01

@checkout

string

Yes

Check out, format with yyyy-MM-dd

2018-01-04

contactPerson

object

Yes

 /

 /

@firstName

string

Yes

First Name

James/

@lastName

string

Yes

Last Name

Bond

@email

string

No

Email

[email protected]

@phone

string

No

 /

 /

@address

string

No

 /

 /

@extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

{ "key": "value"}

roomCriteria

object

Yes

 /

 /

@roomCount

integer

Yes

Total room count per request

 /

@adultCount

integer

Yes

Adult count per room

 /

@childCount

integer

No

Child count per room

 /

@childAges

array

No

For child ages for each child, array size MUST be the same as the child count.

 /

total

object

Yes

 /

 /

@amountBeforeTax

number

No

 /

640

@amountAfterTax

number

No

 /

700

payment

 /

No

 /

 /

@cardCode

string

Yes

VI, MC, AX, etc.

Refer to Appendix: Credit Card Code

VI

@cardNumber

string

Yes

Credit card number

4111111111111111

@cardHolderName

string

Yes

Cardholder name

Sherlock Holmes

@expireDate

string

Yes

It should be 2 digits for the month, and 2 digits for the year, as "MMYY"

0119

@securityCodestringNoCard verification value123

loyaltyAccount

object

No

 /

 /

@programCode

string

Yes

Loyalty program code of the supplier

BW

@accountId

string

Yes

Loyalty program account ID

1234567890123457

corpAccount

object

No

 /

 /

@corpProgramCode

string

Yes

Corporate Hotel Program of hotel supplier

CR

@corpId

string

Yes

Corporate ID in the program account

A-1232

promoteCode

string

No

The promotion code is defined by the hotel, the promotion code is required if making a reservation under the promotion.

 /

guests

array[object]

Yes

 /

 /

@firstName

string

Yes

First Name

James

@lastName

string

Yes

Last Name

Bond

@email

string

No

Email

[email protected]

@phone

string

No

 /

 /

@address

string

No

 /

 /

@age

integer

No

Age of guest

 /

@genderenumNoGender of guest
Enum: [Male, Female]
/
@birthdaystringNoBirthday of guest/

@type

string

No

Type of guest: Adult, Child, or Infant.

Enum: [ Adult, Child, Infant ]

 /

@extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

{ "key": "value"}

@index

integer

No

Indicate which guests will be allocated to which room.

 

For one room reservation, the room index is 1 for all guests.

For multi-room reservations, the index starts from 1 and the max room index is equal to the number of booked rooms. 

index = 1, Indicate the guest will allocate to the first room.

index = 2, Indicate the guest will allocate to the second room.

@extensionsobjectNoOptional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format).

comments

array[string]

No

 /

[ "no smoking", "high floor" ]

roomRates

array[object]

Yes

Min Items: 1 max Item: 1

Meal plan, fee, and cancel policy are optional fields as some distributors do not support these in the API.

 /

@roomId

string

Yes

Room ID in supplier system

10000101

@rateId

string

Yes

Rate ID in supplier system

123456

@currency

string

Yes

currency code [ISO-4217]

USD

@amountBeforeTax

array[number]

No

The daily amount rate without tax and fee

[ 100, 100, 120 ]

@amountAfterTax

array[number]

No

The daily amount of rate with tax and fee

[ 110, 110, 130 ]

@mealPlan

string

No

Meal plan code, refer to the standard meal plan code list.

RO

@paymentType

enum

No

Indicates the product is prepaid to the hotel (PayNow) or pay at the hotel (PayLater).
Enum: [ PayLater, PayNow ]

PayNow

roomRates/guarantee

object

No

Guarantee information for this room rate

 /

@guaranteeType

string

Yes

The type of guarantee method, refer to the standard guarantee type list.

CCG

roomRates/fees

array[object]

No

Fee or tax by date range

 /

fees / dateRange

object

Yes

 /

 /

@startDate

string

Yes

Start date of date range, format with yyyy-MM-dd

2018-01-01

@endDate

string

Yes

End date of date range, format with yyyy-MM-dd

2018-01-04

fees/fee

 

Yes

 /

 /

@name

string

Yes

Pattern: \w[\w\d]+

Service Charge

@type

enum

Yes

Whether the fee or tax is included in the amount before tax or not

Enum: [ Inclusive, Exclusive ]

Exclusive

@amount

number

Yes

Amount value of fee or tax

10

@amountType

string

Yes

Indicates how to charge the tax, 10% per room per night in this example.

Enum: [ Fix, Percent ]

Percent

@chargeType

string

Yes

Enum: [ PerRoomPerNight, PerPersonPerNight, PerRoomPerStay, PerPersonPerStay ]

PerRoomPerNight

@paymentType

enum

No

Indicates the fee is prepaid to hotel (PayNow) or Pay at Hotel (PayLater)

Enum: [ PayLater, PayNow ]

PayNow

roomRates / cancelPolicy

object

No

The cancellation policy defines what penalty will be charged when a guest cancels the booking at a certain advance time range. The penalty is related to No-show or a time range before No-show.

 /

@code

string

 

Max Length: 128

Code of cancellation policy

AD100P_100P

@description

string

 

Max Length: 1024

the description of the cancellation policy

Non Refundable

bookingChannelstringNoSub-distributor ID

 /

productAddonsarray[object]No

@typestringYesproduct addon type
@codestringYesproduct addon code
@datestringYesformat with yyyy-MM-dd2022-01-01
@quantityintegerYes/1
@officeIdstringNo//
productAddons/rateobjectNo//
rate/ageQualifyingTypeobjectNo//
@typeenumYesEnum: [Adult, Child]Adult
@minAgeintegerYes/18
@maxAgeintegerYes/18
rate/currencystringYes/USD
rate/amountBeforeTaxnumberNo/123
rate/amountAfterTaxnumberYes/

threeDomainSecurity

object

No

 /

 /

@cavv

string

No

Cardholder Authentication Verification Value Information is retrieved from the 3DS provider when authentication is successful.

 /

@eci

string

No

The electronic commerce indicator.

 /

@xid

string

No

Transaction identifier for a 3DS Version 1 provider, assigned by the Directory Server to identify a single transaction.


 /

@threeDomainSecurityVersion

string

No

Include this only for 3D Secure 2.

 /

@transactionId

string

No

Transaction identifier for a 3DS Version 2 provider, assigned by the Directory Server to identify a single transaction.

 /

@merchantName

string

No

Identifier of the merchant completing the 3DS transaction.

 /

@channelCodeenumNoSpecify the collection channel of payment cards
Enum: [TO, EC, MO, FA]
Refer to: PSD2-Channel Code
EC
@exemptionTypeenumNoDetermines which exemption was used by the Payment Service Provider (PSP)
Enum: [SC, DA, TA, TB, LV]
Refer to: PSD2-Exemption Type
SC

@extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

 /


Response Example

  • Success Response (HTTP Status 200)
{
    "header": {
      "supplierId": "HILTON",
      "distributorId": "GTA",
      "version": "v4",
      "token": "18393849028490234"
    },
    "reservationIds": {
      "distributorResId": "C2084DFL0",
      "derbyResId": "D15F893D34DF",
      "supplierResId": "89389494"
    },
    "extensions": {
      "key": "value"
    }
  }
  • Successful Response from Exchange Connection and RETAIL Rate Model(HTTP Status 200)
{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "reservationIds": {
    "distributorResId": "C2084DFL0",
    "derbyResId": "D15F893D34DF",
    "supplierResId": "89389494"
  },
  "connectionType": "Exchange",
  "commission": {
    "value": 10,
    "type": "percentage"
  },
  "extensions": {
    "key1": "value1",
    "key2": "value2"
  }
}
  • Successful Response from Exchange Connection and NET Rate Model(HTTP Status 200)
{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "reservationIds": {
    "distributorResId": "C2084DFL0",
    "derbyResId": "D15F893D34DF",
    "supplierResId": "89389494"
  },
  "connectionType": "Exchange",
  "suggestedTotalPrice": {
    "amountBeforeTax": 600,
    "amountAfterTax": 700
  },
  "extensions": {
    "key1": "value1",
    "key2": "value2"
  }
}
  • Error Response (HTTP Status 403)
{
    "error": "Key not authorized"
}
  • Error Response (HTTP Status 500)
{
    "errorCode": "string",
    "supplierErrorCode": "string",
    "errorMessage": "string"
}

Response Specification


Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

Max Length: 32

The ID of hotel suppliers in DerbySoft's system.

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify requests and response, normally it should be UUID.

18393849028490234

reservationIds

object

Yes

 /

100001

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.

C2084DFL0

@derbyResId

string

Yes

Reservation ID in Derbysoft's system, it's a unique ID as DerbySoft would be splitting the reservation.

D15F893D34DF

@supplierResId

string

Yes

Reservation ID in supplier's system

89389494

connectionTypeenumNo

Enum: [Exchange, Standard]

Indicates the connection type of product. 

Notes: If the field is omitted, it means the Connection Type is Standard.

Exchange
commission
objectNoNotes: If the connection type is "Exchange" and "RETAIL" Rate Model, the node will be visible; otherwise, it will not appear.
/
@valuenumberYes/10
@typeenumYes

Commission type

Enum: [percentage, amount]

percentage
suggestedTotalPrice
objectNoNotes: If the connection type is "Exchange" and "NET" Rate Model, the node will be visible; otherwise, it will not appear.
/
@amountBeforeTaxnumberNo
/600
@amountAfterTaxnumberYes
/700

extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

 /


Cancel

This is an API for DerbySoft to call suppliers' systems to cancel a booking. Since DerbySoft does splitting on original reservations, the supplier should cancel the reservation by unique derbyResId or supplierResId.

POST /reservation/cancel HTTP/1.1
URL: {endpoint}/reservation/cancel
Authorization: Bearer 53ac07777cdffac2d53000002d698728ce964432d7167596bc005c5fc
Accept-Encoding: gzip
Content-Encoding: gzip
Content-Type: application/json;charset=utf-8

Request Example

{
    "header": {
        "supplierId": "HILTON",
        "distributorId": "GTA",
        "version": "v4",
        "token": "18393849028490234"
    },
    "reservationIds": {
        "distributorResId": "C2084DFL0",
        "derbyResId": "D15F893D34DF",
        "supplierResId": "89389494"
    },
    "extensions": {
        "key1": "value1",
        "key2": "value2"
    }
}

Request Specification

Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

Max Length: 32

The ID of hotel supplier in DerbySoft's system.

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of the distributor in DerbySoft's system.

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify requests and responses, normally it should be UUID.

18393849028490234

reservationIds

object

Yes

 /

 /

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.

C2084DFL0

@derbyResId

string

No

Reservation ID in Derbysoft's system, it's a unique ID as DerbySoft would be splitting the reservation.

D15F893D34DF

@supplierResId

string

No

Reservation ID in supplier's system

89389494

extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format). Please don't transmit sensitive information through this field. For more information refer to:

Sensitive Information

{"key": "value"}

Response Example

  • Success Response (HTTP Status 200)
{
    "header": {
        "supplierId": "HILTON",
        "distributorId": "GTA",
        "version": "v4",
        "token": "18393849028490234"
    },
    "reservationIds": {
        "distributorResId": "C2084DFL0",
        "derbyResId": "D15F893D34DF",
        "supplierResId": "89389494"
    },
    "cancellationId": "C89389494",
    "extensions": {
        "key1": "value1",
        "key2": "value2"
    }
}
  • Error Response (HTTP Status 403)
{
    "error": "Key not authorized"
} 
  • Error Response (HTTP Status 500)
{
  "errorCode": "string",
  "supplierErrorCode": "string",
  "errorMessage": "string"
}

Response Specification

Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

Max Length: 32

The ID of hotel suppliers is in DerbySoft's system.

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify requests and responses, normally it should be UUID.

18393849028490234

reservationIds

object

Yes

 /

100001

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.

C2084DFL0

@derbyResId

string

Yes

Reservation ID in Derbysoft's system, It's a unique ID as DerbySoft would be splitting the reservation.

D15F893D34DF

@supplierResId

string

Yes

Reservation ID in supplier's system

89389494

cancellationId

string

Yes

Cancellation confirmation number in supplier's system

C89389494

extensions

object

No

Optional: Additional agreed-upon attributes between suppliers and distributors (DerbySoft will provide the specified format)

 /


Query Reservations

This is an API to query a reservation list in DerbySoft's system and supplier's system with a timestamp range of the reservation's last modified date. It should be implemented by both DerbySoft and the supplier.
POST /reservations HTTP/1.1
URL: {endpoint}/reservations
Authorization: Bearer 53ac07777cdffac2d53000002d698728ce964432d7167596bc005c5fc
Accept-Encoding: gzip
Content-Encoding: gzip
Content-Type: application/json;charset=utf-8

Request Example

{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "dateRange": {
    "startDate": "2018-01-01",
    "endDate": "2018-01-04"
  },
  "hotelId": "GATHI"
}

Request Specification

Attribute

Type

Required

Description

Example

header

object

Yes

 /

 

@supplierId

string

Yes

Max Length: 32

The ID of the hotel supplier in DerbySoft's system

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify requests and responses, normally it should be a UUID.

18393849028490234

dateRange

 /

 /

Date range of last modified date of reservation

 /

@startDate

string

Yes

Start date of date range

Format: yyyy-MM-dd

2018-01-01

@endDate

string

Yes

End date of the date range

Format: yyyy-MM-dd

2018-01-04

hotelId

string

No

Supplier hotel ID in DerbySoft's system

GATHI


Response Example

  • Success Response (HTTP Status 200)
{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "reservations": [
    {
      "reservationIds": {
        "distributorResId": "C2084DFL0",
        "derbyResId": "D15F893D34DF",
        "supplierResId": "89389494"
      },
      "iata": "string",
      "hotelId": "GATHI",
      "stayRange": {
        "checkin": "2018-01-01",
        "checkout": "2018-01-04"
      },
      "roomCriteria": {
        "roomCount": 2,
        "adultCount": 1,
        "childCount": 2,
        "childAges": [
          4,
          8
        ]
      },
      "total": {
        "amountBeforeTax": 640,
        "amountAfterTax": 700
      },
      "status": "Confirmed",
      "cancellationId": "C89389494",
      "result": "Successful",
      "failCause": {
        "errorCode": "string",
        "supplierErrorCode": "string",
        "errorMessage": "string"
      }
    }
  ]
}
  • Successful Response from Exchange Connection and RETAIL Rate Model(HTTP Status 200)
{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "reservations": [
    {
      "reservationIds": {
        "distributorResId": "C2084DFL0",
        "derbyResId": "D15F893D34DF",
        "supplierResId": "89389494"
      },
      "iata": "string",
      "hotelId": "GATHI",
      "stayRange": {
        "checkin": "2018-01-01",
        "checkout": "2018-01-04"
      },
      "contactPerson": {
        "firstName": "James",
        "lastName": "Bond",
        "email": "[email protected]",
        "phone": "string",
        "address": "string"
      },
      "roomCriteria": {
        "roomCount": 2,
        "adultCount": 1,
        "childCount": 2,
        "childAges": [
          4,
          8
        ]
      },
      "connectionType": "Exchange",
      "total": {
        "amountBeforeTax": 640,
        "amountAfterTax": 700
      },
      "commission": {
        "value": 10,
        "type": "percentage"
      },
      "status": "Confirmed",
      "cancellationId": "C89389494",
      "result": "Successful"
    }
  ]
}
  • Successful Response from Exchange Connection and NET Rate Model(HTTP Status 200)
{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "reservations": [
    {
      "reservationIds": {
        "distributorResId": "C2084DFL0",
        "derbyResId": "D15F893D34DF",
        "supplierResId": "89389494"
      },
      "iata": "string",
      "hotelId": "GATHI",
      "stayRange": {
        "checkin": "2018-01-01",
        "checkout": "2018-01-04"
      },
      "contactPerson": {
        "firstName": "James",
        "lastName": "Bond",
        "email": "[email protected]",
        "phone": "string",
        "address": "string"
      },
      "roomCriteria": {
        "roomCount": 2,
        "adultCount": 1,
        "childCount": 2,
        "childAges": [
          4,
          8
        ]
      },
      "connectionType": "Exchange",
      "total": {
        "amountBeforeTax": 640,
        "amountAfterTax": 700
      },
      "suggestedTotalPrice": {
        "amountBeforeTax": 600,
        "amountAfterTax": 700
      },
      "status": "Confirmed",
      "cancellationId": "C89389494",
      "result": "Successful"
    }
  ]
}
  • Error Response (HTTP Status 403)
{
    "error": "Key not authorized"
}
  • Error Response (HTTP Status 500)
{
  "errorCode": "InvalidField",
  "errorMessage": "Invalid Message"
}

Response Specification

Attribute

Type

Required

Description

Example

header

object

Yes

 /

 /

@supplierId

string

Yes

Max Length: 32

The ID of hotel supplier in DerbySoft's system

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify requests and responses, normally it should be UUID.

18393849028490234

reservations

array[object]

No

 /

 /

reservations/reservationIds

object

No

 /

 /

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.

C2084DFL0

@derbyResId

string

Yes

Reservation ID in Derbysoft's system, this is a unique ID as DerbySoft would be splitting the reservation.

D15F893D34DF

@supplierResId

string

Yes

Reservation ID in supplier's system

89389494

@iata

string

No

 /

 /

@hotelId

string

Yes

Hotel ID in supplier’s system

100001

reservations/stayRange

object

Yes

 /

 /

@checkin

string

Yes

Check-in, format with yyyy-MM-dd

2018-01-01

@checkout

string

Yes

Check out, format with yyyy-MM-dd

2018-01-04

reservations/roomCriteria

object

Yes

 /

 

@roomCount

integer

Yes

Total room count per request

 

@adultCount

integer

Yes

Adult count per room

 

@childCount

integer

No

Child count per room

 

@childAges

array

No

For child ages for each child, array size MUST be the same as the child count.

 [ 4, 8 ]

reservations/connectionType
enumNo

Enum: [Exchange, Standard]

Indicates the connection type of product. 

Notes: If the field is omitted, it means the Connection Type is Standard.

Exchange

reservations/total

object

Yes

 /

 /

@amountBeforeTax

number

No

 /

640

@amountAfterTax

number

No

 /

700

reservations/commissionobjectNoNotes: If the connection type is "Exchange" and "RETAIL" Rate Model, the node will be visible; otherwise, it will not appear.
/
@valuenumberYes/10
@typeenumYes

Commission type

Enum: [percentage, amount]

percentage
reservations/suggestedTotalPrice
objectNoNotes: If the connection type is "Exchange" and "NET" Rate Model, the node will be visible; otherwise, it will not appear.
/
@amountBeforeTaxnumberNo/600
@amountAfterTaxnumberNo/700

@status

enum

Yes

Enum: [ Confirmed, Modified, Cancelled ]

Status of reservation

 /

cancellationId

string

No

Cancel confirmation number in supplier's system

C89389494

@result

enum

Yes

Enum: [ Successful, Failed, Processing ]

Status of the reservation to send to supplier

 /

reservations/failCause

object

No

Note: If the reservation fails, the node will be visible; otherwise, it will not appear.

 /

@errorCode

string

Yes

Refer to Error Code Appendix

 /

@supplierErrorCode

string

No

Error code from the supplier's system

 /

@errorMessage

string

Yes

Error message

 /


Query Reservation Detail

This API is used by distributors to query existing bookings. It can be used to check the reservation status of some timeout booking requests.

POST /reservation/detail HTTP/1.1
Authorization: Bearer 53ac07777cdffac2d53000002d698728ce964432d7167596bc005c5fc
Accept-Encoding: gzip
Content-Encoding: gzip
Content-Type: application/json;charset=utf-8

Request Example

{
  "header": {
    "supplierId": "HILTON",
    "distributorId": "GTA",
    "version": "v4",
    "token": "18393849028490234"
  },
  "reservationIds": {
    "distributorResId": "C2084DFL0",
    "derbyResId": "D15F893D34DF",
    "supplierResId": "89389494"
  }
}

Request Specification


AttributeTypeRequiredDescriptionExample

header

object

Yes

 /

 /

@supplierId

string

Yes

Max Length: 32

The ID of the hotel supplier in DerbySoft's system.

HILTON

@distributorId

string

Yes

Max Length: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

Max Length: 20

Version of API

v4

@token

string

Yes

Max Length: 64

A unique ID to identify requests and responses, normally it should be UUID.

18393849028490234

reservationIds

object

Yes

 /

 /

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.

C2084DFL0

@derbyResId

string

No

Reservation ID in Derbysoft's system, it's a unique ID as DerbySoft would be splitting the reservation.

D15F893D34DF

@supplierResId

string

No

Reservation ID in supplier's system

89389494


Response Example

  • Success Response (HTTP Status 200)
{
    "header": {
        "supplierId": "HILTON",
        "distributorId": "GTA",
        "version": "v4",
        "token": "18393849028490234"
    },
    "reservations": [
        {
            "reservationIds": {
                "distributorResId": "C2084DFL0",
                "derbyResId": "D15F893D34DF",
                "supplierResId": "89389494"
            },
            "iata": "string",
            "hotelId": "GATHI",
            "stayRange": {
                "checkin": "2018-01-01",
                "checkout": "2018-01-04"
            },
            "roomCriteria": {
                "roomCount": 2,
                "adultCount": 1,
                "childCount": 2,
                "childAges": [
                    4,
                    8
                ]
            },
            "connectionType": "Exchange",
            "total": {
                "amountBeforeTax": 640,
                "amountAfterTax": 700
            },
            "commission": {
                "value": 10,
                "type": "percentage"
            },
            "suggestedTotalPrice": {
                "amountBeforeTax": 600,
                "amountAfterTax": 700
            },
            "loyaltyAccount": {
                "programCode": "BW",
                "accountId": "1234567890123457"
            },
            "corpAccount": {
                "corpProgramCode": "CR",
                "corpId": "A-1232"
            },
            "promoteCode": "string",
            "comments": [
                "no smoking",
                "high floor"
            ],
            "roomRates": [
                {
                    "roomId": "K1D",
                    "rateId": "ODAD01",
                    "currency": "USD",
                    "amountBeforeTax": [
                        100,
                        100,
                        120
                    ],
                    "amountAfterTax": [
                        110,
                        110,
                        130
                    ],
                    "mealPlan": "RO",
                    "paymentType": "PayNow",
                    "guarantee": {
                        "guaranteeType": "CCG"
                    },
                    "fees": [
                        {
                            "dateRange": {
                                "startDate": "2018-01-01",
                                "endDate": "2018-01-04"
                            },
                            "fee": {
                                "name": "Service Charge",
                                "type": "Exclusive",
                                "amount": 10,
                                "amountType": "Percent",
                                "chargeType": "PerRoomPerNight",
                                "paymentType": "PayNow",
                                "effectivePerson": 0
                            }
                        }
                    ],
                    "cancelPolicy": {
                        "code": "AD100P_100P",
                        "description": "Non Refundable",
                        "cancelPenalties": [
                            {
                                "noShow": true,
                                "cancellable": true,
                                "cancelDeadline": {
                                    "offsetTimeDropType": "BeforeArrival",
                                    "offsetTimeUnit": "D",
                                    "offsetTimeValue": 0,
                                    "deadline": "string"
                                },
                                "penaltyCharge": {
                                    "chargeBase": "FullStay",
                                    "nights": 0,
                                    "amount": 0,
                                    "percent": 0
                                }
                            }
                        ]
                    }
                }
            ],
            "bookingChannel": "string",
            "productAddons": [
                {
                    "type": "DisneyTicket",
                    "code": "code",
                    "date": "2018-01-01",
                    "quantity": 1,
                    "officeId": "string",
                    "rate": {
                        "ageQualifyingType": {
                            "type": "Adult",
                            "minAge": 18,
                            "maxAge": 18
                        },
                        "currency": "USD",
                        "amountBeforeTax": 123.23,
                        "amountAfterTax": 134.34
                    }
                }
            ],
            "status": "Confirmed",
            "cancellationId": "C89389494",
            "result": "Successful",
            "failCause": {
                "errorCode": "string",
                "supplierErrorCode": "string",
                "errorMessage": "string"
            }
        }
    ]
}
  • Error Response (HTTP Status 403)
{
    "error": "Key not authorized"
}
  • Error Response (HTTP Status 500)
{
  "errorCode": "InvalidField",
  "errorMessage": "Invalid Message"
}

Response Specification

AttributeTypeRequiredDescriptionExample

header

object

Yes

 /

 /

@supplierId

string

Yes

MaxLength: 32

The ID of the hotel supplier in DerbySoft's system

HILTON

@distributorId

string

Yes

MaxLength: 32

The ID of the distributor in DerbySoft's system

GTA

@version

string

Yes

MaxLength: 20

version of API

v4

@token

string

Yes

MaxLength: 64

A unique ID to identify request and response, normally it should be UUID.

18393849028490234

reservations

array[object]

No

 /

 /

reservationIds

object

No

 /

 /

@distributorResId

string

Yes

Distributor's reservation ID. Distributors should keep the ID unique on their system to avoid any potential issues caused by duplicate reservation IDs.

C2084DFL0

@derbyResId

string

Yes

Reservation ID in DerbySoft system, This is a unique ID as DerbySoft would be splitting the reservation.

D15F893D34DF

@supplierResId

string

Yes

Reservation ID in supplier's system

89389494

iata

string

No

 /

 /

hotelId

string

Yes

Hotel ID in supplier’s system

100001

stayRange

object

Yes

 /

 /

@checkin

string

Yes

Check-in, format with yyyy-MM-dd

2018-01-01

@checkout

string

Yes

Check out, format with yyyy-MM-dd

2018-01-04

roomCriteria

object

Yes

 /

 /

@roomCount

integer

Yes

Total room count per request

 /

@adultCount

integer

Yes

Adult count per room

 /

@childCount

integer

No

Child count per room

 

@childAges

array

No

For child ages each child, the array size MUST be the same as the child count.

 /

connectionType
enumNo

Enum: [Exchange, Standard]

Indicates the connection type of product. 

Notes: If the field is omitted, it means the Connection Type is Standard.

Exchange

total

object

Yes

 /

 /

@amountBeforeTax

number

No

 /

640

@amountAfterTax

number

No

 /

700

commission
objectNoNotes: If the connection type is "Exchange" and "RETAIL" Rate Model, the node will be visible; otherwise, it will not appear.
/
@valuenumberNo/10
@typeenumNo

Commission type

Enum: [percentage, amount]

percentage
suggestedTotalPrice
objectNoNotes: If the connection type is "Exchange" and "NET" Rate Model, the node will be visible; otherwise, it will not appear.
/
@amountBeforeTaxnumberNo/600
@amountAfterTaxnumber
No/700

loyaltyAccount

object

No

 /

 /

@programCode

string

Yes

The loyalty program code of the supplier

BW

@accountId

string

Yes

Loyalty program account ID

1234567890123457

corpAccount

object

No

 /

 /

@corpProgramCode

string

Yes

Corporate Hotel Program of hotel supplier

CR

@corpId

string

Yes

Corporate ID in the program account

A-1232

promoteCode

string

No

The promotion code is defined by the hotel, the promotion code is required if making a reservation under the promotion.

 /

comments

array[string]

No

 /

[ "no smoking", "high floor" ]

roomRates

array[object]

Yes

Min Items: 1 Max Item: 1

Meal plan, fee, and cancel policy are optional fields as some distributors do not support these in the API.

 /

@roomId

string

Yes

Room ID in supplier's system

10000101

@rateId

string

Yes

Rate ID in supplier's system

123456

@currency

string

Yes

Currency code [ISO-4217]

USD

@amountBeforeTax

array[number]

No

The daily amount rate without tax and fee

[ 100, 100, 120 ]

@amountAfterTax

array[number]

No

The daily amount of rate with tax and fee

[ 110, 110, 130 ]

@mealPlan

string

No

Meal plan code, refer to the standard meal plan code list.

RO

@paymentType

enum

No

Indicates the product is prepaid to the hotel (PayNow) or pay at the hotel (PayLater).
Enum: [ PayLater, PayNow ]

PayNow

roomRates/guarantee

object

No

Guarantee information for this room rate.

 /

@guaranteeType

string

Yes

The type of guarantee method, refers to the standard guarantee type list.

CCG

roomRates/fees

array[object]

No

Fee or tax by date range.

 /

fees/dateRange

object

Yes

 /

 /

@startDate

string

Yes

Start date of date range, format with yyyy-MM-dd

2018-01-01

@endDate

string

Yes

End date of date range, format with yyyy-MM-dd

2018-01-04

fees/fee

object

Yes

 /

 /

@name

string

Yes

Pattern: \w[\w\d]+

Service Charge

@type

enum

Yes

Indicates if the fee or tax is included in the amount before tax or not.

Enum: [ Inclusive, Exclusive ]

Exclusive

@amount

number

Yes

Amount value of fee or tax

10

@amountType

string

Yes

Indicates how to charge the tax, 10% per room per night in this example

Enum: [ Fix, Percent ]

Percent

@chargeType

string

Yes

Enum: [ PerRoomPerNight, PerPersonPerNight, PerRoomPerStay, PerPersonPerStay ]

PerRoomPerNight

@paymentType

enum

No

Indicates the fee is prepaid to the hotel (PayNow) or pay at the hotel (PayLater).

Enum: [ PayLater, PayNow ]

PayNow

@effectivePerson

number

 

It indicates the fee will be charged starting from which occupancy, such as the "Extra Person Charge" fee. The EffectivePerson is 3, meaning an extra fee will be applied from the third person onward.

 /

roomRates/cancelPolicy

object

No

Cancellation policy defines what penalty will be charged when a guest cancels the booking at a certain advance time range. 

The penalty is related to No-show or a time range before No-show.

 /

@code

string

 

Max Length: 128

Code of cancel policy

AD100P_100P

@description

string

 

Max Length: 1024

The description of the cancellation policy

Non Refundable

cancelPolicy/cancelPenalties

 

Yes

Detail about the canceled Penalty

 /

@noShow

boolean

Yes

If true, it means the penalty charge applied for No-Show, and the cancellable, cancelDeadline will NOT exist.

 /

@cancellable

boolean

No

Indicates if cancellation is allowed or not. If false, it cannot be canceled. If true, the cancellation deadline will exist.

 /

cancelPenalties/cancelDeadline

object

No

 /

 /

@offsetTimeDropType

enum

No

Enum: [ BeforeArrival ]

An enumerated type indicates when the deadline drop time goes into effect.

 /

@offsetTimeUnit

enum

No

Enum: [ D, H ]

 

 /

@offsetTimeValue

number

No

The number of offset times with the time unit

 /

@deadline

string

No

Local deadline times allowed for cancellation, like 4 PM, or 6 PM.

 /

cancelPenalties/penaltyCharge

object

 No

 /

 /

@chargeBase

enum

No

Enum: [ FullStay, NightBase ]

if FullStay, it will be a percentage or amount, if NightBase, the nights are required.

 /

@nights

number

No 

It exists if the penalty charge is based on the night, like the first night.

 /

@amount

number

No 

It exists if the penalty charge is a flat charge, like USD 30.00.

 /

@percent

number

No 

It exists if the penalty charge is percent, like 15.5 means 15.5%

 /

bookingChannelstringNo

Sub-distributor ID

/
productAddonsarray[object]No//
@typestringYes/DisneyTicket
@codestringYes//
@datestringYesformat with yyyy-MM-dd2022-01-01
@quantityintegerYes/1
@officeIdstringNo

specific distributor office

/
productAddons/rateobjectNo//
rate/ageQualifyingTypeobjectNo//
@typeenumYesEnum: [Adult, Child]Adult
@minAgeintegerYes/18
@maxAgeintegerYes/18
rate/currencystringYes/USD
rate/amountBeforeTaxnumberNo/123.23
rate/amountAfterTaxnumberNo/134.34

status

enum

Yes

Enum: [ Confirmed, Modified, Cancelled ]


The latest status of the reservation


  • Confirmed - New reservation 
  • Modified -  Modification Reservation
  • Cancelled - Cancellation Reservation


Please combine the status and result fields to determine the reservation whether successful, combination examples are as follows:


  • Confirmed + Successful = Booking is successful
  • Confirmed + Failed = Booking is failed
  • Modified + Successful = Modification is successful
  • Modified + Failed = Modification is failed
  • Cancelled + Successful = Cancellation is successful
  • Cancelled + Failed = Cancellation is failed

 /

cancellationIdstringNoCancellation confirmation number in suppliers' systemC89389494

result

enum

Yes

Enum: [ Successful, Failed, Processing ]

result of the reservation to send to the supplier

 /

reservations/failCause

object

No

Note: If the reservation fails, the node will be visible; otherwise, it will not appear.

 /

@errorCode

string

Yes

Error Code Appendix

 /

@supplierErrorCode

string

No

Error code from the supply system

 /

@errorMessage

string

Yes

Error message

 /