Termino Hotel API (1.1.0)

Download OpenAPI specification:Download

This document outlines the API of Termino, utilized by Slevomat to enable the sale of online bookings on Slevomat.cz and Zlavomat.sk. This API is used for connecting channel management (CM) and property management systems (PMS).

Core Functions of the API Include:

  • synchronization of hotel structure (room types and rooms) from CM/PMS to Termino or the other way around
  • synchronization of available capacities (free rooms) from CM/PMS to Termino
  • issuing reservations from Termino to CM/PMS
  • bi-directional editing and canceling of reservations created from Termino

Note: This API does not cover the synchronization of prices (rate plans), payments, or cancellation policies. These elements are beyond the scope of this API's functionalities.

👋 Basics

API Structure

This API is bi-directional, meaning both sides can request or push information to the other's API. Given that this API covers various system setups, there are multiple ways to establish communication. The synchronization of hotel structure and capacities is typically achieved by CM/PMS pushing information to Termino. A periodic pull of capacity information can also be configured, but push is preferred as it facilitates faster change propagation and reduces traffic between systems.

Typical usage for channel managers includes:

  • Implementing the reservation and ping endpoints on your side
  • Calling the capacities-update endpoint to push capacity changes
  • Using the get-hotel endpoint to retrieve the hotel structure and set up the connection

For property management systems, the typical usage involves:

  • Implementing the hotel, reservation, and get-reservation endpoints. The ping endpoint is not needed because the hotel endpoint should provide the same information (whether the hotel is active or not).
  • Depending on the pull or push style, implementing the capacities on your side or calling the capacities-update push endpoint on Termino to deliver updates.

🔑 Security and Authentication

All requests are required to communicate over HTTPS. Termino API endpoints support TLS protocol versions 1.2 and higher.

Authentication

All requests contain the property accessToken with a value assigned during the API verification process. These values identify the communicating parties - CM/PMS on one side and Termino on the other.

📡 Request and Response Format

Both sides accept only HTTP POST. Requests and responses are sent with the Content-Type header set to application/json and a JSON body depending on the operation to be performed. Content encoding is always UTF-8.

If a message is received and processed, the HTTP response code should be 200 OK for successful results and any 4xx for unsuccessful results (the concrete error type is described in the response body).

5xx response codes indicate unexpected and internal errors, and the request can be retried without change. No specific response should be expected for server errors (JSON is not guaranteed). The response header Retry-After (if present) should be respected for retrying the request.

The type of message is determined by the URL.

For push endpoints, the request should be repeated until it is successfully delivered to Termino. Similarly, Termino will repeat requests until they are accepted by your system. Successful delivery means either responding with success or an expected error described in the API specification.

Identifiers

  • All identifiers (parameters named id) have to be unique for a given hotel, unless explicitly stated otherwise.
  • All identifiers generated on the Termino side are UUIDs.
  • All identifiers from your side can be either integers or strings.

Reservation ID

Each reservation has to have a unique ID for reference between systems. This identifier is later used in case of modification and cancellation of the reservation is needed. Termino can either generate and send our identifier with reservation creation, or it can accept and later use the reservation ID returned in response. Using the ID from Termino is preferred because it allows us to reference the reservation even in case this create request fails with a timeout or other unexpected error. When using your ID, another system or manual intervention is needed in this case.

Basic request

{
    "accessToken": "foobar",
    // other properties
}

Basic success response

{
    "success": true,
}

Basic error response

{
    "error": {
        "code": "invalid-access-token",
        "message": "Access token not found."
    }
}

Common error codes

These errors can occur on any API endpoint.

Code Description
invalid-format Unparsable JSON
missing-value A required property is missing.
invalid-value A property has invalid format (e.g., wrong date, time, datetime, interval, URL...).
invalid-access-token Invalid or expired access token

🆕 Changelog

Changes to API and its documentation

2023

2. 11. 2023

  • Added children ages and bed entitlement to reservation data (reservation.children)
  • Added meal plan to reservation data (reservation.meal)
  • Added e-mail address to reservation data (reservation.contact.email)
  • Deprecate occupations and occupations-update endpoints to be used for blockages. Use capacities instead.
  • Deprecate rooms parameter from RoomType structure. Only roomCount parameter is now needed to define room type structure
  • Deprecate roomId parameter from Occupation and Reservation structure. Only roomTypeId parameter is now needed to define occupation

