Back to Collection Items
Use ChilkatAx-9.5.0-win32.pkg
Procedure Test
Handle hoHttp
Boolean iSuccess
Variant vJson
Handle hoJson
Variant vResp
Handle hoResp
String sTemp1
Integer iTemp1
Boolean bTemp1
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
Get Create (RefClass(cComChilkatHttp)) To hoHttp
If (Not(IsComObjectCreated(hoHttp))) Begin
Send CreateComObject of hoHttp
End
// Use this online tool to generate code from sample JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "reservation": {
// "reservationId": {
// "type": "Reservation"
// },
// "preCheckInDetails": {
// "arrival": {
// "arrivalTime": "2021-03-15 14:05:00.0"
// },
// "allowMobileViewFolio": false,
// "reservationPaymentMethods": [
// {
// "paymentCard": {
// "cardType": "AX",
// "cardNumberMasked": "XXXXXXXXXXXX3434",
// "expirationDate": "2022-10-31",
// "cardHolderName": "Card Holder Name"
// },
// "authorizationRule": {
// "code": 5,
// "amount": {
// "amount": 250
// }
// },
// "paymentMethod": "AX",
// "folioView": 1
// }
// ],
// "guestPreferredCurrency": "USD"
// }
// }
// }
Get Create (RefClass(cComChilkatJsonObject)) To hoJson
If (Not(IsComObjectCreated(hoJson))) Begin
Send CreateComObject of hoJson
End
Get ComUpdateString Of hoJson "reservation.reservationId.type" "Reservation" To iSuccess
Get ComUpdateString Of hoJson "reservation.preCheckInDetails.arrival.arrivalTime" "2021-03-15 14:05:00.0" To iSuccess
Get ComUpdateBool Of hoJson "reservation.preCheckInDetails.allowMobileViewFolio" False To iSuccess
Get ComUpdateString Of hoJson "reservation.preCheckInDetails.reservationPaymentMethods[0].paymentCard.cardType" "AX" To iSuccess
Get ComUpdateString Of hoJson "reservation.preCheckInDetails.reservationPaymentMethods[0].paymentCard.cardNumberMasked" "XXXXXXXXXXXX3434" To iSuccess
Get ComUpdateString Of hoJson "reservation.preCheckInDetails.reservationPaymentMethods[0].paymentCard.expirationDate" "2022-10-31" To iSuccess
Get ComUpdateString Of hoJson "reservation.preCheckInDetails.reservationPaymentMethods[0].paymentCard.cardHolderName" "Card Holder Name" To iSuccess
Get ComUpdateInt Of hoJson "reservation.preCheckInDetails.reservationPaymentMethods[0].authorizationRule.code" 5 To iSuccess
Get ComUpdateInt Of hoJson "reservation.preCheckInDetails.reservationPaymentMethods[0].authorizationRule.amount.amount" 250 To iSuccess
Get ComUpdateString Of hoJson "reservation.preCheckInDetails.reservationPaymentMethods[0].paymentMethod" "AX" To iSuccess
Get ComUpdateInt Of hoJson "reservation.preCheckInDetails.reservationPaymentMethods[0].folioView" 1 To iSuccess
Get ComUpdateString Of hoJson "reservation.preCheckInDetails.guestPreferredCurrency" "USD" To iSuccess
Send ComSetRequestHeader To hoHttp "Content-Type" "application/json"
Send ComSetRequestHeader To hoHttp "x-app-key" "{{AppKey}}"
Send ComSetRequestHeader To hoHttp "x-hotelid" "{{HotelId}}"
// Adds the "Authorization: Bearer <access_token>" header.
Set ComAuthToken Of hoHttp To "<access_token>"
Get pvComObject of hoJson to vJson
Get ComPostJson3 Of hoHttp "https://domain.com/rsv/v1/hotels/{{HotelId}}/reservations/{{ReservationId}}/preCheckIn" "application/json" vJson To vResp
If (IsComObject(vResp)) Begin
Get Create (RefClass(cComChilkatHttpResponse)) To hoResp
Set pvComObject Of hoResp To vResp
End
Get ComLastMethodSuccess Of hoHttp To bTemp1
If (bTemp1 = False) Begin
Get ComLastErrorText Of hoHttp To sTemp1
Showln sTemp1
Procedure_Return
End
Get ComStatusCode Of hoResp To iTemp1
Showln iTemp1
Get ComBodyStr Of hoResp To sTemp1
Showln sTemp1
Send Destroy of hoResp
End_Procedure
Curl Command
curl -X POST
-H "Authorization: Bearer <access_token>"
-H "Content-Type: application/json"
-H "x-app-key: {{AppKey}}"
-H "x-hotelid: {{HotelId}}"
-d '{
"reservation": {
"reservationId": {
"type": "Reservation",
},
"preCheckInDetails": {
"arrival": {
"arrivalTime": "2021-03-15 14:05:00.0"
},
"allowMobileViewFolio": false,
"reservationPaymentMethods": [
{
"paymentCard": {
"cardType": "AX",
"cardNumberMasked": "XXXXXXXXXXXX3434",
"expirationDate": "2022-10-31",
"cardHolderName": "Card Holder Name"
},
"authorizationRule": {
"code": 5,
"amount": {
"amount": 250
}
},
"paymentMethod": "AX",
"folioView": 1
}
],
"guestPreferredCurrency": "USD"
}
}
}'
https://domain.com/rsv/v1/hotels/{{HotelId}}/reservations/{{ReservationId}}/preCheckIn
Postman Collection Item JSON
{
"name": "Pre-Register with payment method and arrival time",
"request": {
"auth": {
"type": "bearer",
"bearer": [
{
"key": "token",
"value": "{{Token}}",
"type": "string"
}
]
},
"method": "POST",
"header": [
{
"key": "Content-Type",
"name": "Content-Type",
"value": "application/json",
"type": "text"
},
{
"key": "x-app-key",
"value": "{{AppKey}}",
"type": "text"
},
{
"key": "x-hotelid",
"value": "{{HotelId}}",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"reservation\": {\n \"reservationId\": {\n \"type\": \"Reservation\",\n },\n \"preCheckInDetails\": {\n \"arrival\": {\n \"arrivalTime\": \"2021-03-15 14:05:00.0\"\n },\n \"allowMobileViewFolio\": false,\n \"reservationPaymentMethods\": [\n {\n \"paymentCard\": {\n \"cardType\": \"AX\",\n \"cardNumberMasked\": \"XXXXXXXXXXXX3434\",\n \"expirationDate\": \"2022-10-31\",\n \"cardHolderName\": \"Card Holder Name\"\n },\n \"authorizationRule\": {\n \"code\": 5,\n \"amount\": {\n \"amount\": 250\n }\n },\n \"paymentMethod\": \"AX\",\n \"folioView\": 1\n }\n ],\n \"guestPreferredCurrency\": \"USD\"\n \n }\n }\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "{{HostName}}/rsv/v1/hotels/{{HotelId}}/reservations/{{ReservationId}}/preCheckIn",
"host": [
"{{HostName}}"
],
"path": [
"rsv",
"v1",
"hotels",
"{{HotelId}}",
"reservations",
"{{ReservationId}}",
"preCheckIn"
]
}
},
"response": [
]
}