annotate xml/getAmazonInfo.php @ 32:8130865e9e82

refactor to try to improve error handling
author Charlie Root
date Fri, 04 Jan 2019 09:50:55 -0500
parents 4124f103b46b
children c9d9b76ecbf9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4
a6b55ae70617 original
robert
parents:
diff changeset
1 <?php
a6b55ae70617 original
robert
parents:
diff changeset
2
a6b55ae70617 original
robert
parents:
diff changeset
3 function getAmazonDet($isbn,$go,$localeIn)
a6b55ae70617 original
robert
parents:
diff changeset
4 {
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
5 $Adefault=array(
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
6 'language' =>'en', //what language to render the page in
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
7 'locale' =>$localeIn, //which server's products? available: ca,de,fr,jp,uk,us
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
8 //'mode' =>'books', //what product category?
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
9 'page' =>1, //first page to show (we are counting from 1 not 0)
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
10 //'search' =>'Machiavelli', //what to search for?
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
11 'operation' =>'ItemLookup', //what to do? //ItemSearch
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
12 // 'searchindex' =>'Books', //what product category for search?
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
13 'searchparameter' =>'ItemId', //what kind of search?
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
14 'searchparameterdata'=>$isbn, //what to search for?
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
15 //here some debugging flags you can put at the end of the URL to call this script with, like: '?show_array=true'
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
16 'show_array' =>false, //debug: show complete incoming array? You can use this to see what other information Amazon is sending
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
17 'show_url' =>false, //debug: show XML request url to be send to Amazon?
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
18 'show_xml' =>false, //debug: show incoming XML code from Amazon?
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
19 );
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
20 //change the debug options to true if you want to activate them or call the script with '?show_array=true' to see what actual information you're getting from Amazon and how little my standard script is actually showing of it
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
21 //for all parameters see if the user has overruled it or use the default
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
22 foreach ($Adefault as $i=>$d) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
23 $$i=isset($_GET[$i])?$_GET[$i]:$d;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
24 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
25 switch($locale){
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
26 case "us":
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
27 $loc = 0;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
28 break;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
29 case "uk":
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
30 $loc = 1;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
31 break;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
32 case "ca":
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
33 $loc = 2;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
34 break;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
35 case "de":
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
36 $loc = 3;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
37 break;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
38 case "fr":
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
39 $loc = 4;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
40 break;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
41 };
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
42
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
43 for ($i=1; $i<=3; $i++) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
44 try {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
45 return getAmazonDetRemote($go,$language,$locale,$loc,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
46 $page,$operation,$searchparameter,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
47 $searchparameterdata,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
48 $show_array,$show_url,$show_xml);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
49 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
50 catch (Exception $code) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
51 file_put_contents('/var/ywww/debug/phpDebug',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
52 "Bang: $code $i\n",FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
53 if ($code=='RequestThrottled') {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
54 usleep(200000); // Try to reduce throttling until we get a
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
55 // principled solution in place
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
56 $bail=False;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
57 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
58 else {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
59 $bail=True;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
60 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
61 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
62 if ($bail) { break; }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
63 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
64 return getAmazonDetLocal($go,$language,$loc,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
65 $page,$operation,$searchparameter,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
66 $searchparameterdata,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
67 $show_array,$show_url,$show_xml);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
68 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
69
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
70 function getAmazonDetRemote($go,$language,$locale,$loc,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
71 $page,$operation,$searchparameter,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
72 $searchparameterdata,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
73 $show_array,$show_url,$show_xml)
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
74 {
4
a6b55ae70617 original
robert
parents:
diff changeset
75 global $output;
a6b55ae70617 original
robert
parents:
diff changeset
76
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
77 $Aassociates_id=array(
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
78 'uk' => 'bookwhack-21',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
79 'us' => 'your02b-20',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
80 'ca' => 'book009-20',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
81 'de' => 'book04c-21',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
82 'fr' => 'book07f-21',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
83 );
4
a6b55ae70617 original
robert
parents:
diff changeset
84
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
85 $Aserver=array(
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
86 'ca' => array(
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
87 'ext' => 'ca' , //Canadian normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
88 'nor' => 'http://www.amazon.ca' , //Canadian normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
89 'xml' => 'http://xml.amazon.com' , //Canadian xml server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
90 ),
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
91 'de' => array(
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
92 'ext' => 'de' , //German normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
93 'nor' => 'http://www.amazon.de' , //German normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
94 'xml' => 'http://xml-eu.amazon.com', //German xml server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
95 ),
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
96 'fr' => array(
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
97 'ext' => 'fr' , //French normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
98 'nor' => 'http://www.amazon.fr' , //French normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
99 'xml' => 'http://xml-eu.amazon.com', //French xml server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
100 ),
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
101 'jp' => array(
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
102 'ext' => 'jp' , //Japanese normal server, not co.jp!
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
103 'nor' => 'http://www.amazon.co.jp' , //Japanese normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
104 'xml' => 'http://xml.amazon.com' , //Japanese xml server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
105 ),
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
106 'uk' => array(
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
107 'ext' => 'co.uk' , //UK normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
108 'nor' => 'http://www.amazon.co.uk' , //UK normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
109 'xml' => 'http://xml-eu.amazon.com', //UK xml server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
110 ),
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
111 'us' => array(
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
112 'ext' => 'com' , //USA normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
113 'nor' => 'http://www.amazon.com' , //USA normal server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
114 'xml' => 'http://xml.amazon.com' , //USA xml server
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
115 ),
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
116 );
4
a6b55ae70617 original
robert
parents:
diff changeset
117
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
118 //if(go != 1)
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
119 //include "aws_signed_request.php";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
120 $public_key ="AKIAIHTNWC7L6LOUY4LQ";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
121 $private_key="zWQlIzndJDtXNfxEXH7K7YR7hzv3u77lOcqfqPde";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
122 //this is the data that is used to form the request for AWS
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
123 //this is the part that is search specific
4
a6b55ae70617 original
robert
parents:
diff changeset
124 $parameters=array(
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
125 'Operation' =>$operation ,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
126 //'Keywords' =>urlencode($search) ,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
127 //'SearchIndex' =>$searchindex , //Books for example.
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
128 "$searchparameter"=>$searchparameterdata ,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
129 'ItemPage' =>$page , //which page?
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
130 'AssociateTag' =>$Aassociates_id[$locale],
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
131 'ResponseGroup' =>'ItemAttributes,Reviews,EditorialReview,OfferSummary,Offers,Images,AlternateVersions,SalesRank,BrowseNodes' , //Small, Medium, Large or SellerListing,'BrowseNodes',// ,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
132 'ReviewSort' =>'-HelpfulVotes'
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
133 );
4
a6b55ae70617 original
robert
parents:
diff changeset
134
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
135 $requestURI = $_SERVER['REQUEST_URI'];
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
136 $requestIP = $_SERVER['REMOTE_ADDR'];
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
137 // if ($requestIP=="173.161.113.65" || $requestIP=="141.8.132.25") {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
138 // $delay=60;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
139 // file_put_contents('/var/ywww/debug/phpDebug',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
140 // "bad guy: $requestIP, $requestURI\n",
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
141 // FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
142 // sleep($delay);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
143 // # No, can't do this
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
144 // # return; # bomb!
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
145 // # 'Kung', sitting on my desk in the office while I'm at home,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
146 // # is occasionally hitting xml/getAmazonInfo.php:
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
147 // # e.g. Losing: ItemLookupErrorResponse, RequestThrottled, 129.215.197.36, /xml/getAmazonInfo.php?searchparameterdata=075154454X&locale=uk
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
148 // # repeatedly, same params
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
149 // }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
150 $ext=$Aserver[$locale]['ext'];
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
151 $file_data=$ext;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
152 ksort($parameters);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
153 foreach ($parameters as $i=>$d) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
154 $file_data.='&'.$i.'='.$d;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
155 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
156 $gotit=0;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
157 $url=aws_signed_request($ext,$parameters,$public_key,$private_key);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
158 $crl = curl_init();
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
159 $timeout = 5;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
160 curl_setopt ($crl, CURLOPT_URL,$url);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
161 curl_setopt ($crl, CURLOPT_ENCODING , "gzip");
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
162 curl_setopt ($crl, CURLOPT_RETURNTRANSFER, 1);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
163 curl_setopt ($crl, CURLOPT_CONNECTTIMEOUT, $timeout);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
164 $semaphore = new SyncSemaphore("Amazon");
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
165 $gotit = $semaphore->lock(1000);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
166 if (!$gotit) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
167 file_put_contents('/var/ywww/debug/phpDebug',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
168 "Got it: ".(int)$gotit." $requestIP 1\n",FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
169 $gotit=$semaphore->lock(1000);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
170 file_put_contents('/var/ywww/debug/phpDebug',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
171 "Got it: ".(int)$gotit." $requestIP 1a\n",FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
172 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
173 $output = curl_exec($crl);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
174 curl_close($crl);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
175 usleep(500000);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
176 if ($gotit) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
177 $semaphore->unlock();
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
178 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
179 else {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
180 file_put_contents('/var/ywww/debug/phpDebug',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
181 "W/o lock for $requestIP 1b\n",FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
182 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
183 $review = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
184 $review1 = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
185 $review2 = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
186 $review3 = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
187 // HST added this
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
188 $mm=array();
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
189 if (preg_match("/<Error>/",$output,$mm)) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
190 $xml = new SimpleXMLElement($output);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
191 $resName=$xml->getName();
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
192 $code=$xml->Error->Code;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
193 if (!$code) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
194 $code=$xml->Items->Request->Errors->Error->Code;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
195 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
196 file_put_contents('/var/ywww/debug/phpDebug',"Losing: ".$mm[0].", $resName, $code, $requestIP, $requestURI\n",FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
197 if ($code!='RequestThrottled') {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
198 file_put_contents('/var/ywww/debug/phpDebug',"parms: $go\nurl: $url\n".
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
199 print_r($parameters,TRUE)."\n",FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
200 if ($code=="") {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
201 file_put_contents('/var/ywww/debug/phpDebug',"error elt:\n$output\n",FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
202 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
203 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
204 throw new Exception($code);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
205 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
206 else {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
207 $xml = new SimpleXMLElement($output);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
208 set_error_handler(function () {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
209 global $output;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
210 file_put_contents('/var/ywww/debug/phpDebug',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
211 "Caught one?: ".$searchparameterdata,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
212 FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
213 file_put_contents('/var/ywww/debug/phpDebug',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
214 print_r($output, TRUE)."\n",
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
215 FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
216 } );
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
217 $review = $xml->Items->Item->CustomerReviews->IFrameURL;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
218 // The above is failing repeatedly --
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
219 //PHP Notice: Trying to get property of non-object in
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
220 // /var/ywww/xml/getAmazonInfo.php on line [109]
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
221 // See the dumped structure at the end of this file for the
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
222 // cause
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
223 restore_error_handler();
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
224 //echo $review;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
225 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
226 if ($review != "")
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
227 {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
228 $text = @file_get_contents($review . "&truncate=300");
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
229 $removeTop1 = preg_replace('~<div class="crIFrameHeaderLeftColumn">(.*?)<div class="crIFrameHeaderHistogram">~si', '', $text);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
230 $removeTop2 = preg_replace('~<div class="crIFrameHeaderHistogram">(.*?)<div class="crIframeReviewList">~si', '', $text);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
231 if (preg_match('~<body[^>]*>(.*?)</body>~si', $removeTop2, $body)){ $getBody = trim($body[1]); } else { $getBody = $removeTop2;}
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
232 $removeDiv = preg_replace('~<div[^>]*>(.*?)</div>~si', '', $getBody);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
233 $removeCloseDivs = preg_replace('/<\/div>/','', $removeDiv);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
234 $setBoundary = str_replace('<!-- BOUNDARY -->','BOTTOM-TOP', $removeCloseDivs);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
235 //replace <!-- BOUNDARY --> with BOTTOM-TOP
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
236 $remove1 = '~<table cellpadding="0"(.*?)%">~s';
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
237 $setBoundary = preg_replace($remove1,'', $setBoundary);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
238 $remove2 = '~</td><td bg(.*?)</table>~s';
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
239 $setBoundary = preg_replace($remove2,'', $setBoundary);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
240 $remove3 = '~<a name=(.*?)</a>~s';
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
241 $setBoundary = preg_replace($remove3,'', $setBoundary);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
242 $setBoundary2 = str_replace('<br />','', $setBoundary);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
243 //remove all extra crap;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
244 $setBoundary3 = str_replace('</td>','BOTTOM', $setBoundary2);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
245 //replace </td> with BOTTOM
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
246
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
247 if (preg_match_all('~TOP(.*?)BOTTOM~s', $setBoundary3, $reviews))
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
248 {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
249 $reviewContents = $reviews[1];
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
250 //print_r($reviewContents);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
251 $review1 = trim($reviewContents[0]);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
252 $review1 = str_replace("\n", "", $review1);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
253 $review1 = str_replace("\r", "", $review1);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
254 if (isset($reviewContents[1])) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
255 $review2 = trim($reviewContents[1]);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
256 $review2 = str_replace("\n", "", $review2);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
257 $review2 = str_replace("\r", "", $review2);
7
1dfe64e365a0 a bit more debugging/bomb-proofing
Robert Boland <robert@markup.co.uk>
parents: 5
diff changeset
258 }
9
232deb0b066a tidy up debugging, only show parms on non-throttled error
Henry S. Thompson <ht@markup.co.uk>
parents: 7
diff changeset
259 else {
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
260 $review2 = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
261 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
262 if (isset($reviewContents[2])) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
263 $review3 = trim($reviewContents[2]);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
264 $review3 = str_replace("\n", "", $review3);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
265 $review3 = str_replace("\r", "", $review3);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
266 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
267 else {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
268 $review3 = "";
9
232deb0b066a tidy up debugging, only show parms on non-throttled error
Henry S. Thompson <ht@markup.co.uk>
parents: 7
diff changeset
269 }
5
55445b456ad0 short-circuit error response handling, add debugging
robert
parents: 4
diff changeset
270 }
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
271 else
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
272 {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
273 $review1 = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
274 $review2 = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
275 $review3 = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
276 //echo "EPIC FAIL";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
277 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
278
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
279 unset($xml->Items->Item->CustomerReviews);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
280 $xdoc = new DomDocument;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
281 $xdoc->loadXML($xml->asXML());
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
282
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
283 $cReviews = $xdoc ->createElement('CustomerReviews');
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
284 $cReviewHolder = $xdoc ->createElement('Review');
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
285 $cReview = $xdoc ->createElement('Content');
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
286 $cReviewHolder2 = $xdoc ->createElement('Review');
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
287 $cReview2 = $xdoc ->createElement('Content');
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
288 $cReviewHolder3 = $xdoc ->createElement('Review');
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
289 $cReview3 = $xdoc ->createElement('Content');
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
290
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
291 $txtNode = $xdoc ->createTextNode ($review1);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
292 $cReview -> appendChild($txtNode);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
293
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
294 $txtNode2 = $xdoc ->createTextNode ($review2);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
295 $cReview2 -> appendChild($txtNode2);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
296
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
297 $txtNode3 = $xdoc ->createTextNode ($review3);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
298 $cReview3 -> appendChild($txtNode3);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
299
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
300 $cReviewHolder -> appendChild($cReview);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
301 $cReviewHolder2 -> appendChild($cReview2);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
302 $cReviewHolder3 -> appendChild($cReview3);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
303
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
304 $cReviews -> appendChild($cReviewHolder);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
305 $cReviews -> appendChild($cReviewHolder2);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
306 $cReviews -> appendChild($cReviewHolder3);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
307
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
308 $xdoc->documentElement->childNodes->item(1)->childNodes->item(1)->appendChild($cReviews);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
309 $newXML = simplexml_import_dom($xdoc);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
310 $output = $newXML->asXml();
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
311 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
312
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
313 if($go == 1) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
314 $item = $xml->Items->Item[0];
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
315 if ($item && $item->ItemAttributes && $item->ItemAttributes->Title) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
316 $title = $item->ItemAttributes->Title; }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
317 else { $title = "[no title]"; };
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
318 file_put_contents('/var/ywww/debug/phpDebug',"win: |$errorCode| ".
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
319 $title."\n",
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
320 FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
321 return $output;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
322 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
323 else
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
324 {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
325 if ($xml->Items->Item) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
326 $title = $xml->Items->Item[0]->ItemAttributes->Title;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
327 $author = $xml->Items->Item[0]->ItemAttributes->Author;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
328 $binding = $xml->Items->Item[0]->ItemAttributes->Binding;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
329 $dewey = $xml->Items->Item[0]->ItemAttributes->DeweyDecimalNumber;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
330 if($dewey == "")
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
331 $dewey = "null";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
332 $imageURL = $xml->Items->Item[0]->MediumImage->URL;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
333 $salesRank = $xml->Items->Item[0]->SalesRank;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
334 $pubDate = $xml->Items->Item[0]->ItemAttributes->PublicationDate;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
335 if (strlen($pubDate)==4) { $pubDate=$pubDate."-01-01";}
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
336 if (strlen($pubDate)==7) { $pubDate=$pubDate."-01";}
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
337 if (strlen($pubDate)==0) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
338 $pubDate="null";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
339 }
5
55445b456ad0 short-circuit error response handling, add debugging
robert
parents: 4
diff changeset
340 else {
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
341 $pubDate="\"$pubDate\"";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
342 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
343 $publisher = $xml->Items->Item[0]->ItemAttributes->Publisher;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
344 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
345 else {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
346 $title = $salesRank = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
347 $dewey = "null";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
348 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
349
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
350 $genreID = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
351 $genre = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
352 $genArr = array();
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
353
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
354 if ($xml->Items->Item[0] && $xml->Items->Item[0]->BrowseNodes) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
355 for($i=0;$i<sizeof($xml->Items->Item->BrowseNodes->BrowseNode);$i++){
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
356 //sexy recursive function
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
357 findGenre($xml->Items->Item->BrowseNodes->BrowseNode[$i], $genreID, $genre);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
358
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
359 if($genre != "")
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
360 $genArr[strval($genreID)] = strval($genre);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
361 //$genArr[$i] = array(strval($genreID) => strval($genre));
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
362
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
363 //echo $genre;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
364 //echo $genreID;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
365
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
366 $genre = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
367 $genreID = "";
5
55445b456ad0 short-circuit error response handling, add debugging
robert
parents: 4
diff changeset
368 }
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
369 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
370
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
371 $g1 = "null";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
372 $g2 = "null";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
373 $g3 = "null";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
374 $loop = 1;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
375
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
376 foreach ($genArr as $key => $value) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
377 //echo "$key => $value";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
378 if ($key>2047) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
379 //HST added
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
380 break;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
381 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
382 $queryG = "CALL b_addBrowseNode($key,\"$value\")"; //add the name value pair for genre to new table
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
383 //echo $queryG;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
384 include "../../private/db.php";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
385 $resG = mysqli_query($link, $queryG);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
386 mysqli_close($link);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
387
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
388 switch ($loop) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
389 case 1:
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
390 $g1 = $key;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
391 break;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
392 case 2:
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
393 $g2 = $key;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
394 break;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
395 case 3:
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
396 $g3 = $key;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
397 break;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
398 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
399
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
400 $loop++;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
401 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
402
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
403 if($salesRank == "")
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
404 $salesRank = "null";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
405
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
406 if($title != "")
4
a6b55ae70617 original
robert
parents:
diff changeset
407 {
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
408 include "../../private/db.php";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
409 if ($publisher->count()==0) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
410 $publisher="null";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
411 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
412 else {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
413 $publisher=mysqli_real_escape_string($link,$publisher);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
414 if (strlen($publisher)>30) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
415 $publisher=rtrim(substr($publisher,0,30),"\\");
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
416 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
417 $publisher="\"".$publisher."\"";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
418 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
419 if ($author->count()==0) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
420 $author="unknown";
5
55445b456ad0 short-circuit error response handling, add debugging
robert
parents: 4
diff changeset
421 }
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
422 else {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
423 $author=mysqli_real_escape_string($link,$author);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
424 if (strlen($author)>30) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
425 $author=rtrim(substr($author,0,30),"\\");
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
426 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
427 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
428 $author="\"".$author."\"";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
429 $title=mysqli_real_escape_string($link,$title);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
430 if (strlen($title)>100) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
431 $title=rtrim(substr($title,0,100),"\\");
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
432 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
433 $title="\"".$title."\"";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
434 $review1 = mysqli_real_escape_string($link,$review1);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
435 if (strlen($review1)>500) { $review1=rtrim(substr($review1,0,500),"\\");}
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
436 $review2 = mysqli_real_escape_string($link,$review2);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
437 if (strlen($review2)>500) { $review2=rtrim(substr($review2,0,500),"\\");}
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
438 $review3 = mysqli_real_escape_string($link,$review3);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
439 if (strlen($review3)>500) { $review3=rtrim(substr($review3,0,500),"\\");}
4
a6b55ae70617 original
robert
parents:
diff changeset
440
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
441 $queryInsert = "CALL b_addNewBook(\"$searchparameterdata\",$title, $author,\"$binding\",\"$imageURL\", $dewey, $salesRank,$pubDate,$publisher,$g1,$g2,$g3,$loc)";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
442 //echo $queryInsert;
25
828895488948 more db column protection
Robert Boland <robert@markup.co.uk>
parents: 23
diff changeset
443
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
444 $res = mysqli_query($link, $queryInsert);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
445 if (!$res) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
446 $err=mysqli_error( $link );
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
447 mysqli_close($link);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
448 file_put_contents('/var/ywww/debug/phpDebug',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
449 "anb failed: $queryInsert\n$err\n",
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
450 FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
451 exit($err);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
452 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
453 $queryInsertReviews = "CALL b_insertReviews(\"$searchparameterdata\",\"$review1\",\"$review2\",\"$review3\")";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
454 if($review1 != "") {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
455 $res = mysqli_query($link, $queryInsertReviews);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
456 if (!$res) {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
457 $err=mysqli_error( $link );
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
458 mysqli_close($link);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
459 file_put_contents('/var/ywww/debug/phpDebug',
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
460 "anr failed: $queryInsertReviews\n",
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
461 FILE_APPEND);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
462 exit($err);
19
84a412b8122c try to protect against a range of missing info
Charlie Root
parents: 18
diff changeset
463 }
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
464 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
465 mysqli_close($link); //do not remove. reset is needed otherwise mysqli_fetch_array doesn't work after first loop
4
a6b55ae70617 original
robert
parents:
diff changeset
466 }
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
467
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
468 echo $output;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
469 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
470 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
471
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
472 function getAmazonDetLocal($go,$language,$loc,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
473 $page,$operation,$searchparameter,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
474 $searchparameterdata,
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
475 $show_array,$show_url,$show_xml)
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
476 {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
477 global $output;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
478 //look up info from db
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
479 include "../../private/db.php";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
480 $query = "CALL b_getBookInfo('$searchparameterdata', $loc)";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
481 //echo $query;
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
482 $res = mysqli_query($link, $query) or exit( mysqli_error( $link ));
4
a6b55ae70617 original
robert
parents:
diff changeset
483
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
484 $output = "";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
485 $output .= "<?xml version=\"1.0\" encoding=\"UTF-8\"?>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
486 $output .= "<Details>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
487 if ( mysqli_num_rows( $res ) > 0 )
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
488 {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
489 $rows=mysqli_fetch_array($res, MYSQLI_ASSOC);
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
490 mysqli_close($link); //do not remove. reset is needed otherwise mysqli_fetch_array doesn't work after first loop
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
491 $output .= "<ASIN>" . $searchparameterdata . "</ASIN>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
492 $output .= "<Title>" . htmlspecialchars($rows["Title"]) . "</Title>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
493 $output .= "<Author>" . htmlspecialchars($rows["Author"]) . "</Author>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
494 $output .= "<Binding>" . htmlspecialchars($rows["Binding"]) . "</Binding>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
495 $output .= "<Dewey>" . htmlspecialchars($rows["DeweyDecimal"]) . "</Dewey>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
496 $output .= "<ImageURL>" . htmlspecialchars($rows["ImageURL"]) . "</ImageURL>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
497 $output .= "<SalesRank>" . htmlspecialchars($rows["SalesRank"]) . "</SalesRank>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
498 $output .= "<PublicationDate>" . htmlspecialchars($rows["PublicationDate"]) . "</PublicationDate>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
499 $output .= "<Publisher>" . htmlspecialchars($rows["Publisher"]) . "</Publisher>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
500 $output .= "<Genre1>" . htmlspecialchars($rows["Genre1"]) . "</Genre1>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
501 $output .= "<Genre2>" . htmlspecialchars($rows["Genre2"]) . "</Genre2>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
502 $output .= "<Genre3>" . htmlspecialchars($rows["Genre3"]) . "</Genre3>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
503 $output .= "<ProductGroup>Book</ProductGroup>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
504 $output .= "<Error>AccountLimitExceeded</Error>";
4
a6b55ae70617 original
robert
parents:
diff changeset
505
32
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
506 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
507 else {
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
508 mysqli_close($link); //do not remove. reset is needed otherwise mysqli_fetch_array doesn't work after first loop
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
509 }
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
510 $output .= "</Details>";
8130865e9e82 refactor to try to improve error handling
Charlie Root
parents: 31
diff changeset
511 echo $output;
4
a6b55ae70617 original
robert
parents:
diff changeset
512 }
a6b55ae70617 original
robert
parents:
diff changeset
513
a6b55ae70617 original
robert
parents:
diff changeset
514 function findGenre($browseNode, &$ID, &$gen)
a6b55ae70617 original
robert
parents:
diff changeset
515 {
a6b55ae70617 original
robert
parents:
diff changeset
516 if($browseNode->Name == "Subjects")
a6b55ae70617 original
robert
parents:
diff changeset
517 {
a6b55ae70617 original
robert
parents:
diff changeset
518 return true;
a6b55ae70617 original
robert
parents:
diff changeset
519 }
a6b55ae70617 original
robert
parents:
diff changeset
520 else
a6b55ae70617 original
robert
parents:
diff changeset
521 {
a6b55ae70617 original
robert
parents:
diff changeset
522 if($browseNode->Ancestors->BrowseNode)
a6b55ae70617 original
robert
parents:
diff changeset
523 {
a6b55ae70617 original
robert
parents:
diff changeset
524 if(findGenre($browseNode->Ancestors->BrowseNode, $ID, $gen) == true)
a6b55ae70617 original
robert
parents:
diff changeset
525 {
a6b55ae70617 original
robert
parents:
diff changeset
526 $gen = $browseNode->Name;
a6b55ae70617 original
robert
parents:
diff changeset
527 $ID = $browseNode->BrowseNodeId;
a6b55ae70617 original
robert
parents:
diff changeset
528 }
a6b55ae70617 original
robert
parents:
diff changeset
529 }
a6b55ae70617 original
robert
parents:
diff changeset
530 return false;
a6b55ae70617 original
robert
parents:
diff changeset
531 }
a6b55ae70617 original
robert
parents:
diff changeset
532 }
a6b55ae70617 original
robert
parents:
diff changeset
533
a6b55ae70617 original
robert
parents:
diff changeset
534 if(!isset($ret))
a6b55ae70617 original
robert
parents:
diff changeset
535 {
a6b55ae70617 original
robert
parents:
diff changeset
536 include "aws_signed_request.php";
a6b55ae70617 original
robert
parents:
diff changeset
537 getAmazonDet('default',0,'us'); //will get overwritten
a6b55ae70617 original
robert
parents:
diff changeset
538 }
a6b55ae70617 original
robert
parents:
diff changeset
539 /*Caught oneSimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
540 (
a6b55ae70617 original
robert
parents:
diff changeset
541 [OperationRequest] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
542 (
a6b55ae70617 original
robert
parents:
diff changeset
543 [RequestId] => d2eaacba-2411-44e7-b268-f23a20167330
a6b55ae70617 original
robert
parents:
diff changeset
544 [Arguments] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
545 (
a6b55ae70617 original
robert
parents:
diff changeset
546 [Argument] => Array
a6b55ae70617 original
robert
parents:
diff changeset
547 (
a6b55ae70617 original
robert
parents:
diff changeset
548 [0] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
549 (
a6b55ae70617 original
robert
parents:
diff changeset
550 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
551 (
a6b55ae70617 original
robert
parents:
diff changeset
552 [Name] => AWSAccessKeyId
17
ae1459564f66 Replace old associate keys with new IAMs user keys
Robert Boland <robert@markup.co.uk>
parents: 11
diff changeset
553 [Value] => AKIAIHTNWC7L6LOUY4LQ
4
a6b55ae70617 original
robert
parents:
diff changeset
554 )
a6b55ae70617 original
robert
parents:
diff changeset
555
a6b55ae70617 original
robert
parents:
diff changeset
556 )
a6b55ae70617 original
robert
parents:
diff changeset
557
a6b55ae70617 original
robert
parents:
diff changeset
558 [1] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
559 (
a6b55ae70617 original
robert
parents:
diff changeset
560 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
561 (
a6b55ae70617 original
robert
parents:
diff changeset
562 [Name] => AssociateTag
a6b55ae70617 original
robert
parents:
diff changeset
563 [Value] => bookwhack-21
a6b55ae70617 original
robert
parents:
diff changeset
564 )
a6b55ae70617 original
robert
parents:
diff changeset
565
a6b55ae70617 original
robert
parents:
diff changeset
566 )
a6b55ae70617 original
robert
parents:
diff changeset
567
a6b55ae70617 original
robert
parents:
diff changeset
568 [2] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
569 (
a6b55ae70617 original
robert
parents:
diff changeset
570 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
571 (
a6b55ae70617 original
robert
parents:
diff changeset
572 [Name] => ItemId
a6b55ae70617 original
robert
parents:
diff changeset
573 [Value] => B004Q3Q3Y4
a6b55ae70617 original
robert
parents:
diff changeset
574 )
a6b55ae70617 original
robert
parents:
diff changeset
575
a6b55ae70617 original
robert
parents:
diff changeset
576 )
a6b55ae70617 original
robert
parents:
diff changeset
577
a6b55ae70617 original
robert
parents:
diff changeset
578 [3] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
579 (
a6b55ae70617 original
robert
parents:
diff changeset
580 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
581 (
a6b55ae70617 original
robert
parents:
diff changeset
582 [Name] => ItemPage
a6b55ae70617 original
robert
parents:
diff changeset
583 [Value] => 1
a6b55ae70617 original
robert
parents:
diff changeset
584 )
a6b55ae70617 original
robert
parents:
diff changeset
585
a6b55ae70617 original
robert
parents:
diff changeset
586 )
a6b55ae70617 original
robert
parents:
diff changeset
587
a6b55ae70617 original
robert
parents:
diff changeset
588 [4] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
589 (
a6b55ae70617 original
robert
parents:
diff changeset
590 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
591 (
a6b55ae70617 original
robert
parents:
diff changeset
592 [Name] => Operation
a6b55ae70617 original
robert
parents:
diff changeset
593 [Value] => ItemLookup
a6b55ae70617 original
robert
parents:
diff changeset
594 )
a6b55ae70617 original
robert
parents:
diff changeset
595
a6b55ae70617 original
robert
parents:
diff changeset
596 )
a6b55ae70617 original
robert
parents:
diff changeset
597
a6b55ae70617 original
robert
parents:
diff changeset
598 [5] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
599 (
a6b55ae70617 original
robert
parents:
diff changeset
600 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
601 (
a6b55ae70617 original
robert
parents:
diff changeset
602 [Name] => ResponseGroup
a6b55ae70617 original
robert
parents:
diff changeset
603 [Value] => ItemAttributes,Reviews,EditorialReview,OfferSummary,Offers,Images,AlternateVersions,SalesRank,BrowseNodes
a6b55ae70617 original
robert
parents:
diff changeset
604 )
a6b55ae70617 original
robert
parents:
diff changeset
605
a6b55ae70617 original
robert
parents:
diff changeset
606 )
a6b55ae70617 original
robert
parents:
diff changeset
607
a6b55ae70617 original
robert
parents:
diff changeset
608 [6] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
609 (
a6b55ae70617 original
robert
parents:
diff changeset
610 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
611 (
a6b55ae70617 original
robert
parents:
diff changeset
612 [Name] => ReviewSort
a6b55ae70617 original
robert
parents:
diff changeset
613 [Value] => -HelpfulVotes
a6b55ae70617 original
robert
parents:
diff changeset
614 )
a6b55ae70617 original
robert
parents:
diff changeset
615
a6b55ae70617 original
robert
parents:
diff changeset
616 )
a6b55ae70617 original
robert
parents:
diff changeset
617
a6b55ae70617 original
robert
parents:
diff changeset
618 [7] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
619 (
a6b55ae70617 original
robert
parents:
diff changeset
620 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
621 (
a6b55ae70617 original
robert
parents:
diff changeset
622 [Name] => Service
a6b55ae70617 original
robert
parents:
diff changeset
623 [Value] => AWSECommerceService
a6b55ae70617 original
robert
parents:
diff changeset
624 )
a6b55ae70617 original
robert
parents:
diff changeset
625
a6b55ae70617 original
robert
parents:
diff changeset
626 )
a6b55ae70617 original
robert
parents:
diff changeset
627
a6b55ae70617 original
robert
parents:
diff changeset
628 [8] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
629 (
a6b55ae70617 original
robert
parents:
diff changeset
630 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
631 (
a6b55ae70617 original
robert
parents:
diff changeset
632 [Name] => Timestamp
a6b55ae70617 original
robert
parents:
diff changeset
633 [Value] => 2016-12-15T23:12:34Z
a6b55ae70617 original
robert
parents:
diff changeset
634 )
a6b55ae70617 original
robert
parents:
diff changeset
635
a6b55ae70617 original
robert
parents:
diff changeset
636 )
a6b55ae70617 original
robert
parents:
diff changeset
637
a6b55ae70617 original
robert
parents:
diff changeset
638 [9] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
639 (
a6b55ae70617 original
robert
parents:
diff changeset
640 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
641 (
a6b55ae70617 original
robert
parents:
diff changeset
642 [Name] => Version
a6b55ae70617 original
robert
parents:
diff changeset
643 [Value] => 2011-08-01
a6b55ae70617 original
robert
parents:
diff changeset
644 )
a6b55ae70617 original
robert
parents:
diff changeset
645
a6b55ae70617 original
robert
parents:
diff changeset
646 )
a6b55ae70617 original
robert
parents:
diff changeset
647
a6b55ae70617 original
robert
parents:
diff changeset
648 [10] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
649 (
a6b55ae70617 original
robert
parents:
diff changeset
650 [@attributes] => Array
a6b55ae70617 original
robert
parents:
diff changeset
651 (
a6b55ae70617 original
robert
parents:
diff changeset
652 [Name] => Signature
a6b55ae70617 original
robert
parents:
diff changeset
653 [Value] => SUXfFZHQ74Joc+WDLx87uzemTdtHijNohykqafJXYKQ=
a6b55ae70617 original
robert
parents:
diff changeset
654 )
a6b55ae70617 original
robert
parents:
diff changeset
655
a6b55ae70617 original
robert
parents:
diff changeset
656 )
a6b55ae70617 original
robert
parents:
diff changeset
657
a6b55ae70617 original
robert
parents:
diff changeset
658 )
a6b55ae70617 original
robert
parents:
diff changeset
659
a6b55ae70617 original
robert
parents:
diff changeset
660 )
a6b55ae70617 original
robert
parents:
diff changeset
661
a6b55ae70617 original
robert
parents:
diff changeset
662 [RequestProcessingTime] => 0.3518217620000000
a6b55ae70617 original
robert
parents:
diff changeset
663 )
a6b55ae70617 original
robert
parents:
diff changeset
664
a6b55ae70617 original
robert
parents:
diff changeset
665 [Items] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
666 (
a6b55ae70617 original
robert
parents:
diff changeset
667 [Request] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
668 (
a6b55ae70617 original
robert
parents:
diff changeset
669 [IsValid] => True
a6b55ae70617 original
robert
parents:
diff changeset
670 [ItemLookupRequest] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
671 (
a6b55ae70617 original
robert
parents:
diff changeset
672 [IdType] => ASIN
a6b55ae70617 original
robert
parents:
diff changeset
673 [ItemId] => B004Q3Q3Y4
a6b55ae70617 original
robert
parents:
diff changeset
674 [ResponseGroup] => Array
a6b55ae70617 original
robert
parents:
diff changeset
675 (
a6b55ae70617 original
robert
parents:
diff changeset
676 [0] => ItemAttributes
a6b55ae70617 original
robert
parents:
diff changeset
677 [1] => Reviews
a6b55ae70617 original
robert
parents:
diff changeset
678 [2] => EditorialReview
a6b55ae70617 original
robert
parents:
diff changeset
679 [3] => OfferSummary
a6b55ae70617 original
robert
parents:
diff changeset
680 [4] => Offers
a6b55ae70617 original
robert
parents:
diff changeset
681 [5] => Images
a6b55ae70617 original
robert
parents:
diff changeset
682 [6] => AlternateVersions
a6b55ae70617 original
robert
parents:
diff changeset
683 [7] => SalesRank
a6b55ae70617 original
robert
parents:
diff changeset
684 [8] => BrowseNodes
a6b55ae70617 original
robert
parents:
diff changeset
685 )
a6b55ae70617 original
robert
parents:
diff changeset
686
a6b55ae70617 original
robert
parents:
diff changeset
687 [VariationPage] => All
a6b55ae70617 original
robert
parents:
diff changeset
688 )
a6b55ae70617 original
robert
parents:
diff changeset
689
a6b55ae70617 original
robert
parents:
diff changeset
690 [Errors] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
691 (
a6b55ae70617 original
robert
parents:
diff changeset
692 [Error] => SimpleXMLElement Object
a6b55ae70617 original
robert
parents:
diff changeset
693 (
a6b55ae70617 original
robert
parents:
diff changeset
694 [Code] => AWS.InvalidParameterValue
a6b55ae70617 original
robert
parents:
diff changeset
695 [Message] => B004Q3Q3Y4 is not a valid value for ItemId. Please change this value and retry your request.
a6b55ae70617 original
robert
parents:
diff changeset
696 )
a6b55ae70617 original
robert
parents:
diff changeset
697
a6b55ae70617 original
robert
parents:
diff changeset
698 )
a6b55ae70617 original
robert
parents:
diff changeset
699
a6b55ae70617 original
robert
parents:
diff changeset
700 )
a6b55ae70617 original
robert
parents:
diff changeset
701
a6b55ae70617 original
robert
parents:
diff changeset
702 )
a6b55ae70617 original
robert
parents:
diff changeset
703
a6b55ae70617 original
robert
parents:
diff changeset
704 )
a6b55ae70617 original
robert
parents:
diff changeset
705 */
21
46382face560 use a semaphore to try to cut down on RequestThrottled fails
Charlie Root
parents: 19
diff changeset
706 /*$xml = new SimpleXMLElement("<?xml version=\"1.0\"?><ItemLookupErrorResponse xmlns=\"http://ecs.amazonaws.com/doc/2009-03-31/\"><Error><Code>AccountLimitExceeded</Code><Message>Account limit of 2056 requests per hour exceeded.</Message></Error><RequestID>290ed059-730c-4789-93b4-6d21e11053d3</RequestID></ItemLookupErrorResponse>");*/
4
a6b55ae70617 original
robert
parents:
diff changeset
707 ?>