Sample code for 30+ languages & platforms
PHP ActiveX

MYOB: Update a Category

See more MYOB Examples

Sends a PUT to update a category.

Chilkat PHP ActiveX Downloads

PHP ActiveX
<?php

$success = 0;

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

$http = new COM("Chilkat.Http");

// Implements the following CURL command:

// curl --request PUT "https://ar1.api.myob.com/accountright/c06778dd-4371-4a83-975f-522df65d7574/GeneralLedger/Category/{{category_id}}" \
//   --header "Authorization: Bearer ACCESS_TOKEN" \
//   --header "x-myobapi-key: This is your API Key" \
//   --header "x-myobapi-version: v2" \
//   --header "Accept-Encoding: gzip,deflate" \
//   --data "{
//             \"UID\": \"20b483b2-9a89-4793-b8c3-2da1a6284e1f\",
//             \"DisplayID\": \"Postman001\",
//             \"Name\": \"Postman sample\",
//             \"Description\": \"This has been updated via Postman\",
//             \"IsActive\": true,
//             \"RowVersion\": \"-8858580467037765632\"
//         }"

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

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

// {
//   "UID": "20b483b2-9a89-4793-b8c3-2da1a6284e1f",
//   "DisplayID": "Postman001",
//   "Name": "Postman sample",
//   "Description": "This has been updated via Postman",
//   "IsActive": true,
//   "RowVersion": "-8858580467037765632"
// }

$json = new COM("Chilkat.JsonObject");
$json->UpdateString('UID','20b483b2-9a89-4793-b8c3-2da1a6284e1f');
$json->UpdateString('DisplayID','Postman001');
$json->UpdateString('Name','Postman sample');
$json->UpdateString('Description','This has been updated via Postman');
$json->UpdateBool('IsActive',1);
$json->UpdateString('RowVersion','-8858580467037765632');

$http->SetRequestHeader('Authorization','Bearer ACCESS_TOKEN');
$http->SetRequestHeader('x-myobapi-key','This is your API Key');
$http->SetRequestHeader('Accept-Encoding','gzip,deflate');
$http->SetRequestHeader('x-myobapi-version','v2');

$sbRequestBody = new COM("Chilkat.StringBuilder");
$json->EmitSb($sbRequestBody);

$resp = new COM("Chilkat.HttpResponse");
$success = $http->HttpSb('PUT','https://ar1.api.myob.com/accountright/c06778dd-4371-4a83-975f-522df65d7574/GeneralLedger/Category/{{category_id}}',$sbRequestBody,'utf-8','application/json',$resp);
if ($success == 0) {
    print $http->LastErrorText . "\n";
    exit;
}

$respStatusCode = $resp->StatusCode;
print 'Response Status Code = ' . $respStatusCode . "\n";
if ($respStatusCode != 200) {
    print 'Response Header:' . "\n";
    print $resp->Header . "\n";
    print 'Response Body:' . "\n";
    print $resp->BodyStr . "\n";
    print 'Failed.' . "\n";
    exit;
}

print 'Success.' . "\n";

?>