Sample code for 30+ languages & platforms
PHP ActiveX

Xero Create Account

See more Xero Examples

Create new accounts in a Xero company.

Chilkat PHP ActiveX Downloads

PHP ActiveX
<?php

$success = 0;

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

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

$jsonToken = new COM("Chilkat.JsonObject");
$success = $jsonToken->LoadFile('qa_data/tokens/xero-access-token.json');
if ($success == 0) {
    print $jsonToken->LastErrorText . "\n";
    exit;
}

$http->AuthToken = $jsonToken->stringOf('access_token');

// Replace the value here with an actual tenant ID obtained from this example:
// Get Xero Tenant IDs
$http->SetRequestHeader('Xero-tenant-id','83299b9e-5747-4a14-a18a-a6c94f824eb7');

$http->Accept = 'application/json';

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

// {
//   "Code": "201",
//   "Name": "Sales - clearance lines",
//   "Type": "SALES"
// }

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

$jsonRequestBody = new COM("Chilkat.JsonObject");
$jsonRequestBody->UpdateString('Code','201');
$jsonRequestBody->UpdateString('Name','Sales - clearance lines');
$jsonRequestBody->UpdateString('Type','SALES');

$url = 'https://api.xero.com/api.xro/2.0/Accounts';

$resp = new COM("Chilkat.HttpResponse");
$success = $http->HttpJson('PUT',$url,$jsonRequestBody,'application/json',$resp);
if ($success == 0) {
    print $http->LastErrorText . "\n";
    exit;
}

print 'Response Status Code: ' . $resp->StatusCode . "\n";

$jsonResponse = new COM("Chilkat.JsonObject");
$jsonResponse->Load($resp->BodyStr);
$jsonResponse->EmitCompact = 0;
print $jsonResponse->emit() . "\n";

if ($resp->StatusCode >= 300) {
    print 'Failed.' . "\n";
    exit;
}

// Sample output...
// (See the parsing code below..)
// 
// Use the this online tool to generate parsing code from sample JSON: 
// Generate Parsing Code from JSON

// {
//   "Id": "705036aa-771d-4c0a-9d66-28904022858c",
//   "Status": "OK",
//   "ProviderName": "Chilkat2222",
//   "DateTimeUTC": "\/Date(1587161712234)\/",
//   "Accounts": [
//     {
//       "AccountID": "54ddab14-4a8d-45cf-86be-076c99a0cea0",
//       "Code": "201",
//       "Name": "Sales - clearance lines",
//       "Status": "ACTIVE",
//       "Type": "SALES",
//       "TaxType": "OUTPUT",
//       "Class": "REVENUE",
//       "EnablePaymentsToAccount": false,
//       "ShowInExpenseClaims": false,
//       "ReportingCode": "REV",
//       "ReportingCodeName": "Revenue",
//       "UpdatedDateUTC": "\/Date(1587161712283+0000)\/",
//       "AddToWatchlist": false
//     }
//   ]
// }
// 

$Id = $jsonResponse->stringOf('Id');
$Status = $jsonResponse->stringOf('Status');
$ProviderName = $jsonResponse->stringOf('ProviderName');
$DateTimeUTC = $jsonResponse->stringOf('DateTimeUTC');
$i = 0;
$count_i = $jsonResponse->SizeOfArray('Accounts');
while ($i < $count_i) {
    $jsonResponse->I = $i;
    $AccountID = $jsonResponse->stringOf('Accounts[i].AccountID');
    $Code = $jsonResponse->stringOf('Accounts[i].Code');
    $Name = $jsonResponse->stringOf('Accounts[i].Name');
    $Status = $jsonResponse->stringOf('Accounts[i].Status');
    $Type = $jsonResponse->stringOf('Accounts[i].Type');
    $TaxType = $jsonResponse->stringOf('Accounts[i].TaxType');
    $Class = $jsonResponse->stringOf('Accounts[i].Class');
    $EnablePaymentsToAccount = $jsonResponse->BoolOf('Accounts[i].EnablePaymentsToAccount');
    $ShowInExpenseClaims = $jsonResponse->BoolOf('Accounts[i].ShowInExpenseClaims');
    $ReportingCode = $jsonResponse->stringOf('Accounts[i].ReportingCode');
    $ReportingCodeName = $jsonResponse->stringOf('Accounts[i].ReportingCodeName');
    $UpdatedDateUTC = $jsonResponse->stringOf('Accounts[i].UpdatedDateUTC');
    $AddToWatchlist = $jsonResponse->BoolOf('Accounts[i].AddToWatchlist');
    $i = $i + 1;
}


?>