Merge branch 'FixBridges' of https://github.com/logmanoriginal/rss-bridge
This commit is contained in:
commit
9405dc6c4b
5 changed files with 115 additions and 94 deletions
|
@ -108,12 +108,16 @@ class AnimeUltimeBridge extends BridgeAbstract {
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getName() {
|
public function getName() {
|
||||||
$typeFilter = array_search(
|
if(!is_null($this->getInput('type'))){
|
||||||
$this->getInput('type'),
|
$typeFilter = array_search(
|
||||||
self::PARAMETERS[$this->queriedContext]['type']['values']
|
$this->getInput('type'),
|
||||||
);
|
self::PARAMETERS[$this->queriedContext]['type']['values']
|
||||||
|
);
|
||||||
|
|
||||||
return 'Latest '.$typeFilter.' - Anime-Ultime Bridge';
|
return 'Latest '.$typeFilter.' - Anime-Ultime Bridge';
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -85,6 +85,7 @@ class DailymotionBridge extends BridgeAbstract{
|
||||||
case 'From search results':
|
case 'From search results':
|
||||||
$specific=$this->getInput('s');
|
$specific=$this->getInput('s');
|
||||||
break;
|
break;
|
||||||
|
default: return parent::getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
return $specific.' : Dailymotion Bridge';
|
return $specific.' : Dailymotion Bridge';
|
||||||
|
|
|
@ -115,10 +115,14 @@ class GBAtempBridge extends BridgeAbstract {
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getName() {
|
public function getName() {
|
||||||
$type=array_search(
|
if(!is_null($this->getInput('type'))){
|
||||||
$this->getInput('type'),
|
$type=array_search(
|
||||||
self::PARAMETERS[$this->queriedContext]['type']['values']
|
$this->getInput('type'),
|
||||||
);
|
self::PARAMETERS[$this->queriedContext]['type']['values']
|
||||||
return 'GBAtemp '.$type.' Bridge';
|
);
|
||||||
|
return 'GBAtemp '.$type.' Bridge';
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::getName();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,69 +6,79 @@ class KununuBridge extends BridgeAbstract {
|
||||||
const CACHE_TIMEOUT = 86400; // 24h
|
const CACHE_TIMEOUT = 86400; // 24h
|
||||||
const DESCRIPTION = "Returns the latest reviews for a company and site of your choice.";
|
const DESCRIPTION = "Returns the latest reviews for a company and site of your choice.";
|
||||||
|
|
||||||
const PARAMETERS = array(
|
const PARAMETERS = array(
|
||||||
'global' => array(
|
'global' => array(
|
||||||
'site'=>array(
|
'site'=>array(
|
||||||
'name'=>'Site',
|
'name'=>'Site',
|
||||||
'type'=>'list',
|
'type'=>'list',
|
||||||
'required'=>true,
|
'required'=>true,
|
||||||
'title'=>'Select your site',
|
'title'=>'Select your site',
|
||||||
'values'=>array(
|
'values'=>array(
|
||||||
'Austria'=>'at',
|
'Austria'=>'at',
|
||||||
'Germany'=>'de',
|
'Germany'=>'de',
|
||||||
'Switzerland'=>'ch',
|
'Switzerland'=>'ch',
|
||||||
'United States'=>'us'
|
'United States'=>'us'
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
'full'=>array(
|
'full'=>array(
|
||||||
'name'=>'Load full article',
|
'name'=>'Load full article',
|
||||||
'type'=>'checkbox',
|
'type'=>'checkbox',
|
||||||
'required'=>false,
|
'required'=>false,
|
||||||
'exampleValue'=>'checked',
|
'exampleValue'=>'checked',
|
||||||
'title'=>'Activate to load full article'
|
'title'=>'Activate to load full article'
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
|
||||||
array(
|
array(
|
||||||
'company'=>array(
|
'company'=>array(
|
||||||
'name'=>'Company',
|
'name'=>'Company',
|
||||||
'required'=>true,
|
'required'=>true,
|
||||||
'exampleValue'=>'kununu-us',
|
'exampleValue'=>'kununu-us',
|
||||||
'title'=>'Insert company name (i.e. Kununu US) or URI path (i.e. kununu-us)'
|
'title'=>'Insert company name (i.e. Kununu US) or URI path (i.e. kununu-us)'
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
private $companyName='';
|
private $companyName = '';
|
||||||
|
|
||||||
public function getURI(){
|
public function getURI(){
|
||||||
$company = $this->encode_umlauts(strtolower(str_replace(' ', '-', trim($this->getInput('company')))));
|
if(!is_null($this->getInput('company')) && !is_null($this->getInput('site'))){
|
||||||
$site=$this->getInput('site');
|
|
||||||
$section = '';
|
|
||||||
switch($site){
|
|
||||||
case 'at':
|
|
||||||
case 'de':
|
|
||||||
case 'ch':
|
|
||||||
$section = 'kommentare';
|
|
||||||
break;
|
|
||||||
case 'us':
|
|
||||||
$section = 'reviews';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return self::URI.$site.'/'.$company.'/'.$section;
|
$company = $this->fix_company_name($this->getInput('company'));
|
||||||
}
|
$site = $this->getInput('site');
|
||||||
|
$section = '';
|
||||||
|
|
||||||
function getName(){
|
switch($site){
|
||||||
$company = $this->encode_umlauts(strtolower(str_replace(' ', '-', trim($this->getInput('company')))));
|
case 'at':
|
||||||
return ($this->companyName?:$company).' - '.self::NAME;
|
case 'de':
|
||||||
}
|
case 'ch':
|
||||||
|
$section = 'kommentare';
|
||||||
|
break;
|
||||||
|
case 'us':
|
||||||
|
$section = 'reviews';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return self::URI . $site . '/' . $company . '/' . $section;
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::getURI();
|
||||||
|
}
|
||||||
|
|
||||||
|
function getName(){
|
||||||
|
if(!is_null($this->getInput('company'))){
|
||||||
|
$company = $this->fix_company_name($this->getInput('company'));
|
||||||
|
return ($this->companyName?:$company).' - '.self::NAME;
|
||||||
|
}
|
||||||
|
|
||||||
|
return paren::getName();
|
||||||
|
}
|
||||||
|
|
||||||
public function collectData(){
|
public function collectData(){
|
||||||
$full = $this->getInput('full');
|
$full = $this->getInput('full');
|
||||||
|
|
||||||
// Load page
|
// Load page
|
||||||
$html = getSimpleHTMLDOM($this->getURI());
|
$html = getSimpleHTMLDOMCached($this->getURI());
|
||||||
if(!$html)
|
if(!$html)
|
||||||
returnServerError('Unable to receive data from ' . $this->getURI() . '!');
|
returnServerError('Unable to receive data from ' . $this->getURI() . '!');
|
||||||
// Update name for this request
|
// Update name for this request
|
||||||
|
@ -109,6 +119,16 @@ class KununuBridge extends BridgeAbstract {
|
||||||
return preg_replace('/href=(\'|\")\//i', 'href="'.self::URI, $text);
|
return preg_replace('/href=(\'|\")\//i', 'href="'.self::URI, $text);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Returns a fixed version of the provided company name
|
||||||
|
*/
|
||||||
|
private function fix_company_name($company){
|
||||||
|
$company = trim($company);
|
||||||
|
$company = str_replace(' ', '-', $company);
|
||||||
|
$company = strtolower($company);
|
||||||
|
return $this->encode_umlauts($company);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Encodes unmlauts in the given text
|
* Encodes unmlauts in the given text
|
||||||
*/
|
*/
|
||||||
|
@ -123,12 +143,8 @@ class KununuBridge extends BridgeAbstract {
|
||||||
* Returns the company name from the review html
|
* Returns the company name from the review html
|
||||||
*/
|
*/
|
||||||
private function extract_company_name($html){
|
private function extract_company_name($html){
|
||||||
$panel = $html->find('div.panel', 0);
|
$company_name = $html->find('h1[itemprop=name]', 0);
|
||||||
if($panel === false)
|
if(is_null($company_name))
|
||||||
returnServerError('Cannot find panel for company name!');
|
|
||||||
|
|
||||||
$company_name = $panel->find('h1', 0);
|
|
||||||
if($company_name === false)
|
|
||||||
returnServerError('Cannot find company name!');
|
returnServerError('Cannot find company name!');
|
||||||
|
|
||||||
return $company_name->plaintext;
|
return $company_name->plaintext;
|
||||||
|
@ -139,11 +155,11 @@ class KununuBridge extends BridgeAbstract {
|
||||||
*/
|
*/
|
||||||
private function extract_article_date($article){
|
private function extract_article_date($article){
|
||||||
// They conviniently provide a time attribute for us :)
|
// They conviniently provide a time attribute for us :)
|
||||||
$date = $article->find('time[itemprop=dtreviewed]', 0);
|
$date = $article->find('meta[itemprop=dateCreated]', 0);
|
||||||
if($date === false)
|
if(is_null($date))
|
||||||
returnServerError('Cannot find article date!');
|
returnServerError('Cannot find article date!');
|
||||||
|
|
||||||
return strtotime($date->datetime);
|
return strtotime($date->content);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -151,7 +167,7 @@ class KununuBridge extends BridgeAbstract {
|
||||||
*/
|
*/
|
||||||
private function extract_article_rating($article){
|
private function extract_article_rating($article){
|
||||||
$rating = $article->find('span.rating', 0);
|
$rating = $article->find('span.rating', 0);
|
||||||
if($rating === false)
|
if(is_null($rating))
|
||||||
returnServerError('Cannot find article rating!');
|
returnServerError('Cannot find article rating!');
|
||||||
|
|
||||||
return $rating->getAttribute('aria-label');
|
return $rating->getAttribute('aria-label');
|
||||||
|
@ -161,8 +177,8 @@ class KununuBridge extends BridgeAbstract {
|
||||||
* Returns the summary from a given article
|
* Returns the summary from a given article
|
||||||
*/
|
*/
|
||||||
private function extract_article_summary($article){
|
private function extract_article_summary($article){
|
||||||
$summary = $article->find('[itemprop=summary]', 0);
|
$summary = $article->find('[itemprop=name]', 0);
|
||||||
if($summary === false)
|
if(is_null($summary))
|
||||||
returnServerError('Cannot find article summary!');
|
returnServerError('Cannot find article summary!');
|
||||||
|
|
||||||
return strip_tags($summary->innertext);
|
return strip_tags($summary->innertext);
|
||||||
|
@ -172,32 +188,27 @@ class KununuBridge extends BridgeAbstract {
|
||||||
* Returns the URI from a given article
|
* Returns the URI from a given article
|
||||||
*/
|
*/
|
||||||
private function extract_article_uri($article){
|
private function extract_article_uri($article){
|
||||||
// Notice: This first part is the same as in extract_article_summary!
|
$anchor = $article->find('ku-company-review-more', 0);
|
||||||
$summary = $article->find('[itemprop=summary]', 0);
|
if(is_null($anchor))
|
||||||
if($summary === false)
|
|
||||||
returnServerError('Cannot find article summary!');
|
|
||||||
|
|
||||||
$anchor = $summary->find('a', 0);
|
|
||||||
if($anchor === false)
|
|
||||||
returnServerError('Cannot find article URI!');
|
returnServerError('Cannot find article URI!');
|
||||||
|
|
||||||
return self::URI . $anchor->href;
|
return self::URI . $anchor->{'review-url'};
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the position of the author from a given article
|
* Returns the position of the author from a given article
|
||||||
*/
|
*/
|
||||||
private function extract_article_author_position($article){
|
private function extract_article_author_position($article){
|
||||||
// We need to parse the aside manually
|
// We need to parse the user-content manually
|
||||||
$aside = $article->find('aside', 0);
|
$user_content = $article->find('div.user-content', 0);
|
||||||
if($aside === false)
|
if(is_null($user_content))
|
||||||
returnServerError('Cannot find article author information!');
|
returnServerError('Cannot find user content!');
|
||||||
|
|
||||||
// Go through all h2 elements to find index of required span (I know... it's stupid)
|
// Go through all h2 elements to find index of required span (I know... it's stupid)
|
||||||
$author_position = 'Unknown';
|
$author_position = 'Unknown';
|
||||||
foreach($aside->find('h2') as $subject){
|
foreach($user_content->find('div') as $content){
|
||||||
if(stristr(strtolower($subject->plaintext), 'position')){ /* This works for at, ch, de, us */
|
if(stristr(strtolower($content->plaintext), 'position')){ /* This works for at, ch, de, us */
|
||||||
$author_position = $subject->next_sibling()->plaintext;
|
$author_position = $content->next_sibling()->plaintext;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -209,8 +220,8 @@ class KununuBridge extends BridgeAbstract {
|
||||||
* Returns the description from a given article
|
* Returns the description from a given article
|
||||||
*/
|
*/
|
||||||
private function extract_article_description($article){
|
private function extract_article_description($article){
|
||||||
$description = $article->find('div[itemprop=description]', 0);
|
$description = $article->find('[itemprop=reviewBody]', 0);
|
||||||
if($description === false)
|
if(is_null($description))
|
||||||
returnServerError('Cannot find article description!');
|
returnServerError('Cannot find article description!');
|
||||||
|
|
||||||
return $this->fix_url($description->innertext);
|
return $this->fix_url($description->innertext);
|
||||||
|
@ -227,7 +238,7 @@ class KununuBridge extends BridgeAbstract {
|
||||||
|
|
||||||
// Find the article
|
// Find the article
|
||||||
$article = $html->find('article', 0);
|
$article = $html->find('article', 0);
|
||||||
if($article === false)
|
if(is_null($article))
|
||||||
returnServerError('Cannot find article!');
|
returnServerError('Cannot find article!');
|
||||||
|
|
||||||
// Luckily they use the same layout for the review overview and full article pages :)
|
// Luckily they use the same layout for the review overview and full article pages :)
|
||||||
|
|
|
@ -239,6 +239,7 @@ EOD;
|
||||||
case 'Get manga updates':
|
case 'Get manga updates':
|
||||||
$path = $this->getInput('path');
|
$path = $this->getInput('path');
|
||||||
break;
|
break;
|
||||||
|
default: return parent::getURI();
|
||||||
}
|
}
|
||||||
return self::URI . $path;
|
return self::URI . $path;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue