Back to Collection Items
var
http: TChilkatHttp;
success: Integer;
xml: TChilkatXml;
sbRequestBody: TChilkatStringBuilder;
resp: IChilkatHttpResponse;
begin
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http := TChilkatHttp.Create(Self);
// 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"?>
// <contract-term>
// <name>API Contract Term 1</name>
// <contract-term-type>PriceRangeContractTerm</contract-term-type>
// <use-pct-discounts type="boolean">true</use-pct-discounts>
// <tier-1-upper-bound type="decimal">15.0</tier-1-upper-bound>
// <tier-1-disc-pct type="decimal">6.0</tier-1-disc-pct>
// <tier-2-disc-pct type="decimal">7.0</tier-2-disc-pct>
// </contract-term>
//
xml := TChilkatXml.Create(Self);
xml.Tag := 'contract-term';
xml.UpdateChildContent('name','API Contract Term 1');
xml.UpdateChildContent('contract-term-type','PriceRangeContractTerm');
xml.UpdateAttrAt('use-pct-discounts',1,'type','boolean');
xml.UpdateChildContent('use-pct-discounts','true');
xml.UpdateAttrAt('tier-1-upper-bound',1,'type','decimal');
xml.UpdateChildContent('tier-1-upper-bound','15.0');
xml.UpdateAttrAt('tier-1-disc-pct',1,'type','decimal');
xml.UpdateChildContent('tier-1-disc-pct','6.0');
xml.UpdateAttrAt('tier-2-disc-pct',1,'type','decimal');
xml.UpdateChildContent('tier-2-disc-pct','7.0');
// Adds the "Authorization: Bearer <access_token>" header.
http.AuthToken := '<access_token>';
sbRequestBody := TChilkatStringBuilder.Create(Self);
xml.GetXmlSb(sbRequestBody.ControlInterface);
resp := http.PTextSb('POST','https://domain.com/contracts/:id/contract_terms',sbRequestBody.ControlInterface,'utf-8','application/xml',0,0);
if (http.LastMethodSuccess = 0) then
begin
Memo1.Lines.Add(http.LastErrorText);
Exit;
end;
Memo1.Lines.Add(IntToStr(resp.StatusCode));
Memo1.Lines.Add(resp.BodyStr);
Curl Command
curl -X POST
-H "Authorization: Bearer <access_token>"
-d '<?xml version="1.0" encoding="UTF-8"?>
<contract-term>
<name>API Contract Term 1</name>
<contract-term-type>PriceRangeContractTerm</contract-term-type>
<use-pct-discounts type="boolean">true</use-pct-discounts>
<tier-1-upper-bound type="decimal">15.0</tier-1-upper-bound>
<tier-1-disc-pct type="decimal">6.0</tier-1-disc-pct>
<tier-2-disc-pct type="decimal">7.0</tier-2-disc-pct>
</contract-term>'
https://domain.com/contracts/:id/contract_terms
Postman Collection Item JSON
{
"name": "Add contract term",
"request": {
"method": "POST",
"header": [
],
"body": {
"mode": "raw",
"raw": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<contract-term>\n <name>API Contract Term 1</name>\n <contract-term-type>PriceRangeContractTerm</contract-term-type>\n <use-pct-discounts type=\"boolean\">true</use-pct-discounts>\n <tier-1-upper-bound type=\"decimal\">15.0</tier-1-upper-bound>\n <tier-1-disc-pct type=\"decimal\">6.0</tier-1-disc-pct>\n <tier-2-disc-pct type=\"decimal\">7.0</tier-2-disc-pct>\n</contract-term>",
"options": {
"raw": {
"language": "xml"
}
}
},
"url": {
"raw": "{{URL}}/contracts/:id/contract_terms",
"host": [
"{{URL}}"
],
"path": [
"contracts",
":id",
"contract_terms"
],
"variable": [
{
"key": "id",
"value": "377",
"type": "string"
}
]
}
},
"response": [
]
}