Sample code for 30+ languages & platforms
PHP Extension

effectconnect Read Orderlist

See more effectconnect Examples

Get a set of orders filtered by the parameters in the XML payload.

Chilkat PHP Extension Downloads

PHP Extension
<?php

include("chilkat.php");

$success = false;

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

$fullUri = 'https://submit.effectconnect.com/orderlist';
$uri = '/orderlist';
$apiVersion = '2.0';

$http = new CkHttp();

// Use your effectconnect public key here..
$http->SetRequestHeader('KEY','PUBLIC_KEY');
$http->SetRequestHeader('VERSION',$apiVersion);
$http->SetRequestHeader('URI',$uri);
$http->SetRequestHeader('RESPONSETYPE','XML');
$http->SetRequestHeader('RESPONSELANGUAGE','en');

// Get the current date/time in timestamp format.
$dt = new CkDateTime();
$dt->SetFromCurrentSystemTime();
$timestamp = $dt->getAsTimestamp(true);

$http->SetRequestHeader('TIME',$timestamp);
print 'timestamp = ' . $timestamp . "\n";

// Create the following XML request body:
// <?xml version="1.0" encoding="utf-8"?>
// <list>
//   <filters>
//     <fromDateFilter>
//       <filterValue>2018-09-14T12:12:12+01:00</filterValue>
//     </fromDateFilter>
//     <toDateFilter>
//       <filterValue>2019-04-13T23:59:59+01:00</filterValue>
//     </toDateFilter>
//     <hasStatusFilter>
//       <filterValue>paid</filterValue>
//     </hasStatusFilter>
//     <hasTagFilter>
//       <filterValue>
//         <tagName>Test</tagName>
//         <exclude>false</exclude>
//       </filterValue>
//     </hasTagFilter>
//   </filters>
// </list>

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

$xml = new CkXml();
$xml->put_Tag('list');
$xml->UpdateChildContent('filters|fromDateFilter|filterValue','2018-09-14T12:12:12+01:00');
$xml->UpdateChildContent('filters|toDateFilter|filterValue','2019-04-13T23:59:59+01:00');
$xml->UpdateChildContent('filters|hasStatusFilter|filterValue','paid');
$xml->UpdateChildContent('filters|hasTagFilter|filterValue|tagName','Test');
$xml->UpdateChildContent('filters|hasTagFilter|filterValue|exclude','false');
$xml->put_EmitCompact(true);

$sbXml = new CkStringBuilder();
$xml->GetXmlSb($sbXml);

// Build a string-to-sign and sign it using our effectconnect private key
$sbStringToSign = new CkStringBuilder();
$sbStringToSign->AppendInt($sbXml->get_Length());
$sbStringToSign->Append('POST');
$sbStringToSign->Append($uri);
$sbStringToSign->Append($apiVersion);
$sbStringToSign->Append($timestamp);

$crypt = new CkCrypt2();
$crypt->put_MacAlgorithm('hmac');
$crypt->put_HashAlgorithm('sha512');
$crypt->put_EncodingMode('base64');
// Use your effectconnect private key here:
$crypt->SetMacKeyString('PRIVATE_KEY');
$http->SetRequestHeader('SIGNATURE',$crypt->macStringENC($sbStringToSign->getAsString()));

// Send the POST..
$resp = new CkHttpResponse();
$success = $http->HttpStr('POST',$fullUri,$xml->getXml(),'utf-8','application/xml',$resp);
if ($success == false) {
    print $http->lastErrorText() . "\n";
    exit;
}

print 'response status code = ' . $resp->get_StatusCode() . "\n";

// Examine the response.  The response status code can be 200 for both errors and success.
// The success or error is based on the XML returned in the response body.
$xmlResp = new CkXml();
$xmlResp->LoadXml($resp->bodyStr());

print 'response body:' . "\n";
print $xmlResp->getXml() . "\n";

// Remove previously set headers (unless we want the same headers for the next request,
// in which case we may remove or update individual headers by calling SetRequestHeader.
$http->ClearHeaders();

?>