Chilkat Online Tools

C / Coupa Postman Collection - OAuth - Master / Create New Item

Back to Collection Items

#include <C_CkHttp.h>
#include <C_CkXml.h>
#include <C_CkStringBuilder.h>
#include <C_CkHttpResponse.h>

void ChilkatSample(void)
    {
    HCkHttp http;
    BOOL success;
    HCkXml xml;
    HCkStringBuilder sbRequestBody;
    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 XML: Generate Code to Create XML

    // The following XML is sent in the request body.

    // <?xml version="1.0" encoding="utf-8"?>
    // <item>
    //     <description>Birds for gifts</description>
    //     <item-number>2423152</item-number>
    //     <name>RUBBER HANGER BOOTS 1000/CS</name>
    //     <active type="boolean">true</active>
    //     <image-url>https://cdn.download.ams.birds.cornell.edu/api/v1/asset/202984001/1800</image-url>
    //     <manufacturer-name>IAMCompany</manufacturer-name>
    //     <manufacturer-part-number>IAM1244</manufacturer-part-number>
    //     <item-type>Item</item-type>
    //     <custom-fields>
    //         <gl-acct>1023</gl-acct>
    //     </custom-fields>
    //     <uom>
    //         <code>EA</code>
    //         <name>Each</name>
    //     </uom>
    // </item>
    // 

    xml = CkXml_Create();
    CkXml_putTag(xml,"item");
    CkXml_UpdateChildContent(xml,"description","Birds for gifts");
    CkXml_UpdateChildContentInt(xml,"item-number",2423152);
    CkXml_UpdateChildContent(xml,"name","RUBBER HANGER BOOTS 1000/CS");
    CkXml_UpdateAttrAt(xml,"active",TRUE,"type","boolean");
    CkXml_UpdateChildContent(xml,"active","true");
    CkXml_UpdateChildContent(xml,"image-url","https://cdn.download.ams.birds.cornell.edu/api/v1/asset/202984001/1800");
    CkXml_UpdateChildContent(xml,"manufacturer-name","IAMCompany");
    CkXml_UpdateChildContent(xml,"manufacturer-part-number","IAM1244");
    CkXml_UpdateChildContent(xml,"item-type","Item");
    CkXml_UpdateChildContentInt(xml,"custom-fields|gl-acct",1023);
    CkXml_UpdateChildContent(xml,"uom|code","EA");
    CkXml_UpdateChildContent(xml,"uom|name","Each");

    // Adds the "Authorization: Bearer <access_token>" header.
    CkHttp_putAuthToken(http,"<access_token>");

    sbRequestBody = CkStringBuilder_Create();
    CkXml_GetXmlSb(xml,sbRequestBody);

    resp = CkHttp_PTextSb(http,"POST","https://domain.com/items?fields=[\"id\",\"name\",\"item-number\"]",sbRequestBody,"utf-8","application/xml",FALSE,FALSE);
    if (CkHttp_getLastMethodSuccess(http) == FALSE) {
        printf("%s\n",CkHttp_lastErrorText(http));
        CkHttp_Dispose(http);
        CkXml_Dispose(xml);
        CkStringBuilder_Dispose(sbRequestBody);
        return;
    }

    printf("%d\n",CkHttpResponse_getStatusCode(resp));
    printf("%s\n",CkHttpResponse_bodyStr(resp));
    CkHttpResponse_Dispose(resp);


    CkHttp_Dispose(http);
    CkXml_Dispose(xml);
    CkStringBuilder_Dispose(sbRequestBody);

    }

Curl Command

curl -X POST
	-H "Authorization: Bearer <access_token>"
	-d '<item>
    <description>Birds for gifts</description>
    <item-number>2423152</item-number>
    <name>RUBBER HANGER BOOTS 1000/CS</name>
    <active type="boolean">true</active>
    <image-url>https://cdn.download.ams.birds.cornell.edu/api/v1/asset/202984001/1800</image-url>
    <manufacturer-name>IAMCompany</manufacturer-name>
    <manufacturer-part-number>IAM1244</manufacturer-part-number>
    <item-type>Item</item-type>
    <custom-fields>
    <gl-acct>1023</gl-acct>
    </custom-fields>
    <uom>
        <code>EA</code>
        <name>Each</name>
    </uom>
</item>'
https://domain.com/items?fields=["id","name","item-number"]

Postman Collection Item JSON

{
  "name": "Create New Item",
  "request": {
    "method": "POST",
    "header": [
    ],
    "body": {
      "mode": "raw",
      "raw": "<item>\n    <description>Birds for gifts</description>\n    <item-number>2423152</item-number>\n    <name>RUBBER HANGER BOOTS 1000/CS</name>\n    <active type=\"boolean\">true</active>\n    <image-url>https://cdn.download.ams.birds.cornell.edu/api/v1/asset/202984001/1800</image-url>\n    <manufacturer-name>IAMCompany</manufacturer-name>\n    <manufacturer-part-number>IAM1244</manufacturer-part-number>\n    <item-type>Item</item-type>\n    <custom-fields>\n    <gl-acct>1023</gl-acct>\n    </custom-fields>\n    <uom>\n        <code>EA</code>\n        <name>Each</name>\n    </uom>\n</item>",
      "options": {
        "raw": {
          "language": "xml"
        }
      }
    },
    "url": {
      "raw": "{{URL}}/items?fields=[\"id\",\"name\",\"item-number\"]",
      "host": [
        "{{URL}}"
      ],
      "path": [
        "items"
      ],
      "query": [
        {
          "key": "fields",
          "value": "[\"id\",\"name\",\"item-number\"]"
        }
      ]
    }
  },
  "response": [
  ]
}