<?php
/**
- * @file src/Worker/Cron.php
+ * @copyright Copyright (C) 2020, Friendica
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ *
*/
+
namespace Friendica\Worker;
-use Friendica\BaseObject;
use Friendica\Core\Addon;
-use Friendica\Core\Config;
use Friendica\Core\Hook;
use Friendica\Core\Logger;
use Friendica\Core\Protocol;
use Friendica\Core\Worker;
use Friendica\Database\DBA;
+use Friendica\DI;
use Friendica\Model\Contact;
use Friendica\Util\DateTimeFormat;
{
public static function execute()
{
- $a = BaseObject::getApp();
+ $a = DI::app();
- $last = Config::get('system', 'last_cron');
+ $last = DI::config()->get('system', 'last_cron');
- $poll_interval = intval(Config::get('system', 'cron_interval'));
+ $poll_interval = intval(DI::config()->get('system', 'cron_interval'));
if ($last) {
$next = $last + ($poll_interval * 60);
// Fork the cron jobs in separate parts to avoid problems when one of them is crashing
Hook::fork($a->queue['priority'], "cron");
- // run the process to discover global contacts in the background
- Worker::add(PRIORITY_LOW, "DiscoverPoCo");
+ // run the process to update server directories in the background
+ Worker::add(PRIORITY_LOW, 'UpdateServerDirectories');
// run the process to update locally stored global contacts in the background
- Worker::add(PRIORITY_LOW, 'DiscoverContacts');
+ Worker::add(PRIORITY_LOW, 'UpdateGContacts');
// Expire and remove user entries
Worker::add(PRIORITY_MEDIUM, "CronJobs", "expire_and_remove_users");
Worker::add(PRIORITY_LOW, "CronJobs", "repair_database");
// once daily run birthday_updates and then expire in background
- $d1 = Config::get('system', 'last_expire_day');
+ $d1 = DI::config()->get('system', 'last_expire_day');
$d2 = intval(DateTimeFormat::utcNow('d'));
// Daily cron calls
// update nodeinfo data
Worker::add(PRIORITY_LOW, "CronJobs", "nodeinfo");
- Worker::add(PRIORITY_LOW, "DiscoverPoCo", "update_server");
+ Worker::add(PRIORITY_LOW, 'UpdateGServers');
Worker::add(PRIORITY_LOW, 'UpdateSuggestions');
// check upstream version?
Worker::add(PRIORITY_LOW, 'CheckVersion');
- Config::set('system', 'last_expire_day', $d2);
+ self::checkdeletedContacts();
+
+ DI::config()->set('system', 'last_expire_day', $d2);
}
// Hourly cron calls
- if (Config::get('system', 'last_cron_hourly', 0) + 3600 < time()) {
+ if (DI::config()->get('system', 'last_cron_hourly', 0) + 3600 < time()) {
// Delete all done workerqueue entries
DBA::delete('workerqueue', ['`done` AND `executed` < UTC_TIMESTAMP() - INTERVAL 1 HOUR']);
// Optimizing this table only last seconds
- if (Config::get('system', 'optimize_workerqueue', false)) {
+ if (DI::config()->get('system', 'optimize_workerqueue', false)) {
DBA::e("OPTIMIZE TABLE `workerqueue`");
}
- Config::set('system', 'last_cron_hourly', time());
+ DI::config()->set('system', 'last_cron_hourly', time());
}
// Ensure to have a .htaccess file.
Logger::log('cron: end');
- Config::set('system', 'last_cron', time());
+ DI::config()->set('system', 'last_cron', time());
return;
}
/**
- * @brief Update public contacts
+ * Checks for contacts that are about to be deleted and ensures that they are removed.
+ * This should be done automatically in the "remove" function. This here is a cleanup job.
+ */
+ private static function checkdeletedContacts()
+ {
+ $contacts = DBA::select('contact', ['id'], ['deleted' => true]);
+ while ($contact = DBA::fetch($contacts)) {
+ Worker::add(PRIORITY_MEDIUM, 'RemoveContact', $contact['id']);
+ }
+ DBA::close($contacts);
+ }
+
+ /**
+ * Update public contacts
+ *
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
*/
private static function updatePublicContacts() {
}
/**
- * @brief Poll contacts for unreceived messages
+ * Poll contacts for unreceived messages
*
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
*/
private static function pollContacts() {
- $min_poll_interval = Config::get('system', 'min_poll_interval', 1);
+ $min_poll_interval = DI::config()->get('system', 'min_poll_interval', 1);
Addon::reload();
FROM `user`
STRAIGHT_JOIN `contact`
ON `contact`.`uid` = `user`.`uid` AND `contact`.`poll` != ''
- AND `contact`.`network` IN (?, ?, ?, ?)
+ AND `contact`.`network` IN (?, ?, ?, ?, ?)
AND NOT `contact`.`self` AND NOT `contact`.`blocked`
AND `contact`.`rel` != ?
WHERE NOT `user`.`account_expired` AND NOT `user`.`account_removed`";
- $parameters = [Protocol::DFRN, Protocol::OSTATUS, Protocol::FEED, Protocol::MAIL, Contact::FOLLOWER];
+ $parameters = [Protocol::DFRN, Protocol::ACTIVITYPUB, Protocol::OSTATUS, Protocol::FEED, Protocol::MAIL, Contact::FOLLOWER];
// Only poll from those with suitable relationships,
// and which have a polling address and ignore Diaspora since
// we are unable to match those posts with a Diaspora GUID and prevent duplicates.
- $abandon_days = intval(Config::get('system', 'account_abandon_days'));
+ $abandon_days = intval(DI::config()->get('system', 'account_abandon_days'));
if ($abandon_days < 1) {
$abandon_days = 0;
}
$contact['priority'] = 3;
}
+ // ActivityPub is checked once a week
+ if ($contact['network'] == Protocol::ACTIVITYPUB) {
+ $contact['priority'] = 4;
+ }
+
// Check archived contacts once a month
if ($contact['archive']) {
$contact['priority'] = 5;