Chilkat Online Tools

VB6 / ORACLE Hospitality OPERA Cloud REST API Workflows / Create Rate Plan Schedules

Back to Collection Items

' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

Dim http As New ChilkatHttp
Dim success As Long

' Use this online tool to generate code from sample JSON: Generate Code to Create JSON

' The following JSON is sent in the request body.

' {
'   "ratePlanScheduleList": [
'     {
'       "roomTypeList": [
'         "DLXK",
'         "DLXQ"
'       ],
'       "sunday": true,
'       "monday": true,
'       "tuesday": true,
'       "wednesday": true,
'       "thursday": true,
'       "friday": true,
'       "saturday": true,
'       "rateAmounts": {
'         "onePersonRate": "200",
'         "twoPersonRate": "200",
'         "threePersonRate": "235",
'         "fourPersonRate": "270",
'         "oneChildRate": "150",
'         "twoChildrenRate": "175",
'         "threeChildrenRate": "200",
'         "rateByAgeBuckets": [
'           {
'             "minimumAge": "1",
'             "maximumAge": "17"
'           }
'         ],
'         "minimumChildrenForFreeStay": "1",
'         "overrideFloorAmount": true
'       },
'       "classifications": {},
'       "rateSchedulePackages": {
'         "packages": [
'         ],
'         "packageGroups": [
'         ]
'       },
'       "tierID": "1",
'       "start": "2020-11-01",
'       "end": "2020-11-30"
'     }
'   ],
'   "hotelId": "{{HotelId}}",
'   "ratePlanCode": "{{RatePlanCode}}"
' }

Dim json As New ChilkatJsonObject
success = json.UpdateString("ratePlanScheduleList[0].roomTypeList[0]","DLXK")
success = json.UpdateString("ratePlanScheduleList[0].roomTypeList[1]","DLXQ")
success = json.UpdateBool("ratePlanScheduleList[0].sunday",1)
success = json.UpdateBool("ratePlanScheduleList[0].monday",1)
success = json.UpdateBool("ratePlanScheduleList[0].tuesday",1)
success = json.UpdateBool("ratePlanScheduleList[0].wednesday",1)
success = json.UpdateBool("ratePlanScheduleList[0].thursday",1)
success = json.UpdateBool("ratePlanScheduleList[0].friday",1)
success = json.UpdateBool("ratePlanScheduleList[0].saturday",1)
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.onePersonRate","200")
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.twoPersonRate","200")
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.threePersonRate","235")
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.fourPersonRate","270")
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.oneChildRate","150")
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.twoChildrenRate","175")
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.threeChildrenRate","200")
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.rateByAgeBuckets[0].minimumAge","1")
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.rateByAgeBuckets[0].maximumAge","17")
success = json.UpdateString("ratePlanScheduleList[0].rateAmounts.minimumChildrenForFreeStay","1")
success = json.UpdateBool("ratePlanScheduleList[0].rateAmounts.overrideFloorAmount",1)
success = json.UpdateNewObject("ratePlanScheduleList[0].classifications")
success = json.UpdateNewArray("ratePlanScheduleList[0].rateSchedulePackages.packages")
success = json.UpdateNewArray("ratePlanScheduleList[0].rateSchedulePackages.packageGroups")
success = json.UpdateString("ratePlanScheduleList[0].tierID","1")
success = json.UpdateString("ratePlanScheduleList[0].start","2020-11-01")
success = json.UpdateString("ratePlanScheduleList[0].end","2020-11-30")
success = json.UpdateString("hotelId","{{HotelId}}")
success = json.UpdateString("ratePlanCode","{{RatePlanCode}}")

http.SetRequestHeader "Content-Type","application/json;charset=UTF-8"
http.SetRequestHeader "x-hotelid","{{HotelId}}"
' Adds the "Authorization: Bearer <access_token>" header.
http.AuthToken = "<access_token>"
http.SetRequestHeader "Accept","application/json;charset=UTF-8"
http.SetRequestHeader "x-app-key","{{AppKey}}"

Dim resp As ChilkatHttpResponse
Set resp = http.PostJson3("https://domain.com/rtp/v0/hotels/{{HotelId}}/ratePlans/{{RatePlanCode}}/schedules","application/json;charset=UTF-8",json)
If (http.LastMethodSuccess = 0) Then
    Debug.Print http.LastErrorText
    Exit Sub
End If

Debug.Print resp.StatusCode
Debug.Print resp.BodyStr

