Chilkat Online Tools

Foxpro / ORACLE Hospitality OPERA Cloud REST API Workflows / Create New Profile If one doesn't exist

Back to Collection Items

LOCAL loHttp
LOCAL lnSuccess
LOCAL loJson
LOCAL loResp

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

loHttp = CreateObject('Chilkat_9_5_0.Http')

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

* The following JSON is sent in the request body.

* {
*   "profileDetails": {
*     "customer": {
*       "personName": [
*         {
*           "givenName": "James",
*           "surname": "Smith",
*           "nameType": "Primary"
*         },
*         {
*           "nameType": "Alternate"
*         },
*         {
*           "nameType": "Incognito"
*         }
*       ],
*       "alienInfo": {},
*       "birthCountry": {
*         "code": ""
*       },
*       "language": "E"
*     },
*     "addresses": {
*       "addressInfo": [
*         {
*           "address": {
*             "isValidated": false,
*             "addressLine": [
*               "3450 North Triumph Boulevard",
*               "Suite 300",
*               "",
*               ""
*             ],
*             "cityName": "Lehi",
*             "postalCode": "84043",
*             "state": "UT",
*             "country": {
*               "value": "US"
*             },
*             "language": "E",
*             "type": "BUSINESS",
*             "primaryInd": true
*           }
*         }
*       ]
*     },
*     "telephones": {
*       "telephoneInfo": [
*         {
*           "telephone": {
*             "phoneTechType": "PHONE",
*             "phoneUseType": "HOME",
*             "phoneNumber": "+1 385 555 0102",
*             "orderSequence": "1",
*             "primaryInd": true
*           }
*         }
*       ]
*     },
*     "mailingActions": {
*       "active": true
*     },
*     "privacyInfo": {
*       "marketResearchParticipation": true,
*       "infoFromThirdParty": true,
*       "autoEnrollLoyaltyProgram": false,
*       "allowPhone": true,
*       "allowSMS": true,
*       "allowEmail": true,
*       "optInMailingList": true,
*       "optInMarketResearch": true,
*       "optInThirdParty": true,
*       "optInAutoEnrollmentMember": true,
*       "optInPhone": true,
*       "optInSms": true,
*       "optInEmail": true
*     },
*     "taxInfo": {},
*     "statusCode": "Active",
*     "requestForHotel": "{{HotelId}}",
*     "markAsRecentlyAccessed": true,
*     "profileType": "Guest"
*   },
*   "profileIdList": [
*   ]
* }

