/** * * @param string $user_id * @param PCModelWebsite $site * @return PCModelReview */ public static function lastReviewForSite($user_id, $site){ if($user_id == NULL) return NULL; $keys = array('user_identifier' => $user_id, 'site_identifier'=> $site->getIdentifier()); $reviews = PCModelManager::fetchModelObjectInstances(PCModelReview::getMapper(), $keys); if(count($reviews) <= 0){ return NULL; } return $reviews[0]; }
/** * @XXX remove direct database interaction * @param PCModelWebsite $site */ public static function recacheSiteReview($site) { //error_log('RECACHING SITE INFO: '.$site->getIdentifier()); $select = "SELECT avg(usability) as usability, avg(reliability) as reliability,"; $select .= " avg(contents) as contents, count(identifier) as count "; $mapper = PCModelReview::getMapper(); $select .= " FROM " . $mapper->getTableName() . " WHERE site_identifier = :id"; $pdo = PCDatabase::getSharedDatabaseConnection(); $prepared = $pdo->prepare($select); $result = $prepared->execute(array(":id" => $site->getIdentifier())); if ($result === FALSE) { return NULL; } $item = $prepared->fetch(PDO::FETCH_ASSOC); if (!isset($item)) { return NULL; } $usability = (double) $item['usability']; $reliability = (double) $item['reliability']; $contents = (double) $item['contents']; $count = (double) $item['count']; $cache_time = new DateTime('now', new DateTimeZone('UTC')); $keys = array('usability' => $usability, 'reliability' => $reliability, 'contents' => $contents, 'number_of_votes' => $count, 'cached' => $cache_time->format('Y-m-d H:i:s')); $condition = "identifier = :id"; $bindings = array(':id' => $site->getIdentifier()); $websiteMapper = PCModelWebsite::getMapper(); if (PCModelManager::updateObject($websiteMapper, $keys, $condition, $bindings)) { $site->cached_date = $cache_time; $site->contents = $contents; $site->number_of_votes = $count; $site->reliability = $reliability; $site->usability = $usability; PCCache::cacheProvider()->setItem($site, $websiteMapper->getTableName() . $site->getIdentifier()); return $site; } return NULL; }
/** * * Posta sulla timeline di Facebook (se possibile) * @param array $reviewDescription * @param PCModelWebsite $onSite * @param PCModelUserOauth $user * @return boolean */ public static function postReviewToFacebook($reviewDescription, $onSite, $user){ PCAutoloader::importLibrary('facebook'); $oauth = $user->getOauthStore(); if($oauth == null){ return FALSE; } $domain = $onSite->getDomain(); $usa = $reviewDescription['usability']; $rel = $reviewDescription['reliability']; $cont = $reviewDescription['contents']; $vote = sprintf("%.1f",(($usa+$rel+$cont)/3.0)); $text = "I've just reviewed $domain (Vote: $vote) using http://websherpa.me : ".$reviewDescription['comment']; $facebook = new Facebook(array( "appId" => FB_APP_ID, "secret" => FB_APP_SECRET, "cookie" => true )); $facebook->setAccessToken($oauth['oauth_token']); try { $result = $facebook->api("/me/feed", 'post', array( 'message' => $text, 'name' => 'WebSherpa', 'link' => "http://websherpa.me/sites/site?id=".$onSite->getIdentifier(), 'picture' => 'http://websherpa.me/public/fresh/img/logo_footer.png', )); return isset($result['id']); } catch (FacebookApiException $exc) { c_dump($exc); return FALSE; } return FALSE; }
/** * Posta sulla timeline di twitter * @param array $reviewDescription * @param PCModelWebsite $onSite * @param PCModelUserOauth $user * @return boolean */ public static function postReviewToTwitter($reviewDescription, $onSite ,$user){ PCAutoloader::importLibrary('twitter'); $oauth = $user->getOauthStore(); if($oauth == null) return FALSE; $connection = new TwitterOAuth(TW_CONSUMER_KEY, TW_CONSUMER_SECRET, $oauth['oauth_token'], $oauth['oauth_secret']); $domain = $onSite->getDomain(); $usa = $reviewDescription['usability']; $rel = $reviewDescription['reliability']; $cont = $reviewDescription['contents']; $vote = sprintf("$.1f",(($usa+$rel+$cont)/3.0));; $text = "I've just reviewed http://$domain (Vote: $vote) using @WebSherpa_me http://websherpa.me/sites/site?id=".$onSite->getIdentifier(); $status = $connection->post('statuses/update', array('status' => $text)); if(isset($status->errors)) return FALSE; return TRUE; }