2022-05-20 17:55:33 +00:00
|
|
|
<?php
|
|
|
|
|
2022-05-20 18:07:42 +00:00
|
|
|
class ReadabilityExtension extends Minz_Extension {
|
2022-05-29 23:57:54 +00:00
|
|
|
|
|
|
|
private $readHost;
|
|
|
|
private $mercHost;
|
|
|
|
private $feeds;
|
|
|
|
private $mStore;
|
|
|
|
private $rStore;
|
2022-05-20 17:55:33 +00:00
|
|
|
|
|
|
|
public function init() {
|
|
|
|
|
|
|
|
$this->registerHook('entry_before_insert', array($this, 'fetchStuff'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function fetchStuff($entry) {
|
2022-05-20 18:07:42 +00:00
|
|
|
|
2022-05-29 23:57:54 +00:00
|
|
|
$this->loadConfigValues();
|
|
|
|
$host = '';
|
|
|
|
|
2022-05-30 00:40:01 +00:00
|
|
|
/*
|
|
|
|
Both APIs are basically the same, so the host for request parsing is exchangeable
|
|
|
|
*/
|
|
|
|
|
2022-05-29 23:57:54 +00:00
|
|
|
if ( array_key_exists($entry->feed(false), $this->mStore) )
|
|
|
|
$host = $this->mercHost;
|
2022-05-21 14:23:44 +00:00
|
|
|
|
2022-05-29 23:57:54 +00:00
|
|
|
if ( array_key_exists($entry->feed(false), $this->rStore) )
|
|
|
|
$host = $this->readHost;
|
|
|
|
|
|
|
|
if ($host === '')
|
2022-05-20 20:10:13 +00:00
|
|
|
return $entry;
|
2022-05-21 14:23:44 +00:00
|
|
|
|
2022-05-20 17:55:33 +00:00
|
|
|
$data = "{\"url\": \"" . $entry->link() ."\"}";
|
|
|
|
$headers[] = 'Content-Type: application/json';
|
2022-05-30 00:40:01 +00:00
|
|
|
|
2022-05-20 17:55:33 +00:00
|
|
|
|
2022-05-29 23:57:54 +00:00
|
|
|
$c = curl_init($host);
|
2022-05-20 17:55:33 +00:00
|
|
|
curl_setopt($c, CURLOPT_POSTFIELDS, $data);
|
|
|
|
curl_setopt($c, CURLOPT_HTTPHEADER, $headers);
|
|
|
|
curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
|
|
|
|
$result = curl_exec($c);
|
|
|
|
$c_status = curl_getinfo($c, CURLINFO_HTTP_CODE);
|
2022-05-29 23:57:54 +00:00
|
|
|
//$c_error = curl_error($c);
|
2022-05-20 17:55:33 +00:00
|
|
|
curl_close($c);
|
|
|
|
|
|
|
|
if ($c_status !== 200) {
|
2022-05-29 23:57:54 +00:00
|
|
|
return $entry;
|
2022-05-20 17:55:33 +00:00
|
|
|
}
|
|
|
|
$val = json_decode($result, true);
|
|
|
|
$entry->_content($val["content"]);
|
|
|
|
return $entry;
|
|
|
|
}
|
|
|
|
|
2022-05-30 00:40:01 +00:00
|
|
|
/*
|
|
|
|
* These are called from configure.phtml, which is controlled by handleConfigureAction(),
|
|
|
|
* thus values are already fetched from userconfig and FeedDAO.
|
|
|
|
*/
|
|
|
|
|
2022-05-29 23:57:54 +00:00
|
|
|
public function getReadHost() {
|
|
|
|
return $this->readHost;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getMercHost() {
|
|
|
|
return $this->mercHost;
|
|
|
|
}
|
2022-05-30 00:40:01 +00:00
|
|
|
|
2022-05-29 23:57:54 +00:00
|
|
|
public function getFeeds() {
|
|
|
|
return $this->feeds;
|
|
|
|
}
|
|
|
|
|
2022-05-30 00:40:01 +00:00
|
|
|
/*
|
|
|
|
Loading basic variables from user storage
|
|
|
|
*/
|
2022-05-29 23:57:54 +00:00
|
|
|
public function loadConfigValues()
|
|
|
|
{
|
|
|
|
if (!class_exists('FreshRSS_Context', false) || null === FreshRSS_Context::$user_conf) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (FreshRSS_Context::$user_conf->read_ext_read_host != '') {
|
|
|
|
$this->readHost = FreshRSS_Context::$user_conf->read_ext_read_host;
|
|
|
|
}
|
|
|
|
if (FreshRSS_Context::$user_conf->read_ext_merc_host != '') {
|
|
|
|
$this->mercHost = FreshRSS_Context::$user_conf->read_ext_merc_host;
|
|
|
|
}
|
|
|
|
if (FreshRSS_Context::$user_conf->read_ext_mercury != '') {
|
|
|
|
$this->mStore = json_decode(FreshRSS_Context::$user_conf->read_ext_mercury, true);
|
|
|
|
} else {
|
|
|
|
$this->mStore = [];
|
|
|
|
}
|
|
|
|
if (FreshRSS_Context::$user_conf->read_ext_readability != '') {
|
|
|
|
$this->rStore = json_decode(FreshRSS_Context::$user_conf->read_ext_readability, true);
|
|
|
|
} else {
|
|
|
|
$this->rStore = [];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-30 00:40:01 +00:00
|
|
|
public function getConfStoreR( $list, $id ) {
|
2022-05-29 23:57:54 +00:00
|
|
|
return array_key_exists($id, $this->rStore);
|
|
|
|
}
|
2022-05-30 00:40:01 +00:00
|
|
|
public function getConfStoreM( $list, $id ) {
|
|
|
|
return array_key_exists($id, $this->mStore);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* handleConfigureAction() is only executed on loading and saving the extenstion's configuration page.
|
|
|
|
* If the Request type is POST, values are being saved. It looks weird, but I copied it from another example and it works flawlessly.
|
|
|
|
*/
|
2022-05-29 23:57:54 +00:00
|
|
|
public function handleConfigureAction()
|
|
|
|
{
|
|
|
|
$feedDAO = FreshRSS_Factory::createFeedDao();
|
|
|
|
$this->feeds = $feedDAO->listFeeds();
|
|
|
|
|
|
|
|
if (Minz_Request::isPost()) {
|
|
|
|
$mstore = [];
|
|
|
|
$rstore = [];
|
2022-05-30 00:40:01 +00:00
|
|
|
foreach ( $this->feeds as $f ) {
|
|
|
|
//I rather encode only a few 'true' entries, than 400+ false entries + the few 'true' entries
|
2022-05-29 23:57:54 +00:00
|
|
|
if ((bool)Minz_Request::param("read_".$f->id(), 0)){
|
|
|
|
$rstore[$f->id()] = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( (bool)Minz_Request::param("merc_".$f->id(), 0) ) {
|
|
|
|
$mstore[$f->id()] = true;
|
|
|
|
}
|
|
|
|
}
|
2022-05-30 00:40:01 +00:00
|
|
|
// I don't know if it's possible to save arrays, so it's encoded with json
|
2022-05-29 23:57:54 +00:00
|
|
|
FreshRSS_Context::$user_conf->read_ext_mercury = (string)json_encode($mstore);
|
|
|
|
FreshRSS_Context::$user_conf->read_ext_readability = (string)json_encode($rstore);
|
|
|
|
|
|
|
|
|
|
|
|
FreshRSS_Context::$user_conf->read_ext_merc_host = (string)Minz_Request::param('read_mercury_host');
|
|
|
|
FreshRSS_Context::$user_conf->read_ext_read_host = (string)Minz_Request::param('read_readability_host');
|
|
|
|
|
|
|
|
FreshRSS_Context::$user_conf->save();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
$this->loadConfigValues();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2022-05-20 17:55:33 +00:00
|
|
|
}
|