Fix GoogleSearchBridge
find div instead li
This commit is contained in:
parent
3f503c4356
commit
35415004b9
1 changed files with 37 additions and 31 deletions
|
@ -7,7 +7,7 @@
|
||||||
* qdr:y : in past year
|
* qdr:y : in past year
|
||||||
* sbd:1 : sort by date (will only work if qdr: is specified)
|
* sbd:1 : sort by date (will only work if qdr: is specified)
|
||||||
*/
|
*/
|
||||||
class GoogleSearchBridge extends BridgeAbstract{
|
class GoogleSearchBridge extends BridgeAbstract {
|
||||||
|
|
||||||
const MAINTAINER = "sebsauvage";
|
const MAINTAINER = "sebsauvage";
|
||||||
const NAME = "Google search";
|
const NAME = "Google search";
|
||||||
|
@ -15,40 +15,46 @@ class GoogleSearchBridge extends BridgeAbstract{
|
||||||
const CACHE_TIMEOUT = 1800; // 30min
|
const CACHE_TIMEOUT = 1800; // 30min
|
||||||
const DESCRIPTION = "Returns most recent results from Google search.";
|
const DESCRIPTION = "Returns most recent results from Google search.";
|
||||||
|
|
||||||
const PARAMETERS = array( array(
|
const PARAMETERS = array(array(
|
||||||
'q'=>array(
|
'q' => array(
|
||||||
'name'=>"keyword",
|
'name' => "keyword",
|
||||||
'required'=>true
|
'required' => true
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
|
|
||||||
|
|
||||||
public function collectData(){
|
public function collectData() {
|
||||||
$html = '';
|
$html = '';
|
||||||
|
|
||||||
$html = getSimpleHTMLDOM(self::URI
|
$html = getSimpleHTMLDOM(self::URI.'search?q='.urlencode($this->getInput('q'))
|
||||||
.'search?q=' . urlencode($this->getInput('q'))
|
|
||||||
.'&num=100&complete=0&tbs=qdr:y,sbd:1')
|
.'&num=100&complete=0&tbs=qdr:y,sbd:1')
|
||||||
or returnServerError('No results for this query.');
|
or returnServerError('No results for this query.');
|
||||||
|
|
||||||
$emIsRes = $html->find('div[id=ires]',0);
|
$emIsRes = $html->find('div[id=ires]', 0);
|
||||||
if( !is_null($emIsRes) ){
|
|
||||||
foreach($emIsRes->find('li[class=g]') as $element) {
|
if( !is_null($emIsRes) ) {
|
||||||
|
|
||||||
|
foreach($emIsRes->find('div[class=g]') as $element) {
|
||||||
|
|
||||||
$item = array();
|
$item = array();
|
||||||
|
|
||||||
// Extract direct URL from google href (eg. /url?q=...)
|
// Extract direct URL from google href (eg. /url?q=...)
|
||||||
$t = $element->find('a[href]',0)->href;
|
$t = $element->find('a[href]', 0)->href;
|
||||||
$item['uri'] = ''.$t;
|
$item['uri'] = ''.$t;
|
||||||
parse_str(parse_url($t, PHP_URL_QUERY),$parameters);
|
parse_str(parse_url($t, PHP_URL_QUERY), $parameters);
|
||||||
if (isset($parameters['q'])) { $item['uri'] = $parameters['q']; }
|
if (isset($parameters['q'])) { $item['uri'] = $parameters['q']; }
|
||||||
$item['title'] = $element->find('h3',0)->plaintext;
|
|
||||||
$item['content'] = $element->find('span[class=st]',0)->plaintext;
|
$item['title'] = $element->find('h3', 0)->plaintext;
|
||||||
|
|
||||||
|
$item['content'] = $element->find('span[class=st]', 0)->plaintext;
|
||||||
|
|
||||||
$this->items[] = $item;
|
$this->items[] = $item;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getName(){
|
public function getName(){
|
||||||
|
|
||||||
return $this->getInput('q') .' - Google search';
|
return $this->getInput('q') .' - Google search';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue