Chilkat Online Tools

VB6 / Commercetools / AddAttributeDefinition

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.

' {
'   "version": "{{version}}",
'   "actions": [
'     {
'       "action": "addAttributeDefinition"
'     }
'   ]
' }

Dim json As New ChilkatJsonObject
success = json.UpdateString("version","{{version}}")
success = json.UpdateString("actions[0].action","addAttributeDefinition")

' Adds the "Authorization: Bearer <access_token>" header.
http.AuthToken = "<access_token>"
http.SetRequestHeader "Content-Type","application/json"

Dim sbRequestBody As New ChilkatStringBuilder
success = json.EmitSb(sbRequestBody)

Dim resp As ChilkatHttpResponse
Set resp = http.PTextSb("post","https://domain.com/{{project-key}}/product-types/{{product-type-id}}",sbRequestBody,"utf-8","application/json",0,0)
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"
	-d '{
    "version": {{product-type-version}},
    "actions": [
                |{
            "action": "addAttributeDefinition"
        }
    ]
}'
https://domain.com/{{project-key}}/product-types/{{product-type-id}}

Postman Collection Item JSON

{
  "name": "AddAttributeDefinition",
  "event": [
    {
      "listen": "test",
      "script": {
        "type": "text/javascript",
        "exec": [
          "tests[\"Status code \" + responseCode.code] = responseCode.code === 200 || responseCode.code === 201;",
          "var data = JSON.parse(responseBody);",
          "if(data.results && data.results[0] && data.results[0].id && data.results[0].version){",
          "    pm.environment.set(\"product-type-id\", data.results[0].id); ",
          "    pm.environment.set(\"product-type-version\", data.results[0].version);",
          "}",
          "if(data.results && data.results[0] && data.results[0].key){",
          "    pm.environment.set(\"product-type-key\", data.results[0].key); ",
          "}",
          "if(data.version){",
          "    pm.environment.set(\"product-type-version\", data.version);",
          "}",
          "if(data.id){",
          "    pm.environment.set(\"product-type-id\", data.id); ",
          "}",
          "if(data.key){",
          "    pm.environment.set(\"product-type-key\", data.key);",
          "}",
          ""
        ]
      }
    }
  ],
  "request": {
    "auth": {
      "type": "oauth2",
      "oauth2": {
        "accessToken": "{{ctp_access_token}}",
        "addTokenTo": "header",
        "tokenType": "Bearer"
      }
    },
    "method": "post",
    "body": {
      "mode": "raw",
      "raw": "{\n    \"version\": {{product-type-version}},\n    \"actions\": [\n                |{\n            \"action\": \"addAttributeDefinition\"\n        }\n    ]\n}"
    },
    "header": [
      {
        "key": "Content-Type",
        "value": "application/json"
      }
    ],
    "url": {
      "raw": "{{host}}/{{project-key}}/product-types/{{product-type-id}}",
      "host": [
        "{{host}}"
      ],
      "path": [
        "{{project-key}}",
        "product-types",
        "{{product-type-id}}"
      ],
      "query": [
        {
          "key": "expand",
          "value": "",
          "equals": true,
          "disabled": true
        }
      ]
    },
    "description": "post ProductTypes"
  },
  "response": [
  ]
}