2021

24. 11. 2021

  • Deprecate checkIn, checkOut and url parameters from hotel structure

2020

9. 1. 2020

  • Initial release

Termino endpoints

Endpoints on Termino side are called from PMS/CM system and mostly used to push data changes. If unsuccessful response is returned, the request has to be repeated until it is successfully delivered to Termino.

Occupations (push)

Synchronization of changed reservations on the hotel side.

It is deprecated to send updates for other reservations then those created by Termino/Slevomat.

Usage:

  • Partner changes Slevomat reservation in their system and this endpoint is called to update the reservation in Termino/Slevomat
  • Deprecated Pushing blockage and reservation updates when using pull endpoint /occupations

Updates of occupations in multiple hotels has to be sent in multiple requests.

Request Body schema: application/json
required
accessToken
required
string

Access token to your API.

required
string or integer

Hotel id.

required
Array of objects (Occupation)

List of updated occupations.

Responses

Request samples

Content type
application/json
{
  • "accessToken": "string",
  • "hotelId": "string",
  • "occupations": [
    ]
}

Response samples

Content type
application/json
{
  • "success": true
}

Capacities (push)

Synchronization of changed capacities

Usage:

  • CM / PMS pushes capacity changes to Termino
Request Body schema: application/json
required
accessToken
required
string

Access token to your API.

required
string or integer

Your hotel id.

required
Array of objects (Capacity)

List of updated capacities.

Responses

Request samples

Content type
application/json
{
  • "accessToken": "string",
  • "hotelId": "string",
  • "capacities": [
    ]
}

Response samples

Content type
application/json
{
  • "success": true
}

Hotel update (push)

Synchronization of changed hotel info and structure.

Usage:

  • CM / PMS pushes hotel info and structure changes to Termino
Request Body schema: application/json
required
accessToken
required
string

Access token to your API.

required
object (Hotel)
Array of objects (RoomType)

Updated room types.

Responses

Request samples

Content type
application/json
{
  • "accessToken": "string",
  • "hotel": {
    },
  • "roomTypes": [
    ]
}

Response samples

Content type
application/json
{
  • "success": true
}

Hotel info (reversed)

Provides same information as /hotel endpoint, but in reversed direction. This endpoint is called by CM to load room types created on Termino side and set up mapping.

Request Body schema: application/json
required
accessToken
required
string

Access token to your API.

required
string or integer

Hotel id.

Responses

Request samples

Content type
application/json
{
  • "accessToken": "string",
  • "hotelId": "string"
}

Response samples

Content type
application/json
{
  • "hotel": {
    },
  • "roomTypes": [
    ]
}

PMS/CM endpoints

Partner endpoints should be implemented in your PMS/CM system and are called by Termino, either periodically or when specific action is performed (eg. new reservation, hotel connection).

Hotel info and Room Types

Information about hotel for registration process and structure of room type and rooms.

Usage:

  • loading hotel info and structure when registering a new hotel
  • synchronizing hotel structure - infrequent polling and request when wrong synchronization is detected (unknown room etc.)
Request Body schema: application/json
accessToken
required
string

Access token for authorization

required
string or integer

Your hotel id

Responses

Request samples

Content type
application/json
{
  • "accessToken": "aa5ae844-051c-4d30-9c67-54b70c99b580",
  • "hotelId": "123456"
}

Response samples

Content type
application/json
{
  • "hotel": {
    },
  • "roomTypes": [
    ]
}

Capacities

Synchronizing available space.

Usage:

  • called when new hotel is registered
  • called after a new reservation is created or reservation fails
  • periodical synchronization of available space unless push endpoint is used
Request Body schema: application/json
required
accessToken
required
string

Access token to your API.

required
string or integer

Hotel id.

required
object (DateInterval)
Array of strings or integers

Requested room type ids. When not provided, return capacities for all room types of given hotel.

Responses

Request samples

Content type
application/json
{
  • "accessToken": "string",
  • "hotelId": "string",
  • "interval": {
    },
  • "roomTypeIds": [
    ]
}

Response samples

Content type
application/json
{
  • "capacities": [
    ]
}

Create/update reservation

