mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2026-03-08 00:17:15 -05:00
Merge pull request #1495 from Alkarex/PSHB-unsubscribe
PSHB better unsubscribe
This commit is contained in:
@@ -12,6 +12,7 @@
|
||||
* Add support for PHP 7.1 [#1471](https://github.com/FreshRSS/FreshRSS/issues/1471)
|
||||
* PostgreSQL is not experimental anymore [#1476](https://github.com/FreshRSS/FreshRSS/pull/1476)
|
||||
* Bug fixing
|
||||
* Fix PubSubHubbub bugs when deleting users, and improved behaviour when removing feeds [#1495](https://github.com/FreshRSS/FreshRSS/pull/1495)
|
||||
* Fix SQL uniqueness bug with PostgreSQL [#1476](https://github.com/FreshRSS/FreshRSS/pull/1476)
|
||||
* (Require manual update for existing installations)
|
||||
* Do not require PHP extension `fileinfo` for favicons [#1461](https://github.com/FreshRSS/FreshRSS/issues/1461)
|
||||
|
||||
@@ -213,6 +213,7 @@ class FreshRSS_user_Controller extends Minz_ActionController {
|
||||
$userDAO = new FreshRSS_UserDAO();
|
||||
$ok &= $userDAO->deleteUser($username);
|
||||
$ok &= recursive_unlink($user_data);
|
||||
array_map('unlink', glob(PSHB_PATH . '/feeds/*/' . $username . '.txt'));
|
||||
}
|
||||
return $ok;
|
||||
}
|
||||
|
||||
@@ -429,7 +429,7 @@ class FreshRSS_Feed extends Minz_Model {
|
||||
}
|
||||
} else {
|
||||
@mkdir($path, 0777, true);
|
||||
$key = sha1($path . FreshRSS_Context::$system_conf->salt . uniqid(mt_rand(), true));
|
||||
$key = sha1($path . FreshRSS_Context::$system_conf->salt);
|
||||
$hubJson = array(
|
||||
'hub' => $this->hubUrl,
|
||||
'key' => $key,
|
||||
@@ -451,15 +451,16 @@ class FreshRSS_Feed extends Minz_Model {
|
||||
|
||||
//Parameter true to subscribe, false to unsubscribe.
|
||||
function pubSubHubbubSubscribe($state) {
|
||||
if (FreshRSS_Context::$system_conf->base_url && $this->hubUrl && $this->selfUrl) {
|
||||
$hubFilename = PSHB_PATH . '/feeds/' . base64url_encode($this->selfUrl) . '/!hub.json';
|
||||
$url = $this->selfUrl ? $this->selfUrl : $this->url;
|
||||
if (FreshRSS_Context::$system_conf->base_url && $url) {
|
||||
$hubFilename = PSHB_PATH . '/feeds/' . base64url_encode($url) . '/!hub.json';
|
||||
$hubFile = @file_get_contents($hubFilename);
|
||||
if ($hubFile === false) {
|
||||
Minz_Log::warning('JSON not found for PubSubHubbub: ' . $this->url);
|
||||
return false;
|
||||
}
|
||||
$hubJson = json_decode($hubFile, true);
|
||||
if (!$hubJson || empty($hubJson['key']) || !ctype_xdigit($hubJson['key'])) {
|
||||
if (!$hubJson || empty($hubJson['key']) || !ctype_xdigit($hubJson['key']) || empty($hubJson['hub'])) {
|
||||
Minz_Log::warning('Invalid JSON for PubSubHubbub: ' . $this->url);
|
||||
return false;
|
||||
}
|
||||
@@ -474,13 +475,13 @@ class FreshRSS_Feed extends Minz_Model {
|
||||
}
|
||||
$ch = curl_init();
|
||||
curl_setopt_array($ch, array(
|
||||
CURLOPT_URL => $this->hubUrl,
|
||||
CURLOPT_URL => $hubJson['hub'],
|
||||
CURLOPT_FOLLOWLOCATION => true,
|
||||
CURLOPT_RETURNTRANSFER => true,
|
||||
CURLOPT_USERAGENT => 'FreshRSS/' . FRESHRSS_VERSION . ' (' . PHP_OS . '; ' . FRESHRSS_WEBSITE . ')',
|
||||
CURLOPT_POSTFIELDS => 'hub.verify=sync'
|
||||
. '&hub.mode=' . ($state ? 'subscribe' : 'unsubscribe')
|
||||
. '&hub.topic=' . urlencode($this->selfUrl)
|
||||
. '&hub.topic=' . urlencode($url)
|
||||
. '&hub.callback=' . urlencode($callbackUrl)
|
||||
)
|
||||
);
|
||||
@@ -488,7 +489,7 @@ class FreshRSS_Feed extends Minz_Model {
|
||||
$info = curl_getinfo($ch);
|
||||
|
||||
file_put_contents(USERS_PATH . '/_/log_pshb.txt', date('c') . "\t" .
|
||||
'PubSubHubbub ' . ($state ? 'subscribe' : 'unsubscribe') . ' to ' . $this->selfUrl .
|
||||
'PubSubHubbub ' . ($state ? 'subscribe' : 'unsubscribe') . ' to ' . $url .
|
||||
' with callback ' . $callbackUrl . ': ' . $info['http_code'] . ' ' . $response . "\n", FILE_APPEND);
|
||||
|
||||
if (substr($info['http_code'], 0, 1) == '2') {
|
||||
|
||||
@@ -23,8 +23,13 @@ if (!ctype_xdigit($key)) {
|
||||
chdir(PSHB_PATH);
|
||||
$canonical64 = @file_get_contents('keys/' . $key . '.txt');
|
||||
if ($canonical64 === false) {
|
||||
if (!empty($_REQUEST['hub_mode']) && $_REQUEST['hub_mode'] === 'unsubscribe') {
|
||||
logMe('Warning: Accept unknown unsubscribe');
|
||||
header('Connection: close');
|
||||
exit(isset($_REQUEST['hub_challenge']) ? $_REQUEST['hub_challenge'] : '');
|
||||
}
|
||||
header('HTTP/1.1 404 Not Found');
|
||||
logMe('Error: Feed key not found!: ' . $key);
|
||||
logMe('Warning: Feed key not found!: ' . $key);
|
||||
die('Feed key not found!');
|
||||
}
|
||||
$canonical64 = trim($canonical64);
|
||||
@@ -36,7 +41,7 @@ if (!preg_match('/^[A-Za-z0-9_-]+$/D', $canonical64)) {
|
||||
$hubFile = @file_get_contents('feeds/' . $canonical64 . '/!hub.json');
|
||||
if ($hubFile === false) {
|
||||
header('HTTP/1.1 404 Not Found');
|
||||
//@unlink('keys/' . $key . '.txt');
|
||||
unlink('keys/' . $key . '.txt');
|
||||
logMe('Error: Feed info not found!: ' . $canonical64);
|
||||
die('Feed info not found!');
|
||||
}
|
||||
@@ -50,8 +55,19 @@ chdir('feeds/' . $canonical64);
|
||||
$users = glob('*.txt', GLOB_NOSORT);
|
||||
if (empty($users)) {
|
||||
header('HTTP/1.1 410 Gone');
|
||||
logMe('Error: Nobody is subscribed to this feed anymore!: ' . $canonical64);
|
||||
die('Nobody is subscribed to this feed anymore!');
|
||||
$url = base64url_decode($canonical64);
|
||||
logMe('Warning: Nobody subscribes to this feed anymore!: ' . $url);
|
||||
unlink('../../keys/' . $key . '.txt');
|
||||
Minz_Configuration::register('system',
|
||||
DATA_PATH . '/config.php',
|
||||
DATA_PATH . '/config.default.php');
|
||||
FreshRSS_Context::$system_conf = Minz_Configuration::get('system');
|
||||
$feed = new FreshRSS_Feed($url);
|
||||
$feed->pubSubHubbubSubscribe(false);
|
||||
unlink('!hub.json');
|
||||
chdir('..');
|
||||
recursive_unlink($canonical64);
|
||||
die('Nobody subscribes to this feed anymore!');
|
||||
}
|
||||
|
||||
if (!empty($_REQUEST['hub_mode']) && $_REQUEST['hub_mode'] === 'subscribe') {
|
||||
@@ -108,7 +124,9 @@ $nb = 0;
|
||||
foreach ($users as $userFilename) {
|
||||
$username = basename($userFilename, '.txt');
|
||||
if (!file_exists(USERS_PATH . '/' . $username . '/config.php')) {
|
||||
break;
|
||||
logMe('Warning: Removing broken user link: ' . $username . ' for ' . $self);
|
||||
unlink($userFilename);
|
||||
continue;
|
||||
}
|
||||
|
||||
try {
|
||||
@@ -119,11 +137,14 @@ foreach ($users as $userFilename) {
|
||||
new Minz_ModelPdo($username); //TODO: FIXME: Quick-fix while waiting for a better FreshRSS() constructor/init
|
||||
FreshRSS_Context::init();
|
||||
list($updated_feeds, $feed) = FreshRSS_feed_Controller::actualizeFeed(0, $self, false, $simplePie);
|
||||
if ($updated_feeds > 0) {
|
||||
if ($updated_feeds > 0 || $feed != false) {
|
||||
$nb++;
|
||||
} else {
|
||||
logMe('Warning: User ' . $username . ' does not subscribe anymore to ' . $self);
|
||||
unlink($userFilename);
|
||||
}
|
||||
} catch (Exception $e) {
|
||||
logMe('Error: ' . $e->getMessage());
|
||||
logMe('Error: ' . $e->getMessage() . ' for user ' . $username . ' and feed ' . $self);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -132,8 +153,8 @@ unset($simplePie);
|
||||
|
||||
if ($nb === 0) {
|
||||
header('HTTP/1.1 410 Gone');
|
||||
logMe('Error: Nobody is subscribed to this feed anymore after all!: ' . $self);
|
||||
die('Nobody is subscribed to this feed anymore after all!');
|
||||
logMe('Warning: Nobody subscribes to this feed anymore after all!: ' . $self);
|
||||
die('Nobody subscribes to this feed anymore after all!');
|
||||
} elseif (!empty($hubJson['error'])) {
|
||||
$hubJson['error'] = false;
|
||||
file_put_contents('./!hub.json', json_encode($hubJson));
|
||||
|
||||
Reference in New Issue
Block a user