mirror of
https://github.com/RSS-Bridge/rss-bridge.git
synced 2024-11-30 08:40:24 +03:00
a4b9611e66
- Do not add spaces after opening or before closing parenthesis // Wrong if( !is_null($var) ) { ... } // Right if(!is_null($var)) { ... } - Add space after closing parenthesis // Wrong if(true){ ... } // Right if(true) { ... } - Add body into new line - Close body in new line // Wrong if(true) { ... } // Right if(true) { ... } Notice: Spaces after keywords are not detected: // Wrong (not detected) // -> space after 'if' and missing space after 'else' if (true) { ... } else{ ... } // Right if(true) { ... } else { ... }
74 lines
2.2 KiB
PHP
74 lines
2.2 KiB
PHP
<?php
|
|
class AskfmBridge extends BridgeAbstract {
|
|
|
|
const MAINTAINER = 'az5he6ch';
|
|
const NAME = 'Ask.fm Answers';
|
|
const URI = 'https://ask.fm/';
|
|
const CACHE_TIMEOUT = 300; //5 min
|
|
const DESCRIPTION = 'Returns answers from an Ask.fm user';
|
|
const PARAMETERS = array(
|
|
'Ask.fm username' => array(
|
|
'u' => array(
|
|
'name' => 'Username',
|
|
'required' => true
|
|
)
|
|
)
|
|
);
|
|
|
|
public function collectData(){
|
|
$html = getSimpleHTMLDOM($this->getURI())
|
|
or returnServerError('Requested username can\'t be found.');
|
|
|
|
foreach($html->find('div.streamItem-answer') as $element) {
|
|
$item = array();
|
|
$item['uri'] = self::URI . $element->find('a.streamItemsAge', 0)->href;
|
|
$question = trim($element->find('h1.streamItemContent-question', 0)->innertext);
|
|
|
|
$item['title'] = trim(
|
|
htmlspecialchars_decode($element->find('h1.streamItemContent-question', 0)->plaintext,
|
|
ENT_QUOTES
|
|
)
|
|
);
|
|
|
|
$answer = trim($element->find('p.streamItemContent-answer', 0)->innertext);
|
|
|
|
// Doesn't work, DOM parser doesn't seem to like data-hint, dunno why
|
|
#$item['update'] = $element->find('a.streamitemsage',0)->data-hint;
|
|
|
|
// This probably should be cleaned up, especially for YouTube embeds
|
|
$visual = $element->find('div.streamItemContent-visual', 0)->innertext;
|
|
//Fix tracking links, also doesn't work
|
|
foreach($element->find('a') as $link) {
|
|
if(strpos($link->href, 'l.ask.fm') !== false) {
|
|
|
|
// Too slow
|
|
#$link->href = str_replace('#_=_', '', get_headers($link->href, 1)['Location']);
|
|
|
|
$link->href = $link->plaintext;
|
|
}
|
|
}
|
|
|
|
$content = '<p>' . $question . '</p><p>' . $answer . '</p><p>' . $visual . '</p>';
|
|
// Fix relative links without breaking // scheme used by YouTube stuff
|
|
$content = preg_replace('#href="\/(?!\/)#', 'href="' . self::URI, $content);
|
|
$item['content'] = $content;
|
|
$this->items[] = $item;
|
|
}
|
|
}
|
|
|
|
public function getName(){
|
|
if(!is_null($this->getInput('u'))) {
|
|
return self::NAME . ' : ' . $this->getInput('u');
|
|
}
|
|
|
|
return parent::getName();
|
|
}
|
|
|
|
public function getURI(){
|
|
if(!is_null($this->getInput('u'))) {
|
|
return self::URI . urlencode($this->getInput('u')) . '/answers/more?page=0';
|
|
}
|
|
|
|
return parent::getURI();
|
|
}
|
|
}
|