friendica/src/Worker/UpdateGContacts.php

84 lines
2.4 KiB
PHP
Raw Normal View History

2019-12-20 16:04:38 -05:00
<?php
/**
2019-12-21 13:57:00 -05:00
* @file src/Worker/UpdateGContacts.php
2019-12-20 16:04:38 -05:00
*/
namespace Friendica\Worker;
use Friendica\Core\Logger;
use Friendica\Core\Protocol;
use Friendica\Core\Worker;
use Friendica\Database\DBA;
use Friendica\DI;
2020-01-01 12:54:36 -05:00
use Friendica\Model\GContact;
2019-12-20 16:04:38 -05:00
use Friendica\Model\GServer;
use Friendica\Util\DateTimeFormat;
use Friendica\Util\Strings;
2019-12-21 13:57:00 -05:00
class UpdateGContacts
2019-12-20 16:04:38 -05:00
{
2019-12-21 15:18:44 -05:00
/**
* Updates global contacts
*/
2019-12-20 16:04:38 -05:00
public static function execute()
{
if (!DI::config()->get('system', 'poco_completion')) {
2019-12-20 16:04:38 -05:00
return;
}
2019-12-21 15:18:44 -05:00
Logger::info('Update global contacts');
2019-12-20 16:04:38 -05:00
$starttime = time();
2019-12-20 16:27:49 -05:00
$contacts = DBA::p("SELECT `url`, `created`, `updated`, `last_failure`, `last_contact`, `server_url`, `network` FROM `gcontact`
2019-12-20 16:04:38 -05:00
WHERE `last_contact` < UTC_TIMESTAMP - INTERVAL 1 MONTH AND
`last_failure` < UTC_TIMESTAMP - INTERVAL 1 MONTH AND
2019-12-21 15:18:44 -05:00
`network` IN (?, ?, ?, ?, ?, '') ORDER BY rand()",
Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS, Protocol::FEED);
2019-12-20 16:04:38 -05:00
$checked = 0;
while ($contact = DBA::fetch($contacts)) {
$urlparts = parse_url($contact['url']);
if (empty($urlparts['scheme'])) {
DBA::update('gcontact', ['network' => Protocol::PHANTOM],
['nurl' => Strings::normaliseLink($contact['url'])]);
continue;
}
if (in_array($urlparts['host'], ['twitter.com', 'identi.ca'])) {
$networks = ['twitter.com' => Protocol::TWITTER, 'identi.ca' => Protocol::PUMPIO];
DBA::update('gcontact', ['network' => $networks[$urlparts['host']]],
['nurl' => Strings::normaliseLink($contact['url'])]);
continue;
}
2020-01-01 12:54:36 -05:00
$server_url = GContact::getBasepath($contact['url'], true);
2019-12-20 16:04:38 -05:00
$force_update = false;
if (!empty($contact['server_url'])) {
$force_update = (Strings::normaliseLink($contact['server_url']) != Strings::normaliseLink($server_url));
$server_url = $contact['server_url'];
}
if ((empty($server_url) && ($contact['network'] == Protocol::FEED)) || $force_update || GServer::check($server_url, $contact['network'])) {
Logger::info('Check profile', ['profile' => $contact['url']]);
Worker::add(PRIORITY_LOW, 'UpdateGContact', $contact['url'], 'force');
if (++$checked > 100) {
return;
}
} else {
DBA::update('gcontact', ['last_failure' => DateTimeFormat::utcNow()],
['nurl' => Strings::normaliseLink($contact['url'])]);
}
// Quit the loop after 3 minutes
if (time() > ($starttime + 180)) {
return;
}
}
}
}