Creating new reservations, updating reservations, canceling reservations.

Behavior of this endpoint heavily depends on the agreed scheme of communication:

1 - Reservation Statuses:

The default scheme is "dual requests" - the first request contains status: option and does not contain customer data. The second request contains status: confirmed and includes customer data. This scheme allows more gradual control of the state of the reservation. Both statuses are expected to block the room for the reservation.

The second option is "single request" - in this scheme, even the first request with status: option contains all customer data and the voucher code. The confirmation request is sent also with the same data but does not have to be relayed to the hotel. Single-request mode is more suited for systems which do not support modifying existing reservations without canceling them and creating a new one (OTA-like behavior). You should specify which behavior better suits your system capabilities when consulting the integration with Termino.

2 - Reservation ID:

For referencing reservations between Termino and your system, either your ID or our ID can be used. In case your ID is used, the first (option) request does not contain the property id. You have to generate and send it in response.

In case our ID is used, the first (option) request contains the property id with our ID. You have to store it and use it in all subsequent requests.

Using your ID can be problematic in case communication during the first request fails due to any unexpected error (timeout, outage, etc.). This may cause a reservation being created in your system, but not in Termino. That's why we prefer using our ID, which we can use to check and remove such un-synced reservation.

Termino expects the room to be blocked for reservation when the option request is successfully processed.

Usage:

  • Called with status option and then confirmed when creating a new reservation (see above)
  • Called with canceled status to cancel the reservation
  • Called when changing booking date on customer's request

Grouped reservations are currently not implemented; one request always contains only one reservation. Reservation group ID is the same as reservation ID. Reservation response should contain the same data as the request.

Request Body schema: application/json
required
accessToken
required
string

Access token to your API.

required
string or integer

Your hotel id.

required
object (ReservationGroup)

Responses

Request samples

Content type
application/json
{
  • "accessToken": "11-11-11-11",
  • "hotelId": 123456,
  • "reservationGroup": {
    }
}

Response samples

Content type
application/json
{
  • "hotelId": "string",
  • "accessToken": "string",
  • "reservationGroup": {
    }
}

Reservation query

Request for current state of the reservation

Usage:

  • queried by Termino when a reservation disappears from synchronized interval (moved to another room, term, room deleted etc.) without being updated first (failsafe).
Request Body schema: application/json
required
accessToken
required
string

Access token to your API.

required
string or integer

Hotel id.

required
string or integer

Reservation id.

Responses

Request samples

Content type
application/json
{
  • "accessToken": "string",
  • "hotelId": "string",
  • "reservationId": "string"
}

Response samples

Content type
application/json
{
  • "id": "string",
  • "status": "option",
  • "roomTypeId": "string",
  • "roomId": "string",
  • "term": {
    },
  • "price": {
    },
  • "meal": "none",
  • "adultsCount": 0,
  • "childrenCount": 0,
  • "children": [
    ],
  • "guestNote": "string",
  • "voucher": "string",
  • "contact": {
    }
}

Reservations search

This endpoint was previously used as alternative to /capacities. This usage is deprecated. Use capacities instead.

Synchronization of changes in reservations created by Termino/Slevomat. This allows changes in reservation made in PMS to be propagated to Termino and Slevomat. Changes can also be pushed via /occupations-update endpoint.

Usage:

  • synchronizing occupation changes once a day
Request Body schema: application/json
required
accessToken
required
string

Access token to your API.

required
string or integer

Your hotel id.

required
object (DateInterval)
Array of strings or integers

Filter occupations on given room types.

Responses

Request samples

Content type
application/json
{
  • "accessToken": "string",
  • "hotelId": "string",
  • "interval": {
    },
  • "roomTypeIds": [
    ]
}

Response samples

Content type
application/json
{
  • "occupations": [
    ]
}

Ping

Ping endpoint is used to check if hotel exists and synchronization is active on your side.

If you implement /hotel endpoint, you can ignore this endpoint.

Usage:

  • called periodically to check if hotels are still active
Request Body schema: application/json
required
accessToken
required
string

Access token to your API.

required
string or integer

Hotel id.

Responses

Request samples

Content type
application/json
{
  • "accessToken": "string",
  • "hotelId": "string"
}

Response samples

Content type
application/json
{
  • "success": true
}