<?phpinclude("chilkat.php");
// Use "chilkat_9_5_0.php" for versions of Chilkat < 10.0.0
$xml = newCkXml();
$xml->put_Tag('soapenv:Envelope');
$xml->AddAttribute('xmlns:awd','http://www.wcc.nrcs.usda.gov/ns/awdbWebService');
$xml->AddAttribute('xmlns:soapenv','http://schemas.xmlsoap.org/soap/envelope/');
$xml->UpdateChildContent('soapenv:Header','');
$xml->UpdateChildContent('soapenv:Body|awd:getData|awd:stationTriplets','string');
$xml->UpdateChildContent('soapenv:Body|awd:getData|awd:elementCd','string');
$xml->UpdateChildContentInt('soapenv:Body|awd:getData|awd:ordinal',1042);
$xml->UpdateChildContent('soapenv:Body|awd:getData|awd:heightDepth|awd:unitCd','string');
$xml->UpdateChildContent('soapenv:Body|awd:getData|awd:heightDepth|awd:value','99.0');
$xml->UpdateChildContent('soapenv:Body|awd:getData|awd:duration','DAILY');
$xml->UpdateChildContent('soapenv:Body|awd:getData|awd:getFlags','true');
$xml->UpdateChildContent('soapenv:Body|awd:getData|awd:beginDate','string');
$xml->UpdateChildContent('soapenv:Body|awd:getData|awd:endDate','string');
$xml->UpdateChildContent('soapenv:Body|awd:getData|awd:alwaysReturnDailyFeb29','true');
// In a SOAP HTTP request, including the XML declaration (<?xml version="1.0" encoding="UTF-8"?>) in the XML body is generally not required.
$xml->put_EmitXmlDecl(false);
$soapRequestBody = $xml->getXml();
$endpoint = 'https://wcc.sc.egov.usda.gov/awdbWebService/services';
$soapAction = '';
// For SOAP requests, the standard Content-Type is usually set to "text/xml" or "application/soap+xml"
$contentType = 'text/xml';
$http = newCkHttp();
$http->ClearHeaders();
$http->SetRequestHeader('Content-Type',$contentType);
$http->SetRequestHeader('SOAPAction',$soapAction);
// resp is a CkHttpResponse
$resp = $http->PostXml($endpoint,$soapRequestBody,'utf-8');
if ($http->get_LastMethodSuccess() == false) {
print $http->lastErrorText() . "\n";
print'Failed to send SOAP request.' . "\n";
exit;
}
// Get the XML response body.
$responseXml = newCkXml();
$resp->GetBodyXml($responseXml);
$statusCode = $resp->get_StatusCode();
print'response status code: ' . $statusCode . "\n";
// If the status code does not indicate succcess, then show the response XML,
// which probably contains error information.if ($statusCode != 200) {
print $responseXml->getXml() . "\n";
exit;
}
print $responseXml->getXml() . "\n";
// Parse the successful SOAP response XML.// This is a sample of the response XML, but the namespace prefixes will be different.
// We can parse the result using "*" for the namespace prefixes (see below).
$beginDate = $responseXml->getChildContent('*:Body|*:getDataResponse|*:return|*:beginDate');
$collectionDates = $responseXml->getChildContent('*:Body|*:getDataResponse|*:return|*:collectionDates');
$duration = $responseXml->getChildContent('*:Body|*:getDataResponse|*:return|*:duration');
$endDate = $responseXml->getChildContent('*:Body|*:getDataResponse|*:return|*:endDate');
$flags = $responseXml->getChildContent('*:Body|*:getDataResponse|*:return|*:flags');
$stationTriplet = $responseXml->getChildContent('*:Body|*:getDataResponse|*:return|*:stationTriplet');
$values = $responseXml->getChildContent('*:Body|*:getDataResponse|*:return|*:values');
?>