2019-12-20 22:12:44 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @file src/Worker/UpdateServers.php
|
|
|
|
*/
|
|
|
|
namespace Friendica\Worker;
|
|
|
|
|
|
|
|
use Friendica\Core\Logger;
|
|
|
|
use Friendica\Core\Worker;
|
|
|
|
use Friendica\Database\DBA;
|
|
|
|
use Friendica\Protocol\PortableContact;
|
|
|
|
|
|
|
|
class UpdateServers
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @brief Updates the first 250 servers
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function execute()
|
|
|
|
{
|
2019-12-20 22:27:49 +01:00
|
|
|
$gservers = DBA::p("SELECT `url`, `created`, `last_failure`, `last_contact` FROM `gserver` ORDER BY rand()");
|
2019-12-20 22:12:44 +01:00
|
|
|
if (!DBA::isResult($gservers)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$updated = 0;
|
|
|
|
|
2019-12-21 05:23:26 +01:00
|
|
|
while ($gserver = DBA::fetch($gservers)) {
|
2019-12-20 22:12:44 +01:00
|
|
|
if (!PortableContact::updateNeeded($gserver['created'], '', $gserver['last_failure'], $gserver['last_contact'])) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
Logger::info('Update server status', ['server' => $gserver['url']]);
|
|
|
|
|
2019-12-20 22:46:30 +01:00
|
|
|
Worker::add(PRIORITY_LOW, 'CheckServer', $gserver['url']);
|
2019-12-20 22:12:44 +01:00
|
|
|
|
|
|
|
if (++$updated > 250) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|