loJson = CreateObject('Chilkat_9_5_0.JsonObject')
loJson.UpdateString("profileDetails.customer.personName[0].givenName","James")
loJson.UpdateString("profileDetails.customer.personName[0].surname","Smith")
loJson.UpdateString("profileDetails.customer.personName[0].nameType","Primary")
loJson.UpdateString("profileDetails.customer.personName[1].nameType","Alternate")
loJson.UpdateString("profileDetails.customer.personName[2].nameType","Incognito")
loJson.UpdateNewObject("profileDetails.customer.alienInfo")
loJson.UpdateString("profileDetails.customer.birthCountry.code","")
loJson.UpdateString("profileDetails.customer.language","E")
loJson.UpdateBool("profileDetails.addresses.addressInfo[0].address.isValidated",0)
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.addressLine[0]","3450 North Triumph Boulevard")
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.addressLine[1]","Suite 300")
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.addressLine[2]","")
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.addressLine[3]","")
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.cityName","Lehi")
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.postalCode","84043")
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.state","UT")
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.country.value","US")
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.language","E")
loJson.UpdateString("profileDetails.addresses.addressInfo[0].address.type","BUSINESS")
loJson.UpdateBool("profileDetails.addresses.addressInfo[0].address.primaryInd",1)
loJson.UpdateString("profileDetails.telephones.telephoneInfo[0].telephone.phoneTechType","PHONE")
loJson.UpdateString("profileDetails.telephones.telephoneInfo[0].telephone.phoneUseType","HOME")
loJson.UpdateString("profileDetails.telephones.telephoneInfo[0].telephone.phoneNumber","+1 385 555 0102")
loJson.UpdateString("profileDetails.telephones.telephoneInfo[0].telephone.orderSequence","1")
loJson.UpdateBool("profileDetails.telephones.telephoneInfo[0].telephone.primaryInd",1)
loJson.UpdateBool("profileDetails.mailingActions.active",1)
loJson.UpdateBool("profileDetails.privacyInfo.marketResearchParticipation",1)
loJson.UpdateBool("profileDetails.privacyInfo.infoFromThirdParty",1)
loJson.UpdateBool("profileDetails.privacyInfo.autoEnrollLoyaltyProgram",0)
loJson.UpdateBool("profileDetails.privacyInfo.allowPhone",1)
loJson.UpdateBool("profileDetails.privacyInfo.allowSMS",1)
loJson.UpdateBool("profileDetails.privacyInfo.allowEmail",1)
loJson.UpdateBool("profileDetails.privacyInfo.optInMailingList",1)
loJson.UpdateBool("profileDetails.privacyInfo.optInMarketResearch",1)
loJson.UpdateBool("profileDetails.privacyInfo.optInThirdParty",1)
loJson.UpdateBool("profileDetails.privacyInfo.optInAutoEnrollmentMember",1)
loJson.UpdateBool("profileDetails.privacyInfo.optInPhone",1)
loJson.UpdateBool("profileDetails.privacyInfo.optInSms",1)
loJson.UpdateBool("profileDetails.privacyInfo.optInEmail",1)
loJson.UpdateNewObject("profileDetails.taxInfo")
loJson.UpdateString("profileDetails.statusCode","Active")
loJson.UpdateString("profileDetails.requestForHotel","{{HotelId}}")
loJson.UpdateBool("profileDetails.markAsRecentlyAccessed",1)
loJson.UpdateString("profileDetails.profileType","Guest")
loJson.UpdateNewArray("profileIdList")

loHttp.SetRequestHeader("Content-Type","application/json")
loHttp.SetRequestHeader("x-app-key","{{AppKey}}")
loHttp.SetRequestHeader("x-hotelid","{{HotelId}}")
* Adds the "Authorization: Bearer <access_token>" header.
loHttp.AuthToken = "<access_token>"

loResp = loHttp.PostJson3("https://domain.com/crm/v1/profiles","application/json",loJson)
IF (loHttp.LastMethodSuccess = 0) THEN
    ? loHttp.LastErrorText
    RELEASE loHttp
    RELEASE loJson
    CANCEL
ENDIF

? STR(loResp.StatusCode)
? loResp.BodyStr
RELEASE loResp

RELEASE loHttp
RELEASE loJson

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 '{
    "profileDetails": {
        "customer": {
            "personName": [
                {
                    "givenName": "James",
                    "surname": "Smith",
                    "nameType": "Primary"
                },
                {
                    "nameType": "Alternate"
                },
                {
                    "nameType": "Incognito"
                }
            ],
            "alienInfo": {},
            "birthCountry": {
                "code": ""
            },
            "language": "E"
        },
        "addresses": {
            "addressInfo": [
                {
                    "address": {
                        "isValidated": false,
                        "addressLine": [
                            "3450 North Triumph Boulevard",
                            "Suite 300",
                            "",
                            ""
                        ],
                        "cityName": "Lehi",
                        "postalCode": "84043",
                        "state": "UT",
                        "country": {
                            "value": "US"
                        },
                        "language": "E",
                        "type": "BUSINESS",
                        "primaryInd": true
                    }
                }
            ]
        },
        "telephones": {
            "telephoneInfo": [
                {
                    "telephone": {
                        "phoneTechType": "PHONE",
                        "phoneUseType": "HOME",
                        "phoneNumber": "+1 385 555 0102",
                        "orderSequence": "1",
                        "primaryInd": true
                    }
                }
            ]
        },
        "mailingActions": {
            "active": true
        },
        "privacyInfo": {
            "marketResearchParticipation": true,
            "infoFromThirdParty": true,
            "autoEnrollLoyaltyProgram": false,
            "allowPhone": true,
            "allowSMS": true,
            "allowEmail": true,
            "optInMailingList": true,
            "optInMarketResearch": true,
            "optInThirdParty": true,
            "optInAutoEnrollmentMember": true,
            "optInPhone": true,
            "optInSms": true,
            "optInEmail": true
        },
        "taxInfo": {},
        "statusCode": "Active",
        "requestForHotel": "{{HotelId}}",
        "markAsRecentlyAccessed": true,
        "profileType": "Guest"
    },
    "profileIdList": []
}'
https://domain.com/crm/v1/profiles

