Back to Collection Items
#include <C_CkHttp.h>
#include <C_CkJsonObject.h>
#include <C_CkHttpResponse.h>
void ChilkatSample(void)
{
HCkHttp http;
BOOL success;
HCkJsonObject json;
HCkHttpResponse resp;
// 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) {
printf("%s\n",CkHttp_lastErrorText(http));
CkHttp_Dispose(http);
CkJsonObject_Dispose(json);
return;
}
printf("%d\n",CkHttpResponse_getStatusCode(resp));
printf("%s\n",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": [
]
}