TakeMe Inbound API (2024-12)
This API documentation outlines the process for creating reservations directly within the TakeMe Inbound system. Below is an overview of the key steps and general notes for working with the API:
Key Steps:
- Fetch an eligible shop
- Fetch the shop courses
- Fetch shop availability to get block unit time (optional as most shops are 30 mins in block time, but recommended to check just in case)
- Using IDs and other relevant information from previous fetch APIs, call the create reservation API
General Notes:
- All of the below APIs will require an API key. Please contact TakeMe to obtain an API key. We will also provide you with the "platform" path variable, required for all APIs.
- All dates and times are in JST (Japan Standard Time) unless otherwise specified.
- IDs are generally 16-digit UUIDs (Universally Unique Identifiers) unless otherwise specified.
- "Shop" and "Restaurant" are used interchangeably in this documentation.
- For status codes such as "reservationStatus," you may encounter unknown codes not mentioned in the API docs, especially from the staging environment. These codes are generally for other purposes and can be ignored.
- TakeMe Inbound has two environments: Staging and Production.
- If you would like us to create webhook APIs, please contact us to discuss implementation details.
Fetch a list of shops
This API fetch a list of shops eligible for reservations to be created directly into TakeMe Admin.
path Parameters
platform required | string |
query Parameters
limit | integer <int32> <= 50 The maximum amount of shops to fetch at once with a default of 10 |
offset | integer <int32> The offset of the list of shops to fetch with a default of 0 |
shopIds | Array of strings [ 0 .. 30 ] items Example: shopIds=8d494383-8841-11ee-8147-0ac66e9ce373&shopIds=97c1d19b-8841-11ee-8147-0ac66e9ce373 A list of shop ids to fetch. If this parameter is specified, limit and offset parameters will be ignored. A maximum of 30 shop ids can be specified at once. |
shopNameQuery | string Example: shopNameQuery=Awesome Sushi Find a list of shops with name similar to the parameter shop_name_query |
showRealTimeOnly | boolean Example: showRealTimeOnly=true If true, only show shops that are bookable in real time. If false, show all shops. |
languageCode required | string Enum: "en" "zh-CN" "ja" "ko" "zh-TW" Example: languageCode=en The language requested. Possible values include 'en', 'ja', 'zh-CN', 'zh-TW', 'ko'. Defaults to English |
header Parameters
Authorization required | string |
Responses
Response samples
- 200
{- "rows": [
- {
- "id": "string",
- "number": "string",
- "nameJa": "string",
- "nameEn": "string",
- "addressState": "東京都",
- "addressCity": "渋谷区",
- "addressTown": "道玄坂",
- "addressLine1": "1-18-6",
- "addressLine2": "Shibuya Mark City 4F",
- "minGuests": 1,
- "maxGuests": 10,
- "cancellationPolicyDays": 3,
- "shopBusinessHours": {
- "mon": [
- {
- "startTime": "10:00",
- "endTime": "18:00",
- "lastOrderCutoffMins": 30,
- "availabilityDesc": "Lunch"
}
], - "tue": [
- {
- "startTime": "10:00",
- "endTime": "18:00",
- "lastOrderCutoffMins": 45,
- "availabilityDesc": "Dinner"
}
]
}, - "realTimeBookable": true,
- "cutoffHours": 72,
- "shopI18n": {
- "formattedAddress": "1-1-1 Asakusa, Taito City, Tokyo 111-1111, Japan",
- "internationalPhoneNumber": "+81 3-1111-1111",
- "addressState": "Tokyo",
- "addressCity": "Minato City, which is a ward in Tokyo",
- "addressTown": "Asakusa",
- "addressPostalCode": "111-1111",
- "shopName": "111-1111",
- "shopDescription": "string",
- "languageCode": "string",
- "latitude": 0.1,
- "longitude": 0.1
}, - "shopImages": {
- "main": [
- "string"
], - "food": [
- "string"
], - "interior": [
- "string"
], - "exterior": [
- "string"
]
}
}
], - "count": 0
}
Fetch an individual shop.
This API fetches the details of one shop only.
path Parameters
platform required | string |
shopId required | string The shop id to fetch |
query Parameters
languageCode required | string Enum: "en" "zh-CN" "ja" "ko" "zh-TW" Example: languageCode=en Defaults to English |
header Parameters
Authorization required | string |
Responses
Response samples
- 200
{- "id": "string",
- "number": "string",
- "nameJa": "string",
- "nameEn": "string",
- "addressState": "東京都",
- "addressCity": "渋谷区",
- "addressTown": "道玄坂",
- "addressLine1": "1-18-6",
- "addressLine2": "Shibuya Mark City 4F",
- "minGuests": 1,
- "maxGuests": 10,
- "cancellationPolicyDays": 3,
- "shopBusinessHours": {
- "mon": [
- {
- "startTime": "10:00",
- "endTime": "18:00",
- "lastOrderCutoffMins": 30,
- "availabilityDesc": "Lunch"
}
], - "tue": [
- {
- "startTime": "10:00",
- "endTime": "18:00",
- "lastOrderCutoffMins": 45,
- "availabilityDesc": "Dinner"
}
]
}, - "realTimeBookable": true,
- "cutoffHours": 72,
- "shopI18n": {
- "formattedAddress": "1-1-1 Asakusa, Taito City, Tokyo 111-1111, Japan",
- "internationalPhoneNumber": "+81 3-1111-1111",
- "addressState": "Tokyo",
- "addressCity": "Minato City, which is a ward in Tokyo",
- "addressTown": "Asakusa",
- "addressPostalCode": "111-1111",
- "shopName": "111-1111",
- "shopDescription": "string",
- "languageCode": "string",
- "latitude": 0.1,
- "longitude": 0.1
}, - "shopImages": {
- "main": [
- "string"
], - "food": [
- "string"
], - "interior": [
- "string"
], - "exterior": [
- "string"
]
}
}
Get shop's availability.
Get the shop's availability for a given date. This API should be called first to ensure a reservation is available before proceeding to create a reservation. The shop's cutoff hours will be reflected in the availability.Please note that some courses will have their own availability times that must be met. Please see orderAvailableTimes from the fetch course API.If you would like the course time range to be used to filter the available times, please pass in a courseId.Times returned will in be in JST.
path Parameters
platform required | string |
shopId required | string The shop id to fetch availability for |
query Parameters
requestDate | string Example: requestDate=2024-09-25 Date to get restaurant's availability If omitted, the current date will be used. Format expected is yyyy-MM-dd |
pax | string Default: "2" Example: pax=2 Number of guests |
courseId | string If passed in, the course time range will be used to filter the available times. If omitted, all available shop times will be returned. |
header Parameters
Authorization required | string |
Responses
Response samples
- 200
{- "requestedDate": "2019-08-24",
- "requestedPax": 2,
- "availableTimes": [
- { }
], - "realTime": true
}
Get a list of courses for a specific shop.
Get a list of courses for a specified shop id.
path Parameters
platform required | string |
shopId required | string The shop id to fetch courses for |
query Parameters
limit | integer <int32> <= 50 Example: limit=10 The number of courses to return with a maximum of 50 |
offset | integer <int32> The offset to start from. Default is 0 |
courseNameQuery | string Deprecated Example: courseNameQuery=Sushi Course If provided, the courses will be filtered by this name.We are planning to remove this parameter in the near future as it may introduce strange behaviour. |
languageCode | string Enum: "en" "zh-CN" "ja" "ko" "zh-TW" Example: languageCode=en The language requested |
header Parameters
Authorization required | string |
Responses
Response samples
- 200
{- "rows": [
- {
- "id": "string",
- "shopId": "string",
- "courseName": "string",
- "courseDesc": "string",
- "parentCourseId": "string",
- "lowerAgeLimit": 0,
- "upperAgeLimit": 0,
- "quantityLimit": 0,
- "validFromDate": "2019-08-24T14:15:22Z",
- "validToDate": "2019-08-24T14:15:22Z",
- "orderStartTime": "string",
- "orderEndTime": "string",
- "orderMin": 0,
- "orderMax": 0,
- "coursePrice": {
- "suggestedRetailPrice": 0,
- "settlementPrice": 0
}, - "childCourses": [
- {
- "id": "string",
- "parentCourseId": "string",
- "courseName": "string",
- "courseDesc": "string",
- "lowerAgeLimit": 0,
- "upperAgeLimit": 0,
- "coursePrice": {
- "suggestedRetailPrice": 0,
- "settlementPrice": 0
}
}
], - "courseI18n": {
- "courseName": "string",
- "courseDescFormatted": "string",
- "languageCode": "en",
- "courseDescText": "string"
}, - "courseImages": {
- "courseImageUrls": [
- "string"
]
}, - "orderAvailableTimeRanges": [
- {
- "startRange": "08:00:00",
- "endRange": "10:00:00"
}, - {
- "startRange": "17:00:00",
- "endRange": "06:00:00"
}
]
}
], - "count": 0
}
Create a reservation.
Create a reservation for a specific shop. Shops that are real time bookable will be directly created with 'success' status. Otherwise, they are created with 'pending' status. Shops will be send an email notification upon creation. Please note that each reservation should only have one one course id or its child variants.
path Parameters
platform required | string |
shopId required | string The shop id to create a reservation for |
header Parameters
Authorization required | string |
Request Body schema: application/jsonrequired
reservationStartTime required | string <date-time> The local date time of the reservation start time in ISO 8601 format. e.g 2024-01-01T17:00:00. Please pass this parameter after converting the time to JST. Updates here will trigger a check on shop's cancellation policy. |
guestFirstName required | string <= 255 characters The first name of the user who is making this reservation |
guestLastName required | string <= 255 characters The last name of the user who is making this reservation |
guestPhoneNumber | string [ 0 .. 20 ] characters The phone number of the user who is making this reservation. The format on the phone number should be 'xxx-xxxx-xxxx' |
numberOfGuests | integer <int32> >= 1 The number of guests for this reservation. Updates here will trigger a check in shop's cancellation policy. |
remark | string Any additional remarks for this reservation such as allergies. If remarks are passed, remarkStatus will automatically be set to 0 (unread), otherwise it will be null. |
required | Array of objects (ReservedCourseInboundRequest) non-empty [ items non-empty ] The list of course ids to be requested for this reservation. |
originPlatformReservationNumber required | string <= 100 characters Please pass in the unique reservation number (generally for the guests' reference) used in your DB. |
guestEmail | string The email of the user who is making this reservation. No automated notifications will be sent to this email. |
Responses
Request samples
- Payload
{- "reservationStartTime": "2019-08-24T14:15:22Z",
- "guestFirstName": "John",
- "guestLastName": "Doe",
- "guestPhoneNumber": "123-4567-8910",
- "numberOfGuests": 4,
- "remark": "Allergic to nuts",
- "requestedCourses": [
- {
- "courseId": "string",
- "courseAmountRequested": 2
}
], - "originPlatformReservationNumber": "RES12345678",
- "guestEmail": "string"
}
Response samples
- 200
{- "id": "string",
- "shopId": "string",
- "originPlatformReservationNumber": "string",
- "reservationStartTime": "2019-08-24T14:15:22Z",
- "numberOfGuests": 2,
- "guestFirstName": "string",
- "guestLastName": "string",
- "guestPhoneNumber": "string",
- "guestEmail": "string",
- "remark": "string",
- "remarkStatus": 0,
- "priceTotal": 0,
- "totalSettlementPrice": 0,
- "originPlatform": "string",
- "courses": [
- {
- "courseId": "string",
- "courseAmountRequested": 2
}
], - "status": "PENDING"
}
Update a specific reservation..
Update a specific reservation. Currently, all of the below request fields must be passed in regardless if it will be updated. If reservationStartTime is different from previous value, the shop's cutoff hours will be enforced again. Email notifications are sent to restaurant on most updates.
path Parameters
platform required | string |
reservationIdOrOriginNumber required | string The reservation id or origin platform reservation number to fetch |
header Parameters
Authorization required | string |
Request Body schema: application/jsonrequired
reservationStartTime required | string <date-time> The local date time of the reservation start time in ISO 8601 format. e.g 2024-01-01T17:00:00. Please pass this parameter after converting the time to JST. Updates here will trigger a check on shop's cancellation policy. |
guestFirstName required | string <= 255 characters The first name of the user who is making this reservation |
guestLastName required | string <= 255 characters The last name of the user who is making this reservation |
guestPhoneNumber | string [ 0 .. 20 ] characters The phone number of the user who is making this reservation. The format on the phone number should be 'xxx-xxxx-xxxx' |
numberOfGuests | integer <int32> >= 1 The number of guests for this reservation. Updates here will trigger a check in shop's cancellation policy. |
remark | string Any additional remarks for this reservation such as allergies. If remarks are passed, remarkStatus will automatically be set to 0 (unread), otherwise it will be null. |
required | Array of objects (ReservedCourseInboundRequest) non-empty [ items non-empty ] The list of course ids to be requested for this reservation. Please note updates to this field will need to meet the shop's cancellation policy |
Responses
Request samples
- Payload
{- "reservationStartTime": "2019-08-24T14:15:22Z",
- "guestFirstName": "John",
- "guestLastName": "Doe",
- "guestPhoneNumber": "123-4567-8910",
- "numberOfGuests": 4,
- "remark": "Allergic to nuts",
- "requestedCourses": [
- {
- "courseId": "string",
- "courseAmountRequested": 2
}
]
}
Response samples
- 200
{- "id": "string",
- "shopId": "string",
- "originPlatformReservationNumber": "string",
- "reservationStartTime": "2019-08-24T14:15:22Z",
- "numberOfGuests": 2,
- "guestFirstName": "string",
- "guestLastName": "string",
- "guestPhoneNumber": "string",
- "guestEmail": "string",
- "remark": "string",
- "remarkStatus": 0,
- "priceTotal": 0,
- "totalSettlementPrice": 0,
- "originPlatform": "string",
- "courses": [
- {
- "courseId": "string",
- "courseAmountRequested": 2
}
], - "status": "PENDING"
}
Cancel a specific reservation.
Cancel a specific reservation. The reservation status will be updated based on whether a refund is provided to the guest. Please note that the shop's cancellation policy days will be enforced. (please see cancellationPolicyDays from the Fetch Shop API).Cancellations on the day of the reservationStartTime, even before the appointed time will not be possible via API.
path Parameters
platform required | string |
reservationIdOrOriginNumber required | string The reservation id or origin platform reservation number to fetch |
header Parameters
Authorization required | string |
Request Body schema: application/jsonrequired
refunded | boolean Default: false Whether a refund is granted to the user for this cancellation.. |
remark | string Any additional remarks for this cancellation such as reasons for the cancellation. |
Responses
Request samples
- Payload
{- "refunded": false,
- "remark": "string"
}
Response samples
- 200
{- "id": "string",
- "shopId": "string",
- "originPlatformReservationNumber": "string",
- "reservationStartTime": "2019-08-24T14:15:22Z",
- "numberOfGuests": 2,
- "guestFirstName": "string",
- "guestLastName": "string",
- "guestPhoneNumber": "string",
- "guestEmail": "string",
- "remark": "string",
- "remarkStatus": 0,
- "priceTotal": 0,
- "totalSettlementPrice": 0,
- "originPlatform": "string",
- "courses": [
- {
- "courseId": "string",
- "courseAmountRequested": 2
}
], - "status": "PENDING"
}
Fetch a list of reservations.
This API fetches the list of reservations associated with the caller.
path Parameters
platform required | string |
query Parameters
limit | integer <int32> <= 30 Example: limit=10 The number of reservations to be returned in the response. Default is 10 with a max of 30. |
offset | integer <int32> The offset of the list of shops to fetch. |
reservationNumbers | Array of strings [ 0 .. 30 ] items Example: reservationNumbers=8d494383-8841-11ee-8147-0ac66e9ce373&reservationNumbers=97c1d19b-8841-11ee-8147-0ac66e9ce373 A list of reservation ids or origin platform reservation numbers to fetch. If this parameter is specified, the limit and offset parameters will be ignored. A maximum of 30 shop ids can be specified at once. |
header Parameters
Authorization required | string |
Responses
Response samples
- 200
{- "rows": [
- {
- "id": "string",
- "shopId": "string",
- "originPlatformReservationNumber": "string",
- "reservationStartTime": "2019-08-24T14:15:22Z",
- "numberOfGuests": 2,
- "guestFirstName": "string",
- "guestLastName": "string",
- "guestPhoneNumber": "string",
- "guestEmail": "string",
- "remark": "string",
- "remarkStatus": 0,
- "priceTotal": 0,
- "totalSettlementPrice": 0,
- "originPlatform": "string",
- "courses": [
- {
- "courseId": "string",
- "courseAmountRequested": 2
}
], - "status": "PENDING"
}
], - "count": 0
}
Fetch an individual reservation.
This API fetches the list of reservations associated with the caller.
path Parameters
platform required | string |
reservationNumber required | string The reservation id or origin platform reservation number to fetch |
header Parameters
Authorization required | string |
Responses
Response samples
- 200
{- "id": "string",
- "shopId": "string",
- "originPlatformReservationNumber": "string",
- "reservationStartTime": "2019-08-24T14:15:22Z",
- "numberOfGuests": 2,
- "guestFirstName": "string",
- "guestLastName": "string",
- "guestPhoneNumber": "string",
- "guestEmail": "string",
- "remark": "string",
- "remarkStatus": 0,
- "priceTotal": 0,
- "totalSettlementPrice": 0,
- "originPlatform": "string",
- "courses": [
- {
- "courseId": "string",
- "courseAmountRequested": 2
}
], - "status": "PENDING"
}