Postman Collection Item JSON

{
  "name": "Create New Profile If one doesn't exist",
  "event": [
    {
      "listen": "test",
      "script": {
        "exec": [
          "var data = pm.response.headers.get(\"Location\").split(\"/\").pop();\r",
          "postman.setEnvironmentVariable(\"ProfileId\", data);"
        ],
        "type": "text/javascript"
      }
    }
  ],
  "request": {
    "auth": {
      "type": "bearer",
      "bearer": [
        {
          "key": "token",
          "value": "{{Token}}",
          "type": "string"
        }
      ]
    },
    "method": "POST",
    "header": [
      {
        "key": "Content-Type",
        "name": "Content-Type",
        "type": "text",
        "value": "application/json"
      },
      {
        "key": "x-app-key",
        "type": "text",
        "value": "{{AppKey}}"
      },
      {
        "key": "x-hotelid",
        "type": "text",
        "value": "{{HotelId}}"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n    \"profileDetails\": {\n        \"customer\": {\n            \"personName\": [\n                {\n                    \"givenName\": \"James\",\n                    \"surname\": \"Smith\",\n                    \"nameType\": \"Primary\"\n                },\n                {\n                    \"nameType\": \"Alternate\"\n                },\n                {\n                    \"nameType\": \"Incognito\"\n                }\n            ],\n            \"alienInfo\": {},\n            \"birthCountry\": {\n                \"code\": \"\"\n            },\n            \"language\": \"E\"\n        },\n        \"addresses\": {\n            \"addressInfo\": [\n                {\n                    \"address\": {\n                        \"isValidated\": false,\n                        \"addressLine\": [\n                            \"3450 North Triumph Boulevard\",\n                            \"Suite 300\",\n                            \"\",\n                            \"\"\n                        ],\n                        \"cityName\": \"Lehi\",\n                        \"postalCode\": \"84043\",\n                        \"state\": \"UT\",\n                        \"country\": {\n                            \"value\": \"US\"\n                        },\n                        \"language\": \"E\",\n                        \"type\": \"BUSINESS\",\n                        \"primaryInd\": true\n                    }\n                }\n            ]\n        },\n        \"telephones\": {\n            \"telephoneInfo\": [\n                {\n                    \"telephone\": {\n                        \"phoneTechType\": \"PHONE\",\n                        \"phoneUseType\": \"HOME\",\n                        \"phoneNumber\": \"+1 385 555 0102\",\n                        \"orderSequence\": \"1\",\n                        \"primaryInd\": true\n                    }\n                }\n            ]\n        },\n        \"mailingActions\": {\n            \"active\": true\n        },\n        \"privacyInfo\": {\n            \"marketResearchParticipation\": true,\n            \"infoFromThirdParty\": true,\n            \"autoEnrollLoyaltyProgram\": false,\n            \"allowPhone\": true,\n            \"allowSMS\": true,\n            \"allowEmail\": true,\n            \"optInMailingList\": true,\n            \"optInMarketResearch\": true,\n            \"optInThirdParty\": true,\n            \"optInAutoEnrollmentMember\": true,\n            \"optInPhone\": true,\n            \"optInSms\": true,\n            \"optInEmail\": true\n        },\n        \"taxInfo\": {},\n        \"statusCode\": \"Active\",\n        \"requestForHotel\": \"{{HotelId}}\",\n        \"markAsRecentlyAccessed\": true,\n        \"profileType\": \"Guest\"\n    },\n    \"profileIdList\": []\n}",
      "options": {
        "raw": {
          "language": "json"
        }
      }
    },
    "url": {
      "raw": "{{HostName}}/crm/v1/profiles",
      "host": [
        "{{HostName}}"
      ],
      "path": [
        "crm",
        "v1",
        "profiles"
      ]
    }
  },
  "response": [
  ]
}