PK œqhYî¶J‚ßFßF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /home/trave494/allinonecryptonews.kerihosting.com/wp-content/plugins/wp-automatic/
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
IP: 209.182.202.254
Choose File :

Url:
Dir : /home/trave494/allinonecryptonews.kerihosting.com/wp-content/plugins/wp-automatic/core.amazon.php

<?php 

// Main Class
require_once 'core.php';

Class WpAutomaticAmazon extends wp_automatic{

			/*
			 * ---* Get Amazon Post ---
			 */
			function amazon_get_post($camp) {
				
				if( stristr($camp->camp_general, 'a:') ) $camp->camp_general=base64_encode($camp->camp_general);
				$camp_general = unserialize ( base64_decode( $camp->camp_general) );
				
				// reading keywords that need to be processed
				$keywords = explode ( ',', $camp->camp_keywords );
				
				// default cat 
				if(trim($camp->camp_amazon_cat) == ''){
					$camp->camp_amazon_cat = 'All';
				}
				
				foreach ( $keywords as $keyword ) {
					
					$keyword = trim($keyword);
					
					if (trim ( $keyword ) != '') {
						$keyword = trim ( $keyword );
						  echo ( '<hr><b>Processing Keyword:</b> "' . $keyword . '"' );
						 
						//update last keyword
						update_post_meta($camp->camp_id, 'last_keyword', trim($keyword));
						
						// getting links from the db for that keyword
						$query = "select * from {$this->wp_prefix}automatic_amazon_links where link_keyword='{$camp->camp_id}_$keyword' and link_status ='0'";
						$res = $this->db->get_results ( $query );
						
						// when no links lets get new links
						if (count ( $res ) == 0) {
							$this->amazon_fetch_links ( $keyword, $camp );

							// getting links from the db for that keyword
							$res = $this->db->get_results ( $query );
						}
						
						//delete already posted items from other campaigns
						//deleting duplicated items
						$res_count = count($res);
						for($i=0;$i< $res_count ;$i++){
						
							$t_row = $res[$i];
							
							$t_link_url=$t_row->link_url;
							
							//get amazon item by ASIN if not complete info
							if(! stristr($t_link_url, 'http')){
								
								$asin = $t_link_url;
								
								  echo '<br>Found ASIN:'.$asin.' getting complete details from Amazon...';
								
								$amazonPublic = get_option ( 'wp_amazonpin_abk', '' );
								$amazonSecret = get_option ( 'wp_amazonpin_apvtk', '' );
								$amazonAid = get_option ( 'wp_amazonpin_aaid', '' );
								$obj = new wp_automatic_AmazonProductAPI ( trim($amazonPublic), trim($amazonSecret) , trim($amazonAid), $camp->camp_amazon_region );
								
								try {
									
									$result = $obj->getItemByAsin($asin);
									$Item = $result->Items->Item;
									
								} catch (Exception $e) {
									  echo '<br>Amazon error:'.$e->getMessage();
								}
								 
								if(isset($Item->ASIN) && isset($Item->DetailPageURL)){
									
									  echo " Link : <a href=\"{$Item->DetailPageURL}\">{$Item->ItemAttributes->Title}</a> <br>";
									
									$desc = '';
									@$desc = $Item->EditorialReviews->EditorialReview->Content;
									
									//Features existence
									if(isset($Item->ItemAttributes->Feature)){
										  echo '-- Features found appending to the description';
										$desc .= implode( '<br>', (array) $Item->ItemAttributes->Feature );
									}
									
									 
									$title =  (string) $Item->ItemAttributes->Title ;
									
									// Author if exists, inject it to title
									if(isset($Item->ItemAttributes->Author)){
										$title .= '**' . $Item->ItemAttributes->Author ;
									}else{
										$title .= '** ' ;
									}
									
									// Brand if exists
									if(isset($Item->ItemAttributes->Brand)){
										$title .= '**' . $Item->ItemAttributes->Brand;
									}else{
										$title .= '** ' ;
									}
									
									
									$t_link_url = $linkUrl = (string)$Item->DetailPageURL;
										
									if( $this->is_execluded($camp->camp_id,  $linkUrl) ){
										  echo '<-- Execluded';
										continue;
									}
									
								
								
									$price= '';
								
									@$price=$Item->Offers->Offer->OfferListing->Price->FormattedPrice;
								
									if(trim($price) == ''){
										@$price=$Item->ItemAttributes->ListPrice->FormattedPrice;
									}
								
									if(trim($price) == ''){
										@$price = $Item->OfferSummary->LowestNewPrice->FormattedPrice;
									}
								
									if(trim($price) == ''){
										@$price = $Item->OfferSummary->LowestCollectiblePrice->FormattedPrice;
									}
								
									if(trim($price) == ''){
										@$price = $Item->OfferSummary->LowestUsedPrice->FormattedPrice;
									}
								
									if(trim($price) == ''){
										@$price = $Item->VariationSummary->LowestPrice->FormattedPrice;
									}
									
									//list price
									$ListPrice=$Item->ItemAttributes->ListPrice->FormattedPrice;
									
									if(trim($ListPrice) == ''){
										$ListPrice = $price;
									}
									
									//final saved price price,listprice
									$price=$price.'-'.$ListPrice;
								
									$imgurl = '';
									$imgurl=$Item->LargeImage->URL;
								
									if(trim($imgurl) == ''){
										//get it from the sets
										@$imgurl=$Item->ImageSets->ImageSet[0]->LargeImage->URL;
									}
								
									if(trim($imgurl) == ''){
										//get it from the sets
										@$imgurl=$Item->Variations->Item[0]->LargeImage->URL;
											
									}
									
									//Checking for an image set
									if(trim($imgurl) != ''){
										$imgSets = array();
										$img2url = '';
										$imgs = array();
										@$img2url = $Item->ImageSets->ImageSet[1]->LargeImage->URL;
											
										if(trim($img2url) != ''){
											// found an image set
											$imgSets = $Item->ImageSets->ImageSet;
											foreach($imgSets as $imgSet){
												$imgs[] = $imgSet->LargeImage->URL;
											}
									
											if(count($imgs) > 0){
												$imgs = implode(',', $imgs);
												$imgurl=$imgs;
											}
									
										}
											
									}
										
								
									//review url
									$review = $Item->CustomerReviews->IFrameURL;
								 
									//building the item
									$t_row->link_url = $linkUrl;
									$t_row->link_title = $title;
									$t_row->link_desc = (string)$desc;
									$t_row->link_price = (string)$price;
									$t_row->link_img =(string)$imgurl;
									$t_row->link_review =(string)$review;
									
									$res[$i] = $t_row;
									
								}else{ //valid returned item
									
									//delete non valid item
									$query = "update {$this->wp_prefix}automatic_amazon_links set link_status='1' where link_id=$t_row->link_id";
									$this->db->query ( $query );
									unset($res[$i]);
									
								}
							}//ASIN product
							
							
						
							if( $this->is_duplicate($t_link_url) ){
									
								//duplicated item let's delete
								unset($res[$i]);
									
								  echo '<br>Amazon Item ('. $t_row->link_title .') found cached but duplicated <a href="'.get_permalink($this->duplicate_id).'">#'.$this->duplicate_id.'</a>'  ;
									
								//delete the item
								$query = "update {$this->wp_prefix}automatic_amazon_links set link_status='1' where link_id=$t_row->link_id";
								$this->db->query ( $query );
									
							}else{
								if(stristr($t_link_url, 'http'))
								break;
							}
							
						}
						
						
						// check again if valid links found for that keyword otherwise skip it
						if (count ( $res ) > 0) {
							
							// lets process that link
							$ret = $res [$i];
							
							/*
							//fix commas and dots for es 
							if($camp->camp_amazon_region == 'es' || $camp->camp_amazon_region == 'de' || $camp->camp_amazon_region == 'fr'  || $camp->camp_amazon_region == 'it' ){
								
								$ret->link_price = str_replace(',','*',$ret->link_price);
								$ret->link_price = str_replace('.',',',$ret->link_price);
								$ret->link_price = str_replace('*','.',$ret->link_price);
								
							}
							*/
							
							//fix price split
							if(stristr($ret->link_price, '-')){
								
								//  echo '<br>Found Price:'.$ret->link_price;
								
								$priceParts = explode('-', $ret->link_price) ;
								
								$ret->link_price = $priceParts[0];
								$salePrice = $priceParts[1];
								
								
							}else{
								$salePrice = $ret->link_price;
							}
							
							
							$offer_title = $ret->link_title;
							
							$temp['product_author'] = '' ;
							$temp['product_brand']  = '' ;
							
							if(stristr($offer_title, '**')){
								
								$titleParts = explode('**', $offer_title) ;
								
								$offer_title = $titleParts[0];
								$temp['product_author'] = $titleParts[1];
								$temp['product_brand'] = $titleParts[2];
							}  
							
							
							$offer_desc = $ret->link_desc;
							$offer_url = $ret->link_url;
							$offer_price = trim($ret->link_price);
							$offer_img = $ret->link_img;
							
							
							
							$temp ['offer_title'] = $offer_title;
							$temp ['product_title'] = $offer_title;
							$temp ['offer_desc'] = $offer_desc;
							$temp ['product_desc'] = $offer_desc;
							$temp ['offer_url'] = $offer_url;
							$temp ['product_link'] = $offer_url;
							$temp ['source_link'] = $offer_url;
							$temp ['offer_price'] = $offer_price;
							$temp ['product_price'] = $offer_price;
							$temp ['product_list_price'] = $salePrice;
							$temp ['offer_img'] = $offer_img;
							$temp ['product_img'] = $offer_img;
							$temp ['price_numeric'] = '00.00';
							$temp ['price_currency'] = '$';
							
							//increasing expiration date of the review 
							$ret->link_review = preg_replace('{exp\=20\d\d}', 'exp=2030', $ret->link_review);
							$ret->link_review = str_replace('http://', '//', $ret->link_review); 
							
							$temp ['review_link'] = $ret->link_review; 
							$temp ['review_iframe'] = '<iframe style="width:100%;height:342px" class="wp_automatic_amazon_review" src="'.$ret->link_review.'" ></iframe>';
							
							//chart url 
							$enc_url = urldecode($offer_url);
							$enc_url = explode('?', $enc_url);
							$enc_parms =  $enc_url[1];
							$enc_parms_arr = explode('&',$enc_parms);
							
							$asin='';
							$tag = '' ;
							$subscription = '';
							
							foreach($enc_parms_arr as $param){
							
								if(stristr($param, 'creativeASIN')){
									$asin = str_replace('creativeASIN=', '', $param);
								}elseif(stristr($param, 'tag=')){
									$tag = str_replace('tag=', '', $param);
								}elseif( stristr($param, 'SubscriptionId')){
									$subscription = str_replace('SubscriptionId=', '', $param);
								}
							
							}
							
							  echo '<br>Product found: <a href="'.$ret->link_url.'">'.$asin.'</a>';
							
							$temp['product_asin'] = $asin;
							
							$region = $camp->camp_amazon_region;
							
							$chart_url = "http://www.amazon.$region/gp/aws/cart/add.html?AssociateTag=$tag&ASIN.1=$asin&Quantity.1=1&SubscriptionId=$subscription";
								
							
							$temp['chart_url'] = $chart_url;
							
							//price extraction 
							if(trim($ret->link_price) != ''){
								
								$thousandSeparator = ',';
								
								//restore commas and dots
								if($camp->camp_amazon_region == 'es' || $camp->camp_amazon_region == 'de' || $camp->camp_amazon_region == 'fr'  || $camp->camp_amazon_region == 'it' ){
									$thousandSeparator = '.';
								}
								
								//woo sousands separator 
								if ( class_exists( 'WooCommerce' ) ) {
									$woocommerce_price_thousand_sep = get_option('woocommerce_price_thousand_sep','');
									
									if($woocommerce_price_thousand_sep == '.' || $woocommerce_price_thousand_sep == ','){
										$thousandSeparator = $woocommerce_price_thousand_sep;
										  echo '<br>Woo Thusand separator:'.$woocommerce_price_thousand_sep;
									}
									
								}
								
							  echo '<br>Returned Price:'.$ret->link_price;
								
								//good we have a price 
								$price_no_commas = str_replace($thousandSeparator, '', $offer_price);
								preg_match('{\d.*\d}is', ($price_no_commas),$price_matches);
							 
								$temp ['price_numeric'] = $price_matches[0];
								$temp ['price_currency'] =str_replace($price_matches[0], '', $offer_price);
								
								//fixing listPrice
								$price_no_commas = str_replace($thousandSeparator, '', $salePrice);
								preg_match('{\d.*\d}is', ($price_no_commas),$price_matches);
								$temp ['list_price_numeric'] = $price_matches[0];
								
							}

							 
							$this->used_keyword = $ret->link_keyword;
							
							// update the link status to 1
							$query = "update {$this->wp_prefix}automatic_amazon_links set link_status='1' where link_id=$ret->link_id";
							$this->db->query ( $query );
							
							//fix imgSet
							$temp['product_imgs'] = $temp['product_img'];
							if(stristr($temp['product_img'], ',')){
								//imageset found
								$imgs = explode(',', $temp['product_imgs']);
								

								
								//swap last image to the top
								$imgsCount = count($imgs);
								$lastImageIndex = $imgsCount - 1;
								$lastImage = $imgs[$lastImageIndex];
								unset($imgs[$lastImageIndex]);
								$imgs = array_merge(array($lastImage),$imgs);
					 
								$temp['product_imgs'] = implode(',', $imgs);
								$temp['product_img'] = $temp['offer_img'] = $imgs[0];
								
							}
							
								//imgs html
								$cg_am_full_img_t = @$camp_general['cg_am_full_img_t'];
								
								if(trim($cg_am_full_img_t) == ''){
									$cg_am_full_img_t = '<img src="[img_src]" class="wp_automatic_gallery" />';
								}
								
								$product_imgs_html = '' ;
								
								$allImages = explode(',', $temp['product_imgs']);
								$allImages_html = '';
								
								foreach($allImages as $singleImage){
									
									$singleImageHtml = $cg_am_full_img_t;
									$singleImageHtml = str_replace('[img_src]', $singleImage, $singleImageHtml);
									$allImages_html.= $singleImageHtml;	
								}
								
								$temp['product_imgs_html'] = $allImages_html;

							  //product price with discount
								if($temp ['product_price'] == $temp ['product_list_price']){
									$temp['price_with_discount_fixed'] = $temp ['product_price'];
								}else{
									$temp['price_with_discount_fixed'] = '<del>'.$temp ['product_list_price'].'</del> - '. $temp ['product_price'] ;
								}
							
								
								
							return $temp;
						} else {
							
							//return false;
						}
					} // trim
				} // foreach keyword
			}
			
			/*
			 * ---* Get Amazon links ---
			 */
			function amazon_fetch_links($keyword, $camp) {
				  echo "<br>Requesting links from Amazon for keyword: \"" . $keyword.'"...';
				
				// ini
				$md5 = md5($keyword);
				$camp_opt = unserialize ( $camp->camp_options );
				
				if( stristr($camp->camp_general, 'a:') ) $camp->camp_general=base64_encode($camp->camp_general);
				$camp_general = unserialize ( base64_decode( $camp->camp_general) );
				
				$camp_general=array_map('wp_automatic_stripslashes', $camp_general);
				$amazonPublic = get_option ( 'wp_amazonpin_abk', '' );
				$amazonSecret = get_option ( 'wp_amazonpin_apvtk', '' );
				$amazonAid = get_option ( 'wp_amazonpin_aaid', '' );
				
				if (trim ( $amazonPublic ) == '' || trim ( $amazonSecret ) == '' || trim ( $amazonAid ) == '') {
					$this->log ( 'Error', 'Amazon Public Key,Private Key and associate id required visit settings and add them' );
					  echo '<br>Amazon Public Key,Private Key and associate id required visit settings and add them';
					return false;
				}
				
				// using clickbank
				$clickkey =   ( $keyword );
				
				// getting start
				$query = "select  * from {$this->wp_prefix}automatic_keywords where keyword_name='$keyword' and keyword_camp = {$camp->camp_id} ";
				$ret = $this->db->get_results ( $query );
				
				$row = $ret [0];
				$start = $row->amazon_start;
				
				//max api pages
				if($camp->camp_amazon_cat == 'All'){
					$maxApiPages = 5 ;
				}else{
					$maxApiPages = 10 ;
				}
				
				//check if scrapping
				$moreUrl = get_post_meta( $camp->camp_id, $md5.'_more',1);
				if($start > $maxApiPages && trim($moreUrl) != ''){
					
					  echo '<br>API reached limit for items returned for this keyword which is '.$maxApiPages.' pages 10 products per page';
					
					$scrapePage = $start - $maxApiPages + 1 ;
					
					  echo '<br>Scrapping Amazon page '.$scrapePage.' for new items.';
					
					
					
					$scrapeURL = $moreUrl.'&page='.$scrapePage;
					
					 
					
					//high price and low price 
					if(in_array('OPT_AM_PRICE', $camp_opt)){
						$cg_am_min = $camp_general['cg_am_min'];
						$cg_am_max = $camp_general['cg_am_max'];
						
						if(trim($cg_am_min) != '' && is_numeric($cg_am_min)){
							$scrapeURL.= '&low-price='.$cg_am_min/100;
						}
						
						if(trim($cg_am_max) != '' && is_numeric($cg_am_max)){
							$scrapeURL.= '&high-price='.$cg_am_max/100;
						}
					}
					
					//sort
					if(in_array('OPT_AM_ORDER', $camp_opt)){
						$cg_am_order = trim($camp_general['cg_am_order']);
						if($cg_am_order != '') $scrapeURL.= '&sort='.$cg_am_order;
					}
					
					  echo '<br>Scrape URL: '.$scrapeURL;
					
					$obj = new wp_automatic_AmazonProductAPI ( trim($amazonPublic), trim($amazonSecret) , trim($amazonAid), $camp->camp_amazon_region );
					
					
					try {
						$ASINs = $obj->getASINs($scrapeURL, $this->ch);
						
						foreach ($ASINs as $ASIN){
							  echo '<br>ASIN:'.$ASIN;
							$linkKeyword = "{$camp->camp_id}_$keyword";
							//$query = "INSERT INTO {$this->wp_prefix}automatic_amazon_links ( link_url , link_title , link_keyword  , link_status ,link_desc,link_price,link_img,link_review)VALUES ( '$linkUrl', '$title', '{$camp->camp_id}_$keyword', '0','$desc','{$price}','{$imgurl}','{$review}')";
							$query = "INSERT INTO {$this->wp_prefix}automatic_amazon_links (link_url,link_keyword , link_status) SELECT * FROM (SELECT '$ASIN' , '$linkKeyword' , '0' ) AS tmp WHERE NOT EXISTS ( SELECT link_url FROM wp_automatic_amazon_links WHERE link_url like '%$ASIN' ) LIMIT 1";
							$insert =  $this->db->query ( $query );
							
							if ( $insert != false){
								  echo '<-- NEW';
							}
							 
						}
						
						if(count($ASINs) == 0){
							
							// there was no links lets deactivate
							$newstart = '-1';
							$query = "update {$this->wp_prefix}automatic_keywords set amazon_start  = '$newstart' where keyword_name='$keyword'  and keyword_camp = {$camp->camp_id} ";
							$this->db->query ( $query );
								
							//deactivate key for a week 
							if(! in_array('OPT_NO_DEACTIVATE', $camp_opt))
								$this->deactivate_key($camp->camp_id, $keyword, 0 );
									
							  echo '<br>No more items at amazon to get deactivating the keyword permanently';
									
							
						}else{
							//increase start
							$newstart = $start + 1;
							$query = "update {$this->wp_prefix}automatic_keywords set  amazon_start  = '$newstart' where keyword_name='$keyword'  and keyword_camp = {$camp->camp_id} ";
							$this->db->query ( $query );
						}
						
						return;
						
					} catch (Exception $e) {
						  echo '<br>Exception: '.$e->getMessage();
						return;
					}
					 
				}
				
				// check if the start = -1 this means the keyword is exhausted
				if ($start == '-1' || $start == 11) {
					  echo "<br>Keyword \"$keyword\" is already exhausted and does not have any new links to fetch.";
					
					//check if it is reactivated or still deactivated
					if($this->is_deactivated($camp->camp_id, $keyword)){
						$start =1;
					}else{
						//still deactivated
						return false;
					}
					 
				}
				
				  echo '<br>Current page is :' . $start;
				
				// amazon
				
				$obj = new wp_automatic_AmazonProductAPI ( trim($amazonPublic), trim($amazonSecret) , trim($amazonAid), $camp->camp_amazon_region );
				
				try {
					
					//additional params
					$additionalParm=array();
					
					//node param
					if (in_array ( 'OPT_AMAZON_NODE', $camp_opt ) & trim ( $camp_general ['cg_am_node'] ) != '') {
						  echo '<br>Specific node : ' . $camp_general ['cg_am_node'];
						$additionalParm['BrowseNode'] = $camp_general ['cg_am_node'];
					} 
					
		
					//min and max param
					$max = '';
					$min = '';
					
					if (in_array ( 'OPT_AM_PRICE', $camp_opt )) {
						$min = $camp_general ['cg_am_min'];
						$max = $camp_general ['cg_am_max'];
						
						  echo '<br>Price range ' . $min . ' - ' . $max;
					}
					
					//search param
					if (in_array ( 'OPT_AMAZON_PARAM', $camp_opt )) {
						$additionalParm[$camp_general['cg_am_param_type']]=$camp_general['cg_am_param'];
					}
					
					//order param
					if (in_array ( 'OPT_AM_ORDER', $camp_opt )) {
						$additionalParm['Sort']=$camp_general['cg_am_order'];
					}
					
					//amazon merchant
					if (in_array ( 'OPT_AMAZON_MERCHANT', $camp_opt )) {
						$additionalParm['MerchantId']='Amazon';
					}
					
					if(stristr($clickkey, 'B0')){
						$result = $obj->getItemByAsin($clickkey);
					}else{
						$result = $obj->getItemByKeyword ( "$clickkey", $start, $camp->camp_amazon_cat, $additionalParm , $min, $max );
					}
				} catch ( Exception $e ) {
					$this->log ( 'Amazon Error', $e->getMessage () );
					  echo '<br>' . $e->getMessage ();
					return false;
				}
				
				
				if ( isset($result->Items->Item) && count ( $result->Items->Item ) != 0) {
					 
					$pagesNum = $result->Items->TotalPages;
					
					  echo '<br>Available Pages:' . $pagesNum;
					
					$camp_cb_category = $camp->camp_cb_category;
				
					if(isset($result->Items->MoreSearchResultsUrl)){
						$moreUrl = $result->Items->MoreSearchResultsUrl;
						$moreUrl.= '';

						if(stristr($moreUrl, 'location')){
							$locParts = explode('location=', $moreUrl);
							$locParts2 = explode('&', $locParts[1]);
							$finalMore = $locParts2[0];
							
							if(trim($finalMore) != '') $moreUrl = urldecode( $finalMore );
						}
						
						  echo '<br>More items url:'.$moreUrl;
						update_post_meta( $camp->camp_id, $md5.'_more' , $moreUrl );
					}
				 
					  echo '<ol>';
					foreach ( $result->Items->Item as $Item ) {
						
						echo '<pre>';
						//print_r($Item);
			 			
				 		  echo '<li>';
						
						//   echo "Sales Rank : {$Item->SalesRank}<br>";
						  echo "ASIN : {$Item->ASIN} ";
						  echo " Link : <a href=\"{$Item->DetailPageURL}\">{$Item->ItemAttributes->Title}</a> <br>";
		
						$desc = '';
						@$desc = $Item->EditorialReviews->EditorialReview->Content;
						
						//Features existence 
						if(isset($Item->ItemAttributes->Feature)){
							  echo '-- Features found appending to the description';
							$desc .= implode( '<br>', (array) $Item->ItemAttributes->Feature );
						}
						
						$desc = addslashes ( $desc );
						$title = addslashes ( $Item->ItemAttributes->Title );
						
						// Author if exists, inject it to title
						if(isset($Item->ItemAttributes->Author)){
							$title .= '**' . $Item->ItemAttributes->Author ;
						}else{
							$title .= '** ' ;
						}
						
						// Brand if exists
						if(isset($Item->ItemAttributes->Brand)){
							$title .= '**' . $Item->ItemAttributes->Brand;
						}else{
							$title .= '** ' ;
						}
 
 						$linkUrl = (string)$Item->DetailPageURL;
						 		
							if( $this->is_execluded($camp->camp_id,  $linkUrl) ){
								  echo '<-- Execluded';
								continue;
							}
								
							if (  ! $this->is_duplicate($linkUrl) ) {
								
									$price= '';
									@$price = $Item->OfferSummary->LowestNewPrice->FormattedPrice;
								
								if(trim($price) == ''){
									@$price=$Item->ItemAttributes->ListPrice->FormattedPrice;
								}
								
								if(trim($price) == ''){
									@$price=$Item->Offers->Offer->OfferListing->Price->FormattedPrice;
								}
								
								if(trim($price) == ''){
									@$price = $Item->OfferSummary->LowestCollectiblePrice->FormattedPrice;
								}
								
								if(trim($price) == ''){
									@$price = $Item->OfferSummary->LowestUsedPrice->FormattedPrice;
								}
								
								if(trim($price) == ''){
									@$price = $Item->VariationSummary->LowestPrice->FormattedPrice;
									
								}
								
								//list price
								$ListPrice= '';
								$ListPrice=@$Item->ItemAttributes->ListPrice->FormattedPrice;
								
								if(trim($ListPrice) == ''){
									$ListPrice = $price;
								}
								
								//final saved price price,listprice
								$price=$price.'-'.$ListPrice;
								
								$imgurl = '';
								$imgurl=$Item->LargeImage->URL;
								
								if(trim($imgurl) == ''){
									//get it from the sets
									@$imgurl=$Item->ImageSets->ImageSet[0]->LargeImage->URL;
									
								}
								
								if(trim($imgurl) == ''){
									//get it from the sets
									@$imgurl=$Item->Variations->Item[0]->LargeImage->URL;
								}
								
								
								//Checking for an image set
								if(trim($imgurl) != ''){
									$imgSets = array();
									$img2url = '';
									$imgs = array();
									$img2url = '';
									if(isset($Item->ImageSets->ImageSet[1]->LargeImage->URL)) $img2url = $Item->ImageSets->ImageSet[1]->LargeImage->URL;
									
									if(trim($img2url) != ''){
										// found an image set
										$imgSets = $Item->ImageSets->ImageSet;
										foreach($imgSets as $imgSet){
											$imgs[] = $imgSet->LargeImage->URL;
										}
										
										if(count($imgs) > 0){
											$imgs = implode(',', $imgs);
											$imgurl=$imgs;
										}
										
									}
									
								}
									
								
								
								//review url 
								$review = $Item->CustomerReviews->IFrameURL;
								 
								$query = "INSERT INTO {$this->wp_prefix}automatic_amazon_links ( link_url , link_title , link_keyword  , link_status ,link_desc,link_price,link_img,link_review)VALUES ( '$linkUrl', '$title', '{$camp->camp_id}_$keyword', '0','$desc','{$price}','{$imgurl}','{$review}')";
								$this->db->query ( $query );
							} else {
								  echo ' <- duplicated <a href="'.get_edit_post_link($this->duplicate_id).'">#'.$this->duplicate_id.'</a>';
							}
							
							  echo '</li>';
						 
					}
					
					  echo '</ol>';
					
		 		} // if count
				
				if ( isset($result->Items->Item )  && count ( $result->Items->Item ) > 0) {
					
					// if ASIN
					if(count($result->Items->Item) == 1 && stristr($keyword, 'B0') ){
						  echo '<br>Keyword is an ASIN ... ';
						$this->deactivate_key($camp->camp_id, $keyword, 0 );
						
						$newstart = '-1';
						$query = "update {$this->wp_prefix}automatic_keywords set amazon_start  = '$newstart' where keyword_name='$keyword'  and keyword_camp = {$camp->camp_id} ";
						$this->db->query ( $query );
						
						
						return true;
					}
					
					// increment the start with 1
					$newstart = $start + 1;
					$query = "update {$this->wp_prefix}automatic_keywords set  amazon_start  = '$newstart' where keyword_name='$keyword'  and keyword_camp = {$camp->camp_id} ";
					$this->db->query ( $query );
					
					return true;
					
				} else {
					// there was no links lets deactivate
					$newstart = '-1';
					$query = "update {$this->wp_prefix}automatic_keywords set amazon_start  = '$newstart' where keyword_name='$keyword'  and keyword_camp = {$camp->camp_id} ";
					$this->db->query ( $query );
					
					//deactivate key
					
					if(! in_array('OPT_NO_DEACTIVATE', $camp_opt)){
	
						if(stristr($keyword, 'B0')){
							
							  echo '<br>Keyword is an ASIN ... ';
							$this->deactivate_key($camp->camp_id, $keyword, 0 );
							
						}else{
							$this->deactivate_key($camp->camp_id, $keyword);
						}
						
						
					}
					
					  echo '<br>No more items at amazon to get ';
					
					return false;
				}
			} // end func
			
}