2014-07-20 12:40:00 +04:00
|
|
|
<?php
|
|
|
|
class GooglePlusPostBridge extends BridgeAbstract
|
|
|
|
{
|
2014-07-20 18:28:51 +04:00
|
|
|
protected $_title;
|
|
|
|
protected $_url;
|
|
|
|
|
2016-08-30 12:23:55 +03:00
|
|
|
const MAINTAINER = "Grummfy";
|
|
|
|
const NAME = "Google Plus Post Bridge";
|
|
|
|
const URI = "https://plus.google.com/";
|
|
|
|
const DESCRIPTION = "Returns user public post (without API).";
|
2016-08-27 22:03:26 +03:00
|
|
|
|
2016-08-30 12:23:55 +03:00
|
|
|
const PARAMETERS = array( array(
|
2016-08-27 22:03:26 +03:00
|
|
|
'username'=>array(
|
|
|
|
'name'=>'username or Id',
|
|
|
|
'required'=>true
|
|
|
|
)
|
|
|
|
));
|
2015-11-05 18:50:18 +03:00
|
|
|
|
2016-08-25 02:24:53 +03:00
|
|
|
public function collectData()
|
2014-07-20 12:40:00 +04:00
|
|
|
{
|
2014-07-20 18:28:51 +04:00
|
|
|
// get content parsed
|
2016-07-08 20:06:35 +03:00
|
|
|
// $html = $this->getSimpleHTMLDOM(__DIR__ . '/../posts2.html'
|
2016-08-30 12:23:55 +03:00
|
|
|
$html = $this->getSimpleHTMLDOM(self::URI . urlencode($this->getInput('username')) . '/posts'
|
2014-07-20 18:28:51 +04:00
|
|
|
// force language
|
|
|
|
, false, stream_context_create(array('http'=> array(
|
|
|
|
'header' => 'Accept-Language: fr,fr-be,fr-fr;q=0.8,en;q=0.4,en-us;q=0.2;*' . "\r\n"
|
|
|
|
)))
|
2016-08-17 15:45:08 +03:00
|
|
|
) OR $this->returnServerError('No results for this query.');
|
2014-07-20 12:40:00 +04:00
|
|
|
|
2014-07-20 18:28:51 +04:00
|
|
|
// get title, url, ... there is a lot of intresting stuff in meta
|
|
|
|
$this->_title = $html->find('meta[property]', 0)->getAttribute('content');
|
|
|
|
$this->_url = $html->find('meta[itemprop=url]', 0)->getAttribute('content');
|
|
|
|
|
|
|
|
// foreach ($html->find('meta') as $e)
|
|
|
|
// {
|
2016-08-22 19:55:59 +03:00
|
|
|
// $item = array();
|
|
|
|
// $item['content'] = var_export($e->attr, true);
|
2014-07-20 18:28:51 +04:00
|
|
|
// $this->items[] = $item;
|
|
|
|
// }
|
|
|
|
|
|
|
|
// div[jsmodel=XNmfOc]
|
|
|
|
foreach($html->find('div.yt') as $post)
|
2014-07-20 12:40:00 +04:00
|
|
|
{
|
2016-08-22 19:55:59 +03:00
|
|
|
$item = array();
|
|
|
|
// $item['content'] = $post->find('div.Al', 0)->innertext;
|
|
|
|
$item['username'] = $item['fullname'] = $post->find('header.lea h3 a', 0)->innertext;
|
|
|
|
$item['id'] = $post->getAttribute('id');
|
|
|
|
// $item['title'] = $item['fullname'] = $post->find('header.lea', 0)->plaintext;
|
|
|
|
$item['avatar'] = $post->find('div.ys img', 0)->src;
|
2014-07-20 18:28:51 +04:00
|
|
|
// var_dump((($post->find('a.o-U-s', 0)->getAllAttributes())));
|
2016-08-30 12:23:55 +03:00
|
|
|
$item['uri'] = self::URI . $post->find('a.o-U-s', 0)->href;
|
2016-08-22 19:55:59 +03:00
|
|
|
$item['timestamp'] = strtotime($post->find('a.o-U-s', 0)->plaintext);
|
2014-07-20 12:40:00 +04:00
|
|
|
$this->items[] = $item;
|
2014-07-20 18:28:51 +04:00
|
|
|
|
|
|
|
// hashtag to treat : https://plus.google.com/explore/tag
|
|
|
|
$hashtags = array();
|
|
|
|
foreach($post->find('a.d-s') as $hashtag)
|
|
|
|
{
|
2016-08-30 12:23:55 +03:00
|
|
|
$hashtags[ trim($hashtag->plaintext) ] = self::URI . $hashtag->href;
|
2014-07-20 18:28:51 +04:00
|
|
|
}
|
|
|
|
|
2016-08-22 19:55:59 +03:00
|
|
|
$item['content'] = '';
|
2014-07-20 18:28:51 +04:00
|
|
|
|
|
|
|
// avatar display
|
2016-08-30 12:23:55 +03:00
|
|
|
$item['content'] .= '<div style="float:left; margin: 0 0.5em 0.5em 0;"><a href="' . self::URI . urlencode($this->getInput('username'));
|
2016-08-22 19:55:59 +03:00
|
|
|
$item['content'] .= '"><img align="top" alt="avatar" src="' . $item['avatar'].'" />' . $item['username'] . '</a></div>';
|
2014-07-20 18:28:51 +04:00
|
|
|
|
|
|
|
$content = $post->find('div.Al', 0);
|
|
|
|
|
|
|
|
// alter link
|
|
|
|
// $content = $content->innertext;
|
2016-08-30 12:23:55 +03:00
|
|
|
// $content = str_replace('href="./', 'href="' . self::URI, $content);
|
|
|
|
// $content = str_replace('href="photos', 'href="' . self::URI . 'photos', $content);
|
2014-07-20 18:28:51 +04:00
|
|
|
// XXX ugly but I don't have any idea how to do a better stuff, str_replace on link doesn't work as expected and ask too many checks
|
|
|
|
foreach($content->find('a') as $link)
|
|
|
|
{
|
|
|
|
$hasHttp = strpos($link->href, 'http');
|
|
|
|
$hasDoubleSlash = strpos($link->href, '//');
|
|
|
|
|
|
|
|
if ((!$hasHttp && !$hasDoubleSlash)
|
|
|
|
|| (false !== $hasHttp && strpos($link->href, 'http') != 0)
|
|
|
|
|| (false === $hasHttp && false !== $hasDoubleSlash && $hasDoubleSlash != 0))
|
|
|
|
{
|
|
|
|
// skipp bad link, for some hashtag or other stuff
|
|
|
|
if (strpos($link->href, '/') == 0)
|
|
|
|
{
|
|
|
|
$link->href = substr($link->href, 1);
|
|
|
|
}
|
2016-08-30 12:23:55 +03:00
|
|
|
$link->href = self::URI . $link->href;
|
2014-07-20 18:28:51 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
$content = $content->innertext;
|
|
|
|
|
2016-08-22 19:55:59 +03:00
|
|
|
$item['content'] .= '<div style="margin-top: -1.5em">' . $content . '</div>';
|
2014-07-20 18:28:51 +04:00
|
|
|
|
|
|
|
// extract plaintext
|
2016-08-22 19:55:59 +03:00
|
|
|
$item['content_simple'] = $post->find('div.Al', 0)->plaintext;
|
2014-07-20 12:40:00 +04:00
|
|
|
}
|
|
|
|
|
2014-07-20 18:28:51 +04:00
|
|
|
// $html->save(__DIR__ . '/../posts2.html');
|
2014-07-20 12:40:00 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getName()
|
|
|
|
{
|
2014-07-20 18:28:51 +04:00
|
|
|
return $this->_title ?: 'Google Plus Post Bridge';
|
2014-07-20 12:40:00 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getURI()
|
|
|
|
{
|
2016-08-30 12:23:55 +03:00
|
|
|
return $this->_url ?: self::URI;
|
2014-07-20 12:40:00 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getCacheDuration()
|
|
|
|
{
|
2014-07-20 14:38:45 +04:00
|
|
|
return 1; // 600; // 10 minutes
|
2014-07-20 12:40:00 +04:00
|
|
|
}
|
|
|
|
}
|