Curl Command

curl -X POST
	-H "Authorization: Bearer <access_token>"
	-H "Content-Type: application/json;charset=UTF-8"
	-H "Accept: application/json;charset=UTF-8"
	-H "x-hotelid: {{HotelId}}"
	-H "x-app-key: {{AppKey}}"
	-d '{
    "ratePlanScheduleList": [
        {
            "roomTypeList": [
                "DLXK",
                "DLXQ"
            ],
            "sunday": true,
            "monday": true,
            "tuesday": true,
            "wednesday": true,
            "thursday": true,
            "friday": true,
            "saturday": true,
            "rateAmounts": {
                "onePersonRate": "200",
                "twoPersonRate": "200",
                "threePersonRate": "235",
                "fourPersonRate": "270",
                "oneChildRate": "150",
                "twoChildrenRate": "175",
                "threeChildrenRate": "200",
                "rateByAgeBuckets": [
                    {
                        "minimumAge": "1",
                        "maximumAge": "17"
                    }
                ],
                "minimumChildrenForFreeStay": "1",
                "overrideFloorAmount": true
            },
            "classifications": {},
            "rateSchedulePackages": {
                "packages": [],
                "packageGroups": []
            },
            "tierID": "1",
            "start": "2020-11-01",
            "end": "2020-11-30"
        }
    ],
    "hotelId": "{{HotelId}}",
    "ratePlanCode": "{{RatePlanCode}}"
}'
https://domain.com/rtp/v0/hotels/{{HotelId}}/ratePlans/{{RatePlanCode}}/schedules

Postman Collection Item JSON

{
  "name": "Create Rate Plan Schedules",
  "request": {
    "auth": {
      "type": "bearer",
      "bearer": [
        {
          "key": "token",
          "value": "{{Token}}",
          "type": "string"
        }
      ]
    },
    "method": "POST",
    "header": [
      {
        "key": "Content-Type",
        "type": "text",
        "value": "application/json;charset=UTF-8"
      },
      {
        "key": "Accept",
        "type": "text",
        "value": "application/json;charset=UTF-8"
      },
      {
        "key": "x-hotelid",
        "type": "text",
        "value": "{{HotelId}}"
      },
      {
        "key": "x-app-key",
        "type": "text",
        "value": "{{AppKey}}"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "{\r\n    \"ratePlanScheduleList\": [\r\n        {\r\n            \"roomTypeList\": [\r\n                \"DLXK\",\r\n                \"DLXQ\"\r\n            ],\r\n            \"sunday\": true,\r\n            \"monday\": true,\r\n            \"tuesday\": true,\r\n            \"wednesday\": true,\r\n            \"thursday\": true,\r\n            \"friday\": true,\r\n            \"saturday\": true,\r\n            \"rateAmounts\": {\r\n                \"onePersonRate\": \"200\",\r\n                \"twoPersonRate\": \"200\",\r\n                \"threePersonRate\": \"235\",\r\n                \"fourPersonRate\": \"270\",\r\n                \"oneChildRate\": \"150\",\r\n                \"twoChildrenRate\": \"175\",\r\n                \"threeChildrenRate\": \"200\",\r\n                \"rateByAgeBuckets\": [\r\n                    {\r\n                        \"minimumAge\": \"1\",\r\n                        \"maximumAge\": \"17\"\r\n                    }\r\n                ],\r\n                \"minimumChildrenForFreeStay\": \"1\",\r\n                \"overrideFloorAmount\": true\r\n            },\r\n            \"classifications\": {},\r\n            \"rateSchedulePackages\": {\r\n                \"packages\": [],\r\n                \"packageGroups\": []\r\n            },\r\n            \"tierID\": \"1\",\r\n            \"start\": \"2020-11-01\",\r\n            \"end\": \"2020-11-30\"\r\n        }\r\n    ],\r\n    \"hotelId\": \"{{HotelId}}\",\r\n    \"ratePlanCode\": \"{{RatePlanCode}}\"\r\n}"
    },
    "url": {
      "raw": "{{HostName}}/rtp/v0/hotels/{{HotelId}}/ratePlans/{{RatePlanCode}}/schedules",
      "host": [
        "{{HostName}}"
      ],
      "path": [
        "rtp",
        "v0",
        "hotels",
        "{{HotelId}}",
        "ratePlans",
        "{{RatePlanCode}}",
        "schedules"
      ]
    }
  },
  "response": [
  ]
}