<?php
/**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2022, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
namespace Friendica\Worker;
use Friendica\Core\Logger;
-use Friendica\Core\Worker;
+use Friendica\Core\Search;
use Friendica\DI;
use Friendica\Model\Contact;
+use Friendica\Network\HTTPClient\Client\HttpClientAccept;
class PullDirectory
{
return;
}
- $directory = DI::config()->get('system', 'directory');
+ $directory = Search::getGlobalDirectory();
if (empty($directory)) {
Logger::info('No directory configured');
return;
Logger::info('Synchronization started.', ['now' => $now, 'directory' => $directory]);
- $result = DI::httpRequest()->fetch($directory . '/sync/pull/since/' . $now);
+ $result = DI::httpClient()->fetch($directory . '/sync/pull/since/' . $now, HttpClientAccept::JSON);
if (empty($result)) {
Logger::info('Directory server return empty result.', ['directory' => $directory]);
return;
return;
}
+ $result = Contact::addByUrls($contacts['results']);
+
$now = $contacts['now'] ?? 0;
- $count = $contacts['count'] ?? 0;
- $added = 0;
- $updated = 0;
- foreach ($contacts['results'] as $url) {
- $contact = Contact::getByURL($url, false, ['id']);
- if (empty($contact['id'])) {
- Worker::add(PRIORITY_LOW, 'AddContact', 0, $url);
- ++$added;
- } else {
- Worker::add(PRIORITY_LOW, "UpdateContact", $contact['id']);
- ++$updated;
- }
- }
DI::config()->set('system', 'last-directory-sync', $now);
- Logger::info('Synchronization ended.', ['now' => $now, 'count' => $count, 'added' => $added, 'updated' => $updated, 'directory' => $directory]);
+ Logger::info('Synchronization ended', ['now' => $now, 'count' => $result['count'], 'added' => $result['added'], 'updated' => $result['updated'], 'unchanged' => $result['unchanged'], 'directory' => $directory]);
}
}