Mercurial > hg > ywww
comparison php/read/similar.php @ 6:077b0a0a3e6d
remaining originals according to dependency walk
author | Robert Boland <robert@markup.co.uk> |
---|---|
date | Thu, 16 Feb 2017 22:29:02 +0000 |
parents | |
children | 385ddd7c4b55 ae1459564f66 |
comparison
equal
deleted
inserted
replaced
5:55445b456ad0 | 6:077b0a0a3e6d |
---|---|
1 <?php | |
2 | |
3 function dbConnect($go) | |
4 { | |
5 if($go == 1) | |
6 { | |
7 return "../../private/db.php"; | |
8 } | |
9 else | |
10 { | |
11 return "../../../private/db.php"; | |
12 } | |
13 } | |
14 | |
15 function addAmazonSimilarBooks($isbn1, $loc, $go) | |
16 { | |
17 include dbConnect($go); | |
18 | |
19 $queryLoc = "CALL getLocation('$loc')"; //"select locname from location where LocID = $loc"; | |
20 $res = mysqli_query($link, $queryLoc) or exit( mysqli_error( $link )); | |
21 mysqli_close($link); //do not remove. reset is needed otherwise mysqli_fetch_array doesn't work after first loop | |
22 include dbConnect($go); | |
23 | |
24 $rows=mysqli_fetch_array($res, MYSQLI_ASSOC); | |
25 $locale=$rows['locname']; | |
26 | |
27 $Adefault=array( | |
28 'language' =>'en', //what language to render the page in | |
29 'locale' =>$locale, //which server's products? available: ca,de,fr,jp,uk,us | |
30 'page' =>1, | |
31 'operation' =>'SimilarityLookup', | |
32 'searchparameter' =>'ItemId', //what kind of search? | |
33 'searchparameterdata'=>$isbn1, //what to search for? | |
34 ); | |
35 | |
36 | |
37 $Aassociates_id=array( | |
38 'uk' => 'bookwhack-21', | |
39 'us' => 'your02b-20', | |
40 'ca' => 'book009-20', | |
41 'de' => 'book04c-21', | |
42 'fr' => 'book07f-21', | |
43 ); | |
44 | |
45 $Aserver=array( | |
46 'ca' => array( | |
47 'ext' => 'ca' , //Canadian normal server | |
48 'nor' => 'http://www.amazon.ca' , //Canadian normal server | |
49 'xml' => 'http://xml.amazon.com' , //Canadian xml server | |
50 ), | |
51 'de' => array( | |
52 'ext' => 'de' , //German normal server | |
53 'nor' => 'http://www.amazon.de' , //German normal server | |
54 'xml' => 'http://xml-eu.amazon.com', //German xml server | |
55 ), | |
56 'fr' => array( | |
57 'ext' => 'fr' , //French normal server | |
58 'nor' => 'http://www.amazon.fr' , //French normal server | |
59 'xml' => 'http://xml-eu.amazon.com', //French xml server | |
60 ), | |
61 'jp' => array( | |
62 'ext' => 'jp' , //Japanese normal server, not co.jp! | |
63 'nor' => 'http://www.amazon.co.jp' , //Japanese normal server | |
64 'xml' => 'http://xml.amazon.com' , //Japanese xml server | |
65 ), | |
66 'uk' => array( | |
67 'ext' => 'co.uk' , //UK normal server | |
68 'nor' => 'http://www.amazon.co.uk' , //UK normal server | |
69 'xml' => 'http://xml-eu.amazon.com', //UK xml server | |
70 ), | |
71 'us' => array( | |
72 'ext' => 'com' , //USA normal server | |
73 'nor' => 'http://www.amazon.com' , //USA normal server | |
74 'xml' => 'http://xml.amazon.com' , //USA xml server | |
75 ), | |
76 ); | |
77 | |
78 include "aws_signed_request.php"; | |
79 $public_key ="AKIAJBXEHTNCU6LLFNIA"; | |
80 $private_key="Dgyv7aR6uGe3OtY95Dj6hHpDS/UEtyboMWpJchYA"; | |
81 | |
82 //for all parameters see if the user has overruled it or use the default | |
83 foreach ($Adefault as $i=>$d) { | |
84 $$i=isset($_GET[$i])?$_GET[$i]:$d; | |
85 } | |
86 | |
87 $parameters=array( | |
88 'Operation' =>$operation , | |
89 //'Keywords' =>urlencode($search) , | |
90 //'SearchIndex' =>$searchindex , //Books for example. | |
91 "$searchparameter"=>$searchparameterdata , | |
92 'ItemPage' =>$page , //which page? | |
93 'AssociateTag' =>$Aassociates_id[$locale], | |
94 'ResponseGroup' =>'Small' , //Small, Medium, Large or SellerListing, Similarities | |
95 'Availability'=>'Available', | |
96 ); | |
97 | |
98 $ext=$Aserver[$locale]['ext']; | |
99 | |
100 $url=aws_signed_request($ext,$parameters,$public_key,$private_key); | |
101 //echo $url; | |
102 | |
103 $crl = curl_init(); | |
104 $timeout = 5; | |
105 curl_setopt ($crl, CURLOPT_URL,$url); | |
106 curl_setopt ($crl, CURLOPT_RETURNTRANSFER, 1); | |
107 curl_setopt ($crl, CURLOPT_CONNECTTIMEOUT, $timeout); | |
108 $ret = curl_exec($crl); | |
109 curl_close($crl); | |
110 //echo $ret; | |
111 | |
112 $xml = new SimpleXMLElement($ret); | |
113 | |
114 //$isbn1 = $xml->Items->Request->SimilarityLookupRequest->ItemId; | |
115 //echo $isbn1; | |
116 | |
117 $result = ""; | |
118 for($i=0;$i<sizeof($xml->Items->Item);$i++){ | |
119 foreach($xml->Items->Item[$i]->ASIN as $isbn2){ | |
120 // echo $isbn2; | |
121 | |
122 $group = $xml->Items->Item[$i]->ItemAttributes->ProductGroup; | |
123 | |
124 //foreach one of these, create a new request to check whether its a book. | |
125 //if it is then add it to the return (or add it to the database) | |
126 if($group == 'Book') | |
127 { | |
128 $query1 = "CALL b_getLinkID('$isbn1', '$isbn2', $loc)"; // "select ScoreID from scoretable where BookID1 = '$isbn1' and BookID2 = '$isbn2' and LocID = $loc"; | |
129 //echo $query1; | |
130 $data1 = mysqli_query($link, $query1) or exit( mysqli_error( $link )); | |
131 mysqli_close($link); //do not remove. reset is needed otherwise mysqli_fetch_array doesn't work after first loop | |
132 include dbConnect($go); | |
133 | |
134 if ( mysqli_num_rows( $data1 ) < 1 ) | |
135 { | |
136 $queryL = "CALL b_addNewLink('$isbn1','$isbn2',0,$loc)"; | |
137 //echo $queryL; | |
138 $results1 = mysqli_query($link, $queryL); | |
139 | |
140 $rows=mysqli_fetch_array($results1, MYSQLI_ASSOC); | |
141 $linkid=$rows['LinkID']; | |
142 | |
143 //reset connection | |
144 mysqli_close($link); //do not remove. reset is needed otherwise mysqli_fetch_array doesn't work after first loop | |
145 include dbConnect($go); | |
146 | |
147 //$scoreQuery = "CALL b_insertTempScore('$isbn1','$isbn2',$loc,$linkid,0)"; | |
148 //echo $scoreQuery; | |
149 //$scoreFinal = mysqli_query($link, $scoreQuery); | |
150 $result .= "<type>0</type>"; | |
151 $result .= "<isbn>" . $isbn2 . "</isbn>"; | |
152 $result .= "<linkID>" . trim($linkid) . "</linkID>"; | |
153 } | |
154 } | |
155 } | |
156 } | |
157 | |
158 return $result; | |
159 } | |
160 | |
161 ?> |