ex02a_SoaGatewayEmpListSorted.php

<?php

/*
 * 	This example demonstrates usage of the "list" function exposed by any
 *  Adabas SOA Gateway "WebService" from PHP, retrieving selected records
 *	from the Adabas demo file "Employees", and formatting it, in 4 easy steps.
 */


/*
 * 	Step 1: Instantiate the PHP "SoapClient" class
 */
try {
	$soapclient = new SoapClient("http://localhost:8022/adabas_EmployeesMini?WSDL");
} catch (SoapFault $soapfault) {
	echo "<pre>";
	print_r($soapfault);
	echo "</pre>";
	return;
}

/*
 * 	Step 2: Build the key ("descriptor") array, due to parser requirements ALL
 * 			key elements need to be specified, but elements may be left empty
 * 			when unused.
 */
$listkey = array(
	'personnel_id' => '50005*',
	'first_name' => '',
	'name' => '',
	'city' => '');

/*
 * 	Step 3:	Execute the "list" request, passing the key array as the only parameter,
 * 			the response object will consist of an "adabasEmployees" element containing
 * 			an array of "adabasEmployee" elements.
 */
try {
	$listresponse = $soapclient->list($listkey);
} catch (SoapFault $soapfault) {
	echo "<pre>";
	print_r($soapfault);
	echo "</pre>";
	return;
}

echo "List of Employees by personnel id = 50005* - Default sort order<br><br>";
formatResponse($listresponse);

/*
 * 	Step 4: Build the SOAP Header structure to trigger a DESCENDING
 * 			read instead of an ascending one.
 */

$headers = array(
	'SOAGateway_Internal_Adabas_Sort_Order' => "city"
	);

$header =  new SoapHeader("http://www.risaris.com/namespaces/xmiddle",
							"adabasEmployeeHeader",
                            $headers, false);

$soapclient->__setSoapHeaders(array($header));

/*
 * 	Step 5:	Execute the "list" request, passing the key array as the only parameter,
 * 			the response object will consist of an "adabasEmployees" element containing
 * 			an array of "adabasEmployee" elements.
 */
try {
	$listresponse = $soapclient->list($listkey);
} catch (SoapFault $soapfault) {
	echo "<pre>";
	print_r($soapfault);
	echo "</pre>";
	return;
}

echo "<br><hr><br>List of Employees by personnel id = 50005* - now sorted by City<br><br>";
formatResponse($listresponse);

/*
 * 	Sub:	Format the Employee records nicely into a HTML table.
 */
function formatResponse($listresponse){

	echo "<table border=1 cellpadding=5>";
	echo "<tr><th>Personnel Id</th><th>Name</th><th>First Name</th><th>City</th><th width=200>Address Line</td>";

	/*
	 * 	Loop through all "adabasEmployee" elements, creating a table row for every single one
	 */
if ( isset($listresponse->adabasEmployees->adabasEmployee) )
{
	$Employees = $listresponse->adabasEmployees->adabasEmployee;
	if (!is_array($Employees))
		$Employees = $listresponse->adabasEmployees;

	foreach ($Employees as $Employee) {
		echo "<tr><td>$Employee->personnel_id</td><td>$Employee->name</td><td>$Employee->first_name</td><td>$Employee->city</td><td>";
		echo "<table>";

		if (!is_array($Employee->address_line)) {
			echo "<tr><td width=200>$Employee->address_line</td></tr>";
		} else	{
			foreach ($Employee->address_line as $addr) {
				echo "<tr><td width=200>$addr</td></tr>";
			}
		}
		echo "</table>";
		echo "</td></tr>";
	}

}

echo "</table>";
}
/*
 * 	Proceed to ex03_SoaGatewayEmpAdd.php - Add a new employee record
 */
?>