Back to Collection Items
var
http: HCkHttp;
success: Boolean;
json: HCkJsonObject;
resp: HCkHttpResponse;
begin
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http := CkHttp_Create();
// Use this online tool to generate code from sample JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "reservationIdList": [
// {
// "type": "Reservation",
// "id": "{{ReservationId}}"
// }
// ],
// "keyOptions": "GAR,RFT",
// "keyValidityStart": "2021-22-25 12:00:00.0",
// "noOfKeys": "1",
// "encoderTerminal": "APIRQ",
// "encoderId": {
// "id": "0"
// },
// "resort": "{{HotelId}}",
// "keyType": "New",
// "keyValidityEnd": "2021-11-26 13:00:00.0"
// }
json := CkJsonObject_Create();
CkJsonObject_UpdateString(json,'reservationIdList[0].type','Reservation');
CkJsonObject_UpdateString(json,'reservationIdList[0].id','{{ReservationId}}');
CkJsonObject_UpdateString(json,'keyOptions','GAR,RFT');
CkJsonObject_UpdateString(json,'keyValidityStart','2021-22-25 12:00:00.0');
CkJsonObject_UpdateString(json,'noOfKeys','1');
CkJsonObject_UpdateString(json,'encoderTerminal','APIRQ');
CkJsonObject_UpdateString(json,'encoderId.id','0');
CkJsonObject_UpdateString(json,'resort','{{HotelId}}');
CkJsonObject_UpdateString(json,'keyType','New');
CkJsonObject_UpdateString(json,'keyValidityEnd','2021-11-26 13:00:00.0');
resp := CkHttp_PostJson3(http,'https://domain.com/fof/v0/hotels/hotelId/reservations/reservationId/roomKeys','application/json',json);
if (CkHttp_getLastMethodSuccess(http) = False) then
begin
Memo1.Lines.Add(CkHttp__lastErrorText(http));
Exit;
end;
Memo1.Lines.Add(IntToStr(CkHttpResponse_getStatusCode(resp)));
Memo1.Lines.Add(CkHttpResponse__bodyStr(resp));
CkHttpResponse_Dispose(resp);
CkHttp_Dispose(http);
CkJsonObject_Dispose(json);
Curl Command
curl -X POST
-d '{
"reservationIdList": [
{
"type": "Reservation",
"id": "{{ReservationId}}"
}
],
"keyOptions": "GAR,RFT",
"keyValidityStart": "2021-22-25 12:00:00.0",
"noOfKeys": "1",
"encoderTerminal": "APIRQ",
"encoderId": {
"id": "0"
},
"resort": "{{HotelId}}",
"keyType": "New",
"keyValidityEnd": "2021-11-26 13:00:00.0"
}'
https://domain.com/fof/v0/hotels/hotelId/reservations/reservationId/roomKeys
Postman Collection Item JSON
{
"name": "Create Room Key",
"request": {
"method": "POST",
"header": [
],
"body": {
"mode": "raw",
"raw": "{\n \"reservationIdList\": [\n {\n \"type\": \"Reservation\",\n \"id\": \"{{ReservationId}}\"\n }\n ],\n \"keyOptions\": \"GAR,RFT\",\n \"keyValidityStart\": \"2021-22-25 12:00:00.0\",\n \"noOfKeys\": \"1\",\n \"encoderTerminal\": \"APIRQ\",\n \"encoderId\": {\n \"id\": \"0\"\n },\n \"resort\": \"{{HotelId}}\",\n \"keyType\": \"New\",\n \"keyValidityEnd\": \"2021-11-26 13:00:00.0\"\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{HostName}}/fof/v0/hotels/hotelId/reservations/reservationId/roomKeys",
"host": [
"{{HostName}}"
],
"path": [
"fof",
"v0",
"hotels",
"hotelId",
"reservations",
"reservationId",
"roomKeys"
]
},
"description": "This operation **postRoomKey** will only be available if the property has a valid intergration to a doorlocking system.\r\n\r\nencoderId = 0 is typically the designation that a digital key is requested rather than a physical key\r\n"
},
"response": [
]
}