#!/usr/bin/env php auth_type = 'none'; // avoid necessity to be logged in (not saved!) define('SIMPLEPIE_SYSLOG_ENABLED', FreshRSS_Context::$system_conf->simplepie_syslog_enabled); /** * Writes to FreshRSS admin log, and if it is not already done by default, * writes to syslog (only if simplepie_syslog_enabled in FreshRSS configuration) and to STDOUT */ function notice($message) { Minz_Log::notice($message, ADMIN_LOG); // @phpstan-ignore-next-line if (!COPY_LOG_TO_SYSLOG && SIMPLEPIE_SYSLOG_ENABLED) { syslog(LOG_NOTICE, $message); } // @phpstan-ignore-next-line if (defined('STDOUT') && !COPY_SYSLOG_TO_STDERR) { fwrite(STDOUT, $message . "\n"); //Unbuffered } } notice('FreshRSS starting feeds actualization at ' . $begin_date->format('c')); // make sure the PHP setup of the CLI environment is compatible with FreshRSS as well echo 'Failed requirements!', "\n"; performRequirementCheck(FreshRSS_Context::$system_conf->db['type']); ob_clean(); echo 'Results: ', "\n"; //Buffered // Create the list of users to actualize. // Users are processed in a random order but always start with default user $users = listUsers(); shuffle($users); if (FreshRSS_Context::$system_conf->default_user !== '') { array_unshift($users, FreshRSS_Context::$system_conf->default_user); $users = array_unique($users); } $limits = FreshRSS_Context::$system_conf->limits; $min_last_activity = time() - $limits['max_inactivity']; foreach ($users as $user) { FreshRSS_Context::initUser($user); if (FreshRSS_Context::$user_conf == null) { notice('Invalid user ' . $user); continue; } if (!FreshRSS_Context::$user_conf->enabled) { notice('FreshRSS skip disabled user ' . $user); continue; } if (($user !== FreshRSS_Context::$system_conf->default_user) && (FreshRSS_UserDAO::mtime($user) < $min_last_activity)) { notice('FreshRSS skip inactive user ' . $user); continue; } FreshRSS_Auth::giveAccess(); Minz_ExtensionManager::callHook('freshrss_user_maintenance'); $app->init(); notice('FreshRSS actualize ' . $user . '…'); echo $user, ' '; //Buffered $app->run(); if (!invalidateHttpCache()) { Minz_Log::warning('FreshRSS write access problem in ' . join_path(USERS_PATH, $user, 'log.txt'), ADMIN_LOG); if (defined('STDERR')) { fwrite(STDERR, 'FreshRSS write access problem in ' . join_path(USERS_PATH, $user, 'log.txt') . "\n"); } } gc_collect_cycles(); } $end_date = date_create('now'); $duration = date_diff($end_date, $begin_date); notice('FreshRSS actualization done for ' . count($users) . ' users, using ' . format_bytes(memory_get_peak_usage(true)) . ' of memory, in ' . $duration->format('%a day(s), %h hour(s), %i minute(s) and %s seconds.')); echo 'End.', "\n"; ob_end_flush();