mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2026-02-02 09:31:06 -05:00
* Improve feed refresh Better account for some edge cases for cron and automatic labels fix https://github.com/FreshRSS/FreshRSS/issues/6089 fix https://github.com/FreshRSS/FreshRSS/issues/6109 * Apply labels also to new entries already marked as read * Add case most relevant for cron
50 lines
1.4 KiB
PHP
Executable File
50 lines
1.4 KiB
PHP
Executable File
#!/usr/bin/env php
|
|
<?php
|
|
declare(strict_types=1);
|
|
require(__DIR__ . '/_cli.php');
|
|
|
|
performRequirementCheck(FreshRSS_Context::systemConf()->db['type'] ?? '');
|
|
|
|
$parameters = [
|
|
'long' => [
|
|
'user' => ':'
|
|
],
|
|
'short' => [],
|
|
'deprecated' => [],
|
|
];
|
|
|
|
$options = parseCliParams($parameters);
|
|
|
|
if (!empty($options['invalid']) || empty($options['valid']['user']) || !is_string($options['valid']['user'])) {
|
|
fail('Usage: ' . basename(__FILE__) . " --user username");
|
|
}
|
|
|
|
$username = cliInitUser($options['valid']['user']);
|
|
fwrite(STDERR, 'FreshRSS actualizing user “' . $username . "”…\n");
|
|
|
|
$databaseDAO = FreshRSS_Factory::createDatabaseDAO();
|
|
$databaseDAO->minorDbMaintenance();
|
|
Minz_ExtensionManager::callHookVoid('freshrss_user_maintenance');
|
|
|
|
FreshRSS_feed_Controller::commitNewEntries();
|
|
$result = FreshRSS_category_Controller::refreshDynamicOpmls();
|
|
if (!empty($result['errors'])) {
|
|
$errors = $result['errors'];
|
|
fwrite(STDERR, "FreshRSS error refreshing $errors dynamic OPMLs!\n");
|
|
}
|
|
if (!empty($result['successes'])) {
|
|
$successes = $result['successes'];
|
|
echo "FreshRSS refreshed $successes dynamic OPMLs for $username\n";
|
|
}
|
|
|
|
[$nbUpdatedFeeds, , $nbNewArticles] = FreshRSS_feed_Controller::actualizeFeeds();
|
|
if ($nbNewArticles > 0) {
|
|
FreshRSS_feed_Controller::commitNewEntries();
|
|
}
|
|
|
|
echo "FreshRSS actualized $nbUpdatedFeeds feeds for $username ($nbNewArticles new articles)\n";
|
|
|
|
invalidateHttpCache($username);
|
|
|
|
done($nbUpdatedFeeds > 0);
|