view xml/doAmazonRequest.php @ 60:05f29eb72283 default tip

review from DB not working???
author Charlie Root
date Sun, 09 Jun 2019 06:50:44 -0400
parents e4c78b3eace7
children
line wrap: on
line source

<?php
include_once "dlog.php";

include_once "web.php";
include "aws_signed_request.php";  

function doAmazonRequest($ext, $parameters, $try, $dbl='x', $wantXML=True)
{
  /* Uncomment next line to disable all requests from UK site */
  if ($ext=="co.uk") {
    throw new Exception("ThrottledRepeatedly");
  }
  global $public_key, $private_key;
  $requestURI = $_SERVER['REQUEST_URI'];
  $requestIP = $_SERVER['REMOTE_ADDR'];
  $file_data=$ext;
  ksort($parameters);
  foreach ($parameters as $i=>$d) {
    $file_data.='&'.$i.'='.$d;
  }
  $gotit=0;
  $url=aws_signed_request($ext,$parameters,$public_key,$private_key);  
  //dl("search: $ext $public_key $private_key\n$url\n".print_r($parameters,TRUE)."\n");
  for ($i=1; $i<=$try; $i++) {
    dl("dar: $requestIP $i\n");
    $crl = curl_init();
    $timeout = 5;
    curl_setopt ($crl, CURLOPT_URL,$url);
    curl_setopt ($crl, CURLOPT_ENCODING , "gzip"); 
    curl_setopt ($crl, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt ($crl, CURLOPT_CONNECTTIMEOUT, $timeout);
    $semaphore = new SyncSemaphore("Amazon".$ext);
    $gotit = $semaphore->lock(5000);
    if (!$gotit) {
      dl("No lock: $requestIP $dbl\n");
      for ($j=1; $j<=$try+4; $j++) {
	dl("dar: $requestIP $i $j\n");
	$gotit=$semaphore->lock(1000);
	if ($gotit) {
	  dl("Got it: $i $j $requestIP $dbl"."a\n");
	  break;
	}
      }
    }
    else {
      dl("Got it: $i ! $requestIP $dbl"."a\n");
    }
    if (!$gotit) {
      usleep(1000000);
      continue;
    }
    usleep(1000000);
    $output = curl_exec($crl);
    dl("nai2: $gotit ".strlen($output)."\n");
    curl_close($crl);
    $mm=array();
    try {
      $xml = new SimpleXMLElement($output);
    }
    catch (Exception $e) {
      dl("dar: bad output:\n$output\n");
      throw $e;
    }
    if (preg_match("/<Error>/",$output,$mm)) {
      $resName=$xml->getName();
      $code=$xml->Error->Code;
      if ($code) {
	$message=$xml->Error->Message;
      }
      else {
	$code=$xml->Items->Request->Errors->Error->Code;
	$message=$xml->Items->Request->Errors->Error->Message;
      }
      dl("Losing $i: $dbl ".
	 $mm[0].", $resName, $code, $requestIP, $requestURI\n");
      if ($code!='RequestThrottled') {
	dl("message: $message\n");
	if ($code=='AWS.InvalidParameterValue' && strpos($message,"for ItemId.")>0) {
	  // Check for common problem and try to fix...
	  $spd=$parameters['ItemId'];
	  if (strpos($spd,'/')>0) {
	    $isbnMaybe=substr($spd,0,strpos($spd,'/'));
	    $parameters['ItemId']=$isbnMaybe;
	    if (isset($parameters['Keywords'])) {
		$parameters['Keywords']=urlencode($isbnMaybe);
	      }
	    dl("retrying with $isbnMaybe\n");
	    if ($gotit) {
	      $semaphore->unlock();
	    }
	    return doAmazonRequest($ext,$parameters,$try,$dbl);
	  }
	}
	if ($code=="") {
	  dl("error elt:\n$output\n");
	}
	if ($gotit) {
	  $semaphore->unlock();
	}
	throw new Exception($code);
      }
    }
    else {
      if ($gotit) {
	$cnt=0;
	$semaphore->unlock($cnt);
	dl("unlocked: $i $cnt\n");
      }
      if ($wantXML) {
	return $xml;
      }
      else {
	//dl("returning ".strlen($output)."\n");
	return $output;
      }
    }
    usleep(100000*$i); // Try to reduce throttling until we get a 
    // principled solution in place
    if ($gotit) {
      $semaphore->unlock();
    }
  }
  throw new Exception("ThrottledRepeatedly");
}
?>