2019-12-20 20:37:21 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2023-01-01 14:36:24 +00:00
|
|
|
* @copyright Copyright (C) 2010-2023, the Friendica project
|
2020-02-09 15:18:46 +00:00
|
|
|
*
|
|
|
|
* @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/>.
|
|
|
|
*
|
2019-12-20 20:37:21 +00:00
|
|
|
*/
|
2020-02-09 15:18:46 +00:00
|
|
|
|
2019-12-20 20:37:21 +00:00
|
|
|
namespace Friendica\Worker;
|
|
|
|
|
|
|
|
use Friendica\Core\Logger;
|
2020-08-01 16:15:18 +00:00
|
|
|
use Friendica\DI;
|
|
|
|
use Friendica\Model\Contact;
|
2019-12-21 06:39:22 +00:00
|
|
|
use Friendica\Model\GServer;
|
2022-04-02 18:26:11 +00:00
|
|
|
use Friendica\Network\HTTPClient\Client\HttpClientAccept;
|
2019-12-20 20:37:21 +00:00
|
|
|
|
2019-12-20 21:27:49 +00:00
|
|
|
class UpdateServerDirectory
|
2019-12-20 20:37:21 +00:00
|
|
|
{
|
2019-12-21 20:18:44 +00:00
|
|
|
/**
|
|
|
|
* Query the given server for their users
|
2023-01-01 14:36:24 +00:00
|
|
|
*
|
2020-08-01 16:15:18 +00:00
|
|
|
* @param array $gserver Server record
|
2019-12-21 20:18:44 +00:00
|
|
|
*/
|
2020-08-01 16:15:18 +00:00
|
|
|
public static function execute(array $gserver)
|
2019-12-20 20:37:21 +00:00
|
|
|
{
|
2020-08-01 16:15:18 +00:00
|
|
|
if ($gserver['directory-type'] == GServer::DT_MASTODON) {
|
|
|
|
self::discoverMastodonDirectory($gserver);
|
|
|
|
} elseif (!empty($gserver['poco'])) {
|
|
|
|
self::discoverPoCo($gserver);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private static function discoverPoCo(array $gserver)
|
|
|
|
{
|
2022-04-02 19:16:22 +00:00
|
|
|
$result = DI::httpClient()->fetch($gserver['poco'] . '?fields=urls', HttpClientAccept::JSON);
|
2020-08-01 16:15:18 +00:00
|
|
|
if (empty($result)) {
|
|
|
|
Logger::info('Empty result', ['url' => $gserver['url']]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$contacts = json_decode($result, true);
|
|
|
|
if (empty($contacts['entry'])) {
|
|
|
|
Logger::info('No contacts', ['url' => $gserver['url']]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
Logger::info('PoCo discovery started', ['poco' => $gserver['poco']]);
|
|
|
|
|
|
|
|
$urls = [];
|
2020-08-04 03:18:34 +00:00
|
|
|
foreach (array_column($contacts['entry'], 'urls') as $url_entries) {
|
|
|
|
foreach ($url_entries as $url_entry) {
|
2020-08-01 16:15:18 +00:00
|
|
|
if (empty($url_entry['type']) || empty($url_entry['value'])) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if ($url_entry['type'] == 'profile') {
|
|
|
|
$urls[] = $url_entry['value'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-02 13:37:43 +00:00
|
|
|
$result = Contact::addByUrls($urls);
|
2020-08-01 16:15:18 +00:00
|
|
|
|
2020-10-03 10:52:34 +00:00
|
|
|
Logger::info('PoCo discovery ended', ['count' => $result['count'], 'added' => $result['added'], 'updated' => $result['updated'], 'unchanged' => $result['unchanged'], 'poco' => $gserver['poco']]);
|
2020-08-01 16:15:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private static function discoverMastodonDirectory(array $gserver)
|
2023-01-01 14:36:24 +00:00
|
|
|
{
|
2022-04-02 19:16:22 +00:00
|
|
|
$result = DI::httpClient()->fetch($gserver['url'] . '/api/v1/directory?order=new&local=true&limit=200&offset=0', HttpClientAccept::JSON);
|
2020-08-01 16:15:18 +00:00
|
|
|
if (empty($result)) {
|
|
|
|
Logger::info('Empty result', ['url' => $gserver['url']]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$accounts = json_decode($result, true);
|
|
|
|
if (empty($accounts)) {
|
|
|
|
Logger::info('No contacts', ['url' => $gserver['url']]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
Logger::info('Account discovery started', ['url' => $gserver['url']]);
|
|
|
|
|
|
|
|
$urls = [];
|
|
|
|
foreach ($accounts as $account) {
|
|
|
|
if (!empty($account['url'])) {
|
|
|
|
$urls[] = $account['url'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-02 13:37:43 +00:00
|
|
|
$result = Contact::addByUrls($urls);
|
2020-08-01 16:15:18 +00:00
|
|
|
|
2020-10-03 10:52:34 +00:00
|
|
|
Logger::info('Account discovery ended', ['count' => $result['count'], 'added' => $result['added'], 'updated' => $result['updated'], 'unchanged' => $result['unchanged'], 'url' => $gserver['url']]);
|
2019-12-20 20:37:21 +00:00
|
|
|
}
|
|
|
